/* * Copyright (c) 2021-2022 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef UTIL_H #define UTIL_H #include #include #include #include "define_multimodal.h" #include "struct_multimodal.h" namespace OHOS { extern "C" { int32_t ReadConfigInfo(const char* line, int32_t len, int32_t* element_key, int32_t* element_value); } namespace MMI { struct DeviceConfig { int32_t autoSwitch { 1 }; int32_t delayTime { 500 }; int32_t intervalTime { 50 }; int32_t keyboardType { 0 }; }; int64_t GetSysClockTime(); int64_t GetMillisTime(); uint64_t GetThisThreadId(); size_t StringSplit(const std::string &str, const std::string &sep, std::vector &vecList); std::string IdsListToString(const std::vector &list, const std::string &sep = ", "); int32_t GetPid(); const char* GetProgramName(); void SetThreadName(const std::string &name); void ReadProFile(const std::string &filePath, int32_t deviceId, std::map> &configMap); void ReadProConfigFile(const std::string &realPath, int32_t deviceId, std::map> &configKey); bool IsValidJsonPath(const std::string &filePath); std::string ReadJsonFile(const std::string &filePath); int32_t ReadCursorStyleFile(const std::string &filePath); int32_t ReadTomlFile(const std::string &filePath, DeviceConfig &devConf); std::string FileVerification(std::string &filePath, const std::string &checkExtension); std::string StringPrintf(const char *format, ...); inline void RemoveSpace(std::string &str) { str.erase(remove_if(str.begin(), str.end(), [](unsigned char c) { return std::isspace(c);}), str.end()); } template bool AddInt(T op1, T op2, T minVal, T maxVal, T &res) { if (op1 >= 0) { if (op2 > maxVal - op1) { return false; } } else { if (op2 < minVal - op1) { return false; } } res = op1 + op2; return true; } inline bool AddInt32(int32_t op1, int32_t op2, int32_t &res) { return AddInt(op1, op2, INT32_MIN, INT32_MAX, res); } inline bool AddInt64(int64_t op1, int64_t op2, int64_t &res) { return AddInt(op1, op2, INT64_MIN, INT64_MAX, res); } } // namespace MMI } // namespace OHOS #endif // UTIL_H