1 /*
2 * Copyright (c) 2021 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15 #ifndef RDB_JSKIT_COMMON_H
16 #define RDB_JSKIT_COMMON_H
17
18 #include <string>
19 #include <vector>
20
21 #include "hilog/log.h"
22 #include "rdb_errno.h"
23
24 namespace OHOS {
25 namespace RdbJsKit {
26 static const OHOS::HiviewDFX::HiLogLabel PREFIX_LABEL = { LOG_CORE, 0xD001650, "RdbJsKit" };
27
28 #define LOG_DEBUG(...) ((void)OHOS::HiviewDFX::HiLog::Debug(PREFIX_LABEL, __VA_ARGS__))
29 #define LOG_INFO(...) ((void)OHOS::HiviewDFX::HiLog::Info(PREFIX_LABEL, __VA_ARGS__))
30 #define LOG_WARN(...) ((void)OHOS::HiviewDFX::HiLog::Warn(PREFIX_LABEL, __VA_ARGS__))
31 #define LOG_ERROR(...) ((void)OHOS::HiviewDFX::HiLog::Error(PREFIX_LABEL, __VA_ARGS__))
32 #define LOG_FATAL(...) ((void)OHOS::HiviewDFX::HiLog::Fatal(PREFIX_LABEL, __VA_ARGS__))
33
34 static const std::vector<std::string> ERR_INFO {
35 "E_ERROR",
36 "E_CANNOT_UPDATE_READONLY",
37 "E_REMOVE_FILE",
38 "E_EMPTY_FILE_NAME",
39 "E_EMPTY_TABLE_NAME",
40 "E_EMPTY_VALUES_BUCKET",
41 "E_INVALID_STATEMENT",
42 "E_INVALID_COLUMN_INDEX",
43 "E_INVALID_COLUMN_TYPE",
44 "E_INVALID_COLUMN_NAME",
45 "E_QUERY_IN_EXECUTE",
46 "E_TRANSACTION_IN_EXECUTE",
47 "E_EXECUTE_IN_STEP_QUERY",
48 "E_EXECUTE_WRITE_IN_READ_CONNECTION",
49 "E_BEGIN_TRANSACTION_IN_READ_CONNECTION",
50 "E_NO_TRANSACTION_IN_SESSION",
51 "E_MORE_STEP_QUERY_IN_ONE_SESSION",
52 "E_NO_ROW_IN_QUERY",
53 "E_INVALID_BIND_ARGS_COUNT",
54 "E_INVALID_OBJECT_TYPE",
55 "E_INVALID_CONFLICT_FLAG",
56 "E_HAVING_CLAUSE_NOT_IN_GROUP_BY",
57 "E_NOT_SUPPORTED_BY_STEP_RESULT_SET",
58 "E_STEP_RESULT_SET_CROSS_THREADS",
59 "E_STEP_RESULT_QUERY_NOT_EXECUTED",
60 "E_STEP_RESULT_IS_AFTER_LAST",
61 "E_STEP_RESULT_QUERY_EXCEEDED",
62 "E_STATEMENT_NOT_PREPARED",
63 "E_EXECUTE_RESULT_INCORRECT",
64 "E_STEP_RESULT_CLOSED",
65 "E_RELATIVE_PATH",
66 "E_EMPTY_NEW_ENCRYPT_KEY",
67 "E_CHANGE_UNENCRYPTED_TO_ENCRYPTED",
68 "E_CHANGE_ENCRYPT_KEY_IN_BUSY",
69 "E_STEP_STATEMENT_NOT_INIT",
70 "E_NOT_SUPPORTED_ATTACH_IN_WAL_MODE"
71 };
72
GetErrStr(int err)73 static inline const char *GetErrStr(int err)
74 {
75 if (err == OHOS::NativeRdb::E_OK) {
76 return nullptr;
77 }
78 size_t index = err - OHOS::NativeRdb::E_BASE - 1;
79 if (index >= ERR_INFO.size() || index < 0) {
80 return "Unkown error";
81 }
82 return ERR_INFO.at(index).c_str();
83 }
84 } // namespace RdbJsKit
85 } // namespace OHOS
86
87 #endif
88