122736c2fSopenharmony_ci/* 222736c2fSopenharmony_ci * Copyright (c) 2022-2022 Huawei Device Co., Ltd. 322736c2fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 422736c2fSopenharmony_ci * you may not use this file except in compliance with the License. 522736c2fSopenharmony_ci * You may obtain a copy of the License at 622736c2fSopenharmony_ci * 722736c2fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 822736c2fSopenharmony_ci * 922736c2fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 1022736c2fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 1122736c2fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1222736c2fSopenharmony_ci * See the License for the specific language governing permissions and 1322736c2fSopenharmony_ci * limitations under the License. 1422736c2fSopenharmony_ci */ 1522736c2fSopenharmony_ci 1622736c2fSopenharmony_ci#include "inputmethod_trace.h" 1722736c2fSopenharmony_ci 1822736c2fSopenharmony_ci#include "hitrace_meter.h" 1922736c2fSopenharmony_ci 2022736c2fSopenharmony_cinamespace OHOS { 2122736c2fSopenharmony_cinamespace MiscServices { 2222736c2fSopenharmony_ciconstexpr uint64_t HITRACE_TAG_MISC = (1ULL << 41); // Notification module tag. 2322736c2fSopenharmony_civoid InitHiTrace() 2422736c2fSopenharmony_ci{ 2522736c2fSopenharmony_ci UpdateTraceLabel(); 2622736c2fSopenharmony_ci} 2722736c2fSopenharmony_ci 2822736c2fSopenharmony_civoid ValueTrace(const std::string &name, int64_t count) 2922736c2fSopenharmony_ci{ 3022736c2fSopenharmony_ci CountTrace(HITRACE_TAG_MISC, name, count); 3122736c2fSopenharmony_ci} 3222736c2fSopenharmony_ci 3322736c2fSopenharmony_civoid StartAsync(const std::string &value, int32_t taskId) 3422736c2fSopenharmony_ci{ 3522736c2fSopenharmony_ci StartAsyncTrace(HITRACE_TAG_MISC, value, taskId); 3622736c2fSopenharmony_ci} 3722736c2fSopenharmony_ci 3822736c2fSopenharmony_civoid FinishAsync(const std::string &value, int32_t taskId) 3922736c2fSopenharmony_ci{ 4022736c2fSopenharmony_ci FinishAsyncTrace(HITRACE_TAG_MISC, value, taskId); 4122736c2fSopenharmony_ci} 4222736c2fSopenharmony_ci 4322736c2fSopenharmony_ciInputMethodSyncTrace::InputMethodSyncTrace(const std::string &value) 4422736c2fSopenharmony_ci{ 4522736c2fSopenharmony_ci StartTrace(HITRACE_TAG_MISC, value); 4622736c2fSopenharmony_ci} 4722736c2fSopenharmony_ci 4822736c2fSopenharmony_ciInputMethodSyncTrace::InputMethodSyncTrace(const std::string &value, const std::string &id) 4922736c2fSopenharmony_ci{ 5022736c2fSopenharmony_ci auto info = value + "_" + id; 5122736c2fSopenharmony_ci StartTrace(HITRACE_TAG_MISC, info); 5222736c2fSopenharmony_ci} 5322736c2fSopenharmony_ci 5422736c2fSopenharmony_ciInputMethodSyncTrace::~InputMethodSyncTrace() 5522736c2fSopenharmony_ci{ 5622736c2fSopenharmony_ci FinishTrace(HITRACE_TAG_MISC); 5722736c2fSopenharmony_ci} 5822736c2fSopenharmony_ci} // namespace MiscServices 5922736c2fSopenharmony_ci} // namespace OHOS