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