• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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