Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
2742159f
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2742159f
编写于
4月 29, 2021
作者:
H
Haojun Liao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[td-3967]1). fix escape char error in sql. 2) refactor.
上级
2617bf2b
变更
19
隐藏空白更改
内联
并排
Showing
19 changed file
with
102 addition
and
76 deletion
+102
-76
src/client/inc/tschemautil.h
src/client/inc/tschemautil.h
+1
-1
src/client/src/tscParseInsert.c
src/client/src/tscParseInsert.c
+21
-12
src/client/src/tscPrepare.c
src/client/src/tscPrepare.c
+1
-1
src/client/src/tscSQLParser.c
src/client/src/tscSQLParser.c
+7
-7
src/client/src/tscSql.c
src/client/src/tscSql.c
+1
-1
src/client/src/tscUtil.c
src/client/src/tscUtil.c
+4
-4
src/client/tests/timeParseTest.cpp
src/client/tests/timeParseTest.cpp
+1
-1
src/common/inc/tname.h
src/common/inc/tname.h
+1
-1
src/common/inc/tvariant.h
src/common/inc/tvariant.h
+1
-1
src/common/src/tname.c
src/common/src/tname.c
+1
-1
src/common/src/tvariant.c
src/common/src/tvariant.c
+7
-7
src/os/tests/test.cpp
src/os/tests/test.cpp
+1
-1
src/query/inc/qSqlparser.h
src/query/inc/qSqlparser.h
+1
-1
src/query/src/qSqlParser.c
src/query/src/qSqlParser.c
+3
-3
src/query/src/sql.c
src/query/src/sql.c
+3
-3
src/query/tests/tsBufTest.cpp
src/query/tests/tsBufTest.cpp
+2
-2
src/query/tests/unitTest.cpp
src/query/tests/unitTest.cpp
+7
-7
src/util/inc/ttoken.h
src/util/inc/ttoken.h
+16
-13
src/util/src/ttokenizer.c
src/util/src/ttokenizer.c
+23
-9
未找到文件。
src/client/inc/tschemautil.h
浏览文件 @
2742159f
...
...
@@ -21,8 +21,8 @@ extern "C" {
#endif
#include "taosmsg.h"
#include "tstoken.h"
#include "tsclient.h"
#include "ttoken.h"
/**
* get the number of tags of this table
...
...
src/client/src/tscParseInsert.c
浏览文件 @
2742159f
...
...
@@ -29,8 +29,7 @@
#include "taosdef.h"
#include "tscLog.h"
#include "tscSubquery.h"
#include "tstoken.h"
#include "ttoken.h"
#include "tdataformat.h"
...
...
@@ -463,23 +462,33 @@ int tsParseOneRow(char **str, STableDataBlocks *pDataBlocks, SSqlCmd *pCmd, int1
// Remove quotation marks
if
(
TK_STRING
==
sToken
.
type
)
{
// delete escape character: \\, \', \"
char
delim
=
sToken
.
z
[
0
];
//
char delim = sToken.z[0];
int32_t
cnt
=
0
;
int32_t
j
=
0
;
for
(
uint32_t
k
=
1
;
k
<
sToken
.
n
-
1
;
++
k
)
{
if
(
sToken
.
z
[
k
]
==
delim
||
sToken
.
z
[
k
]
==
'\\'
)
{
if
(
sToken
.
z
[
k
+
1
]
==
delim
)
{
cnt
++
;
tmpTokenBuf
[
j
]
=
sToken
.
z
[
k
+
1
];
j
++
;
k
++
;
continue
;
}
if
(
sToken
.
z
[
k
]
==
'\\'
)
{
cnt
++
;
tmpTokenBuf
[
j
]
=
GET_ESCAPE_CHAR
(
sToken
.
z
[
k
+
1
]);
j
++
;
k
++
;
continue
;
}
// if (sToken.z[k] == delim || sToken.z[k] == '\\') {
// if (sToken.z[k + 1] == delim) {
// cnt++;
// tmpTokenBuf[j] = sToken.z[k + 1];
// j++;s
// k++;
// continue;
// }
// }
tmpTokenBuf
[
j
]
=
sToken
.
z
[
k
];
j
++
;
}
tmpTokenBuf
[
j
]
=
0
;
sToken
.
z
=
tmpTokenBuf
;
sToken
.
n
-=
2
+
cnt
;
...
...
@@ -1005,7 +1014,7 @@ int validateTableName(char *tblName, int len, SStrToken* psTblToken) {
psTblToken
->
n
=
len
;
psTblToken
->
type
=
TK_ID
;
t
SQL
GetToken
(
psTblToken
->
z
,
&
psTblToken
->
type
);
tGetToken
(
psTblToken
->
z
,
&
psTblToken
->
type
);
return
tscValidateName
(
psTblToken
);
}
...
...
src/client/src/tscPrepare.c
浏览文件 @
2742159f
...
...
@@ -151,7 +151,7 @@ static int normalStmtPrepare(STscStmt* stmt) {
while
(
sql
[
i
]
!=
0
)
{
SStrToken
token
=
{
0
};
token
.
n
=
t
SQL
GetToken
(
sql
+
i
,
&
token
.
type
);
token
.
n
=
tGetToken
(
sql
+
i
,
&
token
.
type
);
if
(
token
.
type
==
TK_QUESTION
)
{
sql
[
i
]
=
0
;
...
...
src/client/src/tscSQLParser.c
浏览文件 @
2742159f
...
...
@@ -21,19 +21,19 @@
#endif // __APPLE__
#include "os.h"
#include "ttype.h"
#include "texpr.h"
#include "taos.h"
#include "taosmsg.h"
#include "tcompare.h"
#include "texpr.h"
#include "tname.h"
#include "tscLog.h"
#include "tscUtil.h"
#include "tschemautil.h"
#include "tsclient.h"
#include "tstoken.h"
#include "tstrbuild.h"
#include "ttoken.h"
#include "ttokendef.h"
#include "ttype.h"
#include "qUtil.h"
#define DEFAULT_PRIMARY_TIMESTAMP_COL_NAME "_c0"
...
...
@@ -4629,7 +4629,7 @@ int32_t getTimeRange(STimeWindow* win, tSqlExpr* pRight, int32_t optr, int16_t t
}
}
else
{
SStrToken
token
=
{.
z
=
pRight
->
value
.
pz
,
.
n
=
pRight
->
value
.
nLen
,
.
type
=
TK_ID
};
int32_t
len
=
t
SQL
GetToken
(
pRight
->
value
.
pz
,
&
token
.
type
);
int32_t
len
=
tGetToken
(
pRight
->
value
.
pz
,
&
token
.
type
);
if
((
token
.
type
!=
TK_INTEGER
&&
token
.
type
!=
TK_FLOAT
)
||
len
!=
pRight
->
value
.
nLen
)
{
return
TSDB_CODE_TSC_INVALID_SQL
;
...
...
@@ -5498,13 +5498,13 @@ int32_t validateLocalConfig(SMiscInfo* pOptions) {
}
int32_t
validateColumnName
(
char
*
name
)
{
bool
ret
=
isKeyWord
(
name
,
(
int32_t
)
strlen
(
name
));
bool
ret
=
taosIsKeyWordToken
(
name
,
(
int32_t
)
strlen
(
name
));
if
(
ret
)
{
return
TSDB_CODE_TSC_INVALID_SQL
;
}
SStrToken
token
=
{.
z
=
name
};
token
.
n
=
t
SQL
GetToken
(
name
,
&
token
.
type
);
token
.
n
=
tGetToken
(
name
,
&
token
.
type
);
if
(
token
.
type
!=
TK_STRING
&&
token
.
type
!=
TK_ID
)
{
return
TSDB_CODE_TSC_INVALID_SQL
;
...
...
@@ -5515,7 +5515,7 @@ int32_t validateColumnName(char* name) {
strntolower
(
token
.
z
,
token
.
z
,
token
.
n
);
token
.
n
=
(
uint32_t
)
strtrim
(
token
.
z
);
int32_t
k
=
t
SQL
GetToken
(
token
.
z
,
&
token
.
type
);
int32_t
k
=
tGetToken
(
token
.
z
,
&
token
.
type
);
if
(
k
!=
token
.
n
)
{
return
TSDB_CODE_TSC_INVALID_SQL
;
}
...
...
src/client/src/tscSql.c
浏览文件 @
2742159f
...
...
@@ -962,7 +962,7 @@ static int tscParseTblNameList(SSqlObj *pSql, const char *tblNameList, int32_t t
len
=
(
int32_t
)
strtrim
(
tblName
);
SStrToken
sToken
=
{.
n
=
len
,
.
type
=
TK_ID
,
.
z
=
tblName
};
t
SQL
GetToken
(
tblName
,
&
sToken
.
type
);
tGetToken
(
tblName
,
&
sToken
.
type
);
// Check if the table name available or not
if
(
tscValidateName
(
&
sToken
)
!=
TSDB_CODE_SUCCESS
)
{
...
...
src/client/src/tscUtil.c
浏览文件 @
2742159f
...
...
@@ -1519,7 +1519,7 @@ void tscColumnListDestroy(SArray* pColumnList) {
static
int32_t
validateQuoteToken
(
SStrToken
*
pToken
)
{
tscDequoteAndTrimToken
(
pToken
);
int32_t
k
=
t
SQL
GetToken
(
pToken
->
z
,
&
pToken
->
type
);
int32_t
k
=
tGetToken
(
pToken
->
z
,
&
pToken
->
type
);
if
(
pToken
->
type
==
TK_STRING
)
{
return
tscValidateName
(
pToken
);
...
...
@@ -1587,7 +1587,7 @@ int32_t tscValidateName(SStrToken* pToken) {
tscStrToLower
(
pToken
->
z
,
pToken
->
n
);
//pToken->n = (uint32_t)strtrim(pToken->z);
int
len
=
t
SQL
GetToken
(
pToken
->
z
,
&
pToken
->
type
);
int
len
=
tGetToken
(
pToken
->
z
,
&
pToken
->
type
);
// single token, validate it
if
(
len
==
pToken
->
n
)
{
...
...
@@ -1613,7 +1613,7 @@ int32_t tscValidateName(SStrToken* pToken) {
pToken
->
n
=
(
uint32_t
)
strtrim
(
pToken
->
z
);
}
pToken
->
n
=
t
SQL
GetToken
(
pToken
->
z
,
&
pToken
->
type
);
pToken
->
n
=
tGetToken
(
pToken
->
z
,
&
pToken
->
type
);
if
(
pToken
->
z
[
pToken
->
n
]
!=
TS_PATH_DELIMITER
[
0
])
{
return
TSDB_CODE_TSC_INVALID_SQL
;
}
...
...
@@ -1630,7 +1630,7 @@ int32_t tscValidateName(SStrToken* pToken) {
pToken
->
z
=
sep
+
1
;
pToken
->
n
=
(
uint32_t
)(
oldLen
-
(
sep
-
pStr
)
-
1
);
int32_t
len
=
t
SQL
GetToken
(
pToken
->
z
,
&
pToken
->
type
);
int32_t
len
=
tGetToken
(
pToken
->
z
,
&
pToken
->
type
);
if
(
len
!=
pToken
->
n
||
(
pToken
->
type
!=
TK_STRING
&&
pToken
->
type
!=
TK_ID
))
{
return
TSDB_CODE_TSC_INVALID_SQL
;
}
...
...
src/client/tests/timeParseTest.cpp
浏览文件 @
2742159f
...
...
@@ -4,7 +4,7 @@
#include <iostream>
#include "taos.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "tutil.h"
int
main
(
int
argc
,
char
**
argv
)
{
...
...
src/common/inc/tname.h
浏览文件 @
2742159f
...
...
@@ -18,7 +18,7 @@
#include "os.h"
#include "taosmsg.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "tvariant.h"
typedef
struct
SDataStatis
{
...
...
src/common/inc/tvariant.h
浏览文件 @
2742159f
...
...
@@ -16,8 +16,8 @@
#ifndef TDENGINE_TVARIANT_H
#define TDENGINE_TVARIANT_H
#include "tstoken.h"
#include "tarray.h"
#include "ttoken.h"
#ifdef __cplusplus
extern
"C"
{
...
...
src/common/src/tname.c
浏览文件 @
2742159f
...
...
@@ -2,7 +2,7 @@
#include "tutil.h"
#include "tname.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "tvariant.h"
#define VALIDNUMOFCOLS(x) ((x) >= TSDB_MIN_COLUMNS && (x) <= TSDB_MAX_COLUMNS)
...
...
src/common/src/tvariant.c
浏览文件 @
2742159f
...
...
@@ -14,14 +14,14 @@
*/
#include "os.h"
#include "tvariant.h"
#include "hash.h"
#include "taos.h"
#include "taosdef.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "ttokendef.h"
#include "tutil.h"
#include "ttype.h"
#include "tutil.h"
#include "tvariant.h"
void
tVariantCreate
(
tVariant
*
pVar
,
SStrToken
*
token
)
{
int32_t
ret
=
0
;
...
...
@@ -49,7 +49,7 @@ void tVariantCreate(tVariant *pVar, SStrToken *token) {
ret
=
tStrToInteger
(
token
->
z
,
token
->
type
,
token
->
n
,
&
pVar
->
i64
,
true
);
if
(
ret
!=
0
)
{
SStrToken
t
=
{
0
};
t
SQL
GetToken
(
token
->
z
,
&
t
.
type
);
tGetToken
(
token
->
z
,
&
t
.
type
);
if
(
t
.
type
==
TK_MINUS
)
{
// it is a signed number which is greater than INT64_MAX or less than INT64_MIN
pVar
->
nType
=
-
1
;
// -1 means error type
return
;
...
...
@@ -460,7 +460,7 @@ static FORCE_INLINE int32_t convertToInteger(tVariant *pVariant, int64_t *result
*
result
=
(
int64_t
)
pVariant
->
dKey
;
}
else
if
(
pVariant
->
nType
==
TSDB_DATA_TYPE_BINARY
)
{
SStrToken
token
=
{.
z
=
pVariant
->
pz
,
.
n
=
pVariant
->
nLen
};
/*int32_t n = */
t
SQL
GetToken
(
pVariant
->
pz
,
&
token
.
type
);
/*int32_t n = */
tGetToken
(
pVariant
->
pz
,
&
token
.
type
);
if
(
token
.
type
==
TK_NULL
)
{
if
(
releaseVariantPtr
)
{
...
...
@@ -495,10 +495,10 @@ static FORCE_INLINE int32_t convertToInteger(tVariant *pVariant, int64_t *result
wchar_t
*
endPtr
=
NULL
;
SStrToken
token
=
{
0
};
token
.
n
=
t
SQL
GetToken
(
pVariant
->
pz
,
&
token
.
type
);
token
.
n
=
tGetToken
(
pVariant
->
pz
,
&
token
.
type
);
if
(
token
.
type
==
TK_MINUS
||
token
.
type
==
TK_PLUS
)
{
token
.
n
=
t
SQL
GetToken
(
pVariant
->
pz
+
token
.
n
,
&
token
.
type
);
token
.
n
=
tGetToken
(
pVariant
->
pz
+
token
.
n
,
&
token
.
type
);
}
if
(
token
.
type
==
TK_FLOAT
)
{
...
...
src/os/tests/test.cpp
浏览文件 @
2742159f
...
...
@@ -4,7 +4,7 @@
#include <iostream>
#include "taos.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "tutil.h"
int
main
(
int
argc
,
char
**
argv
)
{
...
...
src/query/inc/qSqlparser.h
浏览文件 @
2742159f
...
...
@@ -22,8 +22,8 @@ extern "C" {
#include "taos.h"
#include "taosmsg.h"
#include "tstoken.h"
#include "tstrbuild.h"
#include "ttoken.h"
#include "tvariant.h"
#define ParseTOKENTYPE SStrToken
...
...
src/query/src/qSqlParser.c
浏览文件 @
2742159f
...
...
@@ -13,13 +13,13 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "os.h"
#include "qSqlparser.h"
#include "os.h"
#include "taosdef.h"
#include "taosmsg.h"
#include "tcmdtype.h"
#include "tstoken.h"
#include "tstrbuild.h"
#include "ttoken.h"
#include "ttokendef.h"
#include "tutil.h"
...
...
@@ -38,7 +38,7 @@ SSqlInfo qSqlParse(const char *pStr) {
goto
abort_parse
;
}
t0
.
n
=
t
SQL
GetToken
((
char
*
)
&
pStr
[
i
],
&
t0
.
type
);
t0
.
n
=
tGetToken
((
char
*
)
&
pStr
[
i
],
&
t0
.
type
);
t0
.
z
=
(
char
*
)(
pStr
+
i
);
i
+=
t0
.
n
;
...
...
src/query/src/sql.c
浏览文件 @
2742159f
...
...
@@ -26,14 +26,14 @@
#include <assert.h>
/************ Begin %include sections from the grammar ************************/
#include <assert.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
#include <stdbool.h>
#include "qSqlparser.h"
#include "tcmdtype.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "ttokendef.h"
#include "tutil.h"
#include "tvariant.h"
...
...
src/query/tests/tsBufTest.cpp
浏览文件 @
2742159f
...
...
@@ -3,10 +3,10 @@
#include <cassert>
#include <iostream>
#include "qTsbuf.h"
#include "taos.h"
#include "tsdb.h"
#include "qTsbuf.h"
#include "tstoken.h"
#include "ttoken.h"
#include "tutil.h"
namespace
{
...
...
src/query/tests/unitTest.cpp
浏览文件 @
2742159f
...
...
@@ -21,7 +21,7 @@ int32_t testValidateName(char* name) {
token
.
n
=
strlen
(
name
);
token
.
type
=
0
;
t
SQL
GetToken
(
name
,
&
token
.
type
);
tGetToken
(
name
,
&
token
.
type
);
return
tscValidateName
(
&
token
);
}
}
...
...
@@ -691,32 +691,32 @@ TEST(testCase, tGetToken_Test) {
char
*
s
=
".123 "
;
uint32_t
type
=
0
;
int32_t
len
=
t
SQL
GetToken
(
s
,
&
type
);
int32_t
len
=
tGetToken
(
s
,
&
type
);
EXPECT_EQ
(
type
,
TK_FLOAT
);
EXPECT_EQ
(
len
,
strlen
(
s
)
-
1
);
char
s1
[]
=
"1.123e10 "
;
len
=
t
SQL
GetToken
(
s1
,
&
type
);
len
=
tGetToken
(
s1
,
&
type
);
EXPECT_EQ
(
type
,
TK_FLOAT
);
EXPECT_EQ
(
len
,
strlen
(
s1
)
-
1
);
char
s4
[]
=
"0xff "
;
len
=
t
SQL
GetToken
(
s4
,
&
type
);
len
=
tGetToken
(
s4
,
&
type
);
EXPECT_EQ
(
type
,
TK_HEX
);
EXPECT_EQ
(
len
,
strlen
(
s4
)
-
1
);
// invalid data type
char
s2
[]
=
"e10 "
;
len
=
t
SQL
GetToken
(
s2
,
&
type
);
len
=
tGetToken
(
s2
,
&
type
);
EXPECT_FALSE
(
type
==
TK_FLOAT
);
char
s3
[]
=
"1.1.1.1"
;
len
=
t
SQL
GetToken
(
s3
,
&
type
);
len
=
tGetToken
(
s3
,
&
type
);
EXPECT_EQ
(
type
,
TK_IPTOKEN
);
EXPECT_EQ
(
len
,
strlen
(
s3
));
char
s5
[]
=
"0x "
;
len
=
t
SQL
GetToken
(
s5
,
&
type
);
len
=
tGetToken
(
s5
,
&
type
);
EXPECT_FALSE
(
type
==
TK_HEX
);
}
...
...
src/util/inc/t
s
token.h
→
src/util/inc/ttoken.h
浏览文件 @
2742159f
...
...
@@ -37,13 +37,25 @@ typedef struct SStrToken {
char
*
z
;
}
SStrToken
;
extern
const
char
escapeChar
[];
/**
* check if it is a number or not
* @param pToken
* @return
*/
#define isNumber(tk) \
((tk)->type == TK_INTEGER || (tk)->type == TK_FLOAT || (tk)->type == TK_HEX || (tk)->type == TK_BIN)
#define GET_ESCAPE_CHAR(c) (escapeChar[(uint8_t)(c)])
/**
* tokenizer for sql string
* @param z
* @param tokenType
* @return
*/
uint32_t
t
SQL
GetToken
(
char
*
z
,
uint32_t
*
tokenType
);
uint32_t
tGetToken
(
char
*
z
,
uint32_t
*
tokenType
);
/**
* enhanced tokenizer for sql string.
...
...
@@ -61,21 +73,12 @@ SStrToken tStrGetToken(char *str, int32_t *i, bool isPrevOptr);
* @param len
* @return
*/
bool
isKeyWord
(
const
char
*
z
,
int32_t
len
);
/**
* check if it is a number or not
* @param pToken
* @return
*/
#define isNumber(tk) \
((tk)->type == TK_INTEGER || (tk)->type == TK_FLOAT || (tk)->type == TK_HEX || (tk)->type == TK_BIN)
bool
taosIsKeyWordToken
(
const
char
*
z
,
int32_t
len
);
/**
* check if it is a token or not
* @param pToken
* @return
token type, if it is not a number, TK_ILLEGAL will return
* @param
pToken
* @return token type, if it is not a number, TK_ILLEGAL will return
*/
static
FORCE_INLINE
int32_t
tGetNumericStringType
(
const
SStrToken
*
pToken
)
{
const
char
*
z
=
pToken
->
z
;
...
...
src/
query/src/qT
okenizer.c
→
src/
util/src/tt
okenizer.c
浏览文件 @
2742159f
...
...
@@ -18,7 +18,7 @@
#include "hash.h"
#include "hashfunc.h"
#include "taosdef.h"
#include "t
s
token.h"
#include "ttoken.h"
#include "ttokendef.h"
#include "tutil.h"
...
...
@@ -232,6 +232,18 @@ static const char isIdChar[] = {
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
0
,
0
,
0
,
0
,
0
,
/* 7x */
};
const
char
escapeChar
[]
=
{
/* x0 x1 x2 x3 x4 x5 x6 x7 x8 x9 xA xB xC xD xE xF */
0x00
,
0x01
,
0x02
,
0x03
,
0x04
,
0x05
,
0x06
,
0x07
,
0x08
,
0x09
,
0x0A
,
0x0B
,
0x0C
,
0x0D
,
0x0E
,
0x0F
,
/* 0x */
0x10
,
0x11
,
0x12
,
0x13
,
0x14
,
0x15
,
0x16
,
0x17
,
0x18
,
0x19
,
0x1A
,
0x1B
,
0x1C
,
0x1D
,
0x1E
,
0x1F
,
/* 1x */
0x20
,
0x21
,
0x22
,
0x23
,
0x24
,
0x25
,
0x26
,
0x27
,
0x28
,
0x29
,
0x2A
,
0x2B
,
0x2C
,
0x2D
,
0x2E
,
0x2F
,
/* 2x */
0x30
,
0x31
,
0x32
,
0x33
,
0x34
,
0x35
,
0x36
,
0x37
,
0x38
,
0x39
,
0x3A
,
0x3B
,
0x3C
,
0x3D
,
0x3E
,
0x3F
,
/* 3x */
0x40
,
0x41
,
0x42
,
0x43
,
0x44
,
0x45
,
0x46
,
0x47
,
0x48
,
0x49
,
0x4A
,
0x4B
,
0x4C
,
0x4D
,
0x4E
,
0x4F
,
/* 4x */
0x50
,
0x51
,
0x52
,
0x53
,
0x54
,
0x55
,
0x56
,
0x57
,
0x58
,
0x59
,
0x5A
,
0x5B
,
0x5C
,
0x5D
,
0x5E
,
0x5F
,
/* 5x */
0x60
,
0x07
,
0x08
,
0x63
,
0x64
,
0x65
,
0x0C
,
0x67
,
0x68
,
0x69
,
0x6A
,
0x6B
,
0x6C
,
0x6D
,
0x0A
,
0x6F
,
/* 6x */
0x70
,
0x71
,
0x0D
,
0x73
,
0x09
,
0x75
,
0x0B
,
0x77
,
0x78
,
0x79
,
0x7A
,
0x7B
,
0x7C
,
0x7D
,
0x7E
,
0x7F
,
/* 7x */
};
static
void
*
keywordHashTable
=
NULL
;
static
void
doInitKeywordsTable
(
void
)
{
...
...
@@ -247,7 +259,7 @@ static void doInitKeywordsTable(void) {
static
pthread_once_t
keywordsHashTableInit
=
PTHREAD_ONCE_INIT
;
int
tSQL
KeywordCode
(
const
char
*
z
,
int
n
)
{
static
int32_t
t
KeywordCode
(
const
char
*
z
,
int
n
)
{
pthread_once
(
&
keywordsHashTableInit
,
doInitKeywordsTable
);
char
key
[
512
]
=
{
0
};
...
...
@@ -271,7 +283,7 @@ int tSQLKeywordCode(const char* z, int n) {
* Return the length of the token that begins at z[0].
* Store the token type in *type before returning.
*/
uint32_t
t
SQL
GetToken
(
char
*
z
,
uint32_t
*
tokenId
)
{
uint32_t
tGetToken
(
char
*
z
,
uint32_t
*
tokenId
)
{
uint32_t
i
;
switch
(
*
z
)
{
case
' '
:
...
...
@@ -408,7 +420,7 @@ uint32_t tSQLGetToken(char* z, uint32_t* tokenId) {
continue
;
}
if
(
z
[
i
]
==
delim
)
{
if
(
z
[
i
]
==
delim
)
{
if
(
z
[
i
+
1
]
==
delim
)
{
i
++
;
}
else
{
...
...
@@ -551,7 +563,7 @@ uint32_t tSQLGetToken(char* z, uint32_t* tokenId) {
}
for
(
i
=
1
;
((
z
[
i
]
&
0x80
)
==
0
)
&&
isIdChar
[(
uint8_t
)
z
[
i
]];
i
++
)
{
}
*
tokenId
=
t
SQL
KeywordCode
(
z
,
i
);
*
tokenId
=
tKeywordCode
(
z
,
i
);
return
i
;
}
}
...
...
@@ -584,7 +596,7 @@ SStrToken tStrGetToken(char* str, int32_t* i, bool isPrevOptr) {
t
=
str
[
++
(
*
i
)];
}
t0
.
n
=
t
SQL
GetToken
(
&
str
[
*
i
],
&
t0
.
type
);
t0
.
n
=
tGetToken
(
&
str
[
*
i
],
&
t0
.
type
);
break
;
// not support user specfied ignored symbol list
...
...
@@ -613,7 +625,7 @@ SStrToken tStrGetToken(char* str, int32_t* i, bool isPrevOptr) {
// support parse the 'db.tbl' format, notes: There should be no space on either side of the dot!
if
(
'.'
==
str
[
*
i
+
t0
.
n
])
{
len
=
t
SQL
GetToken
(
&
str
[
*
i
+
t0
.
n
+
1
],
&
type
);
len
=
tGetToken
(
&
str
[
*
i
+
t0
.
n
+
1
],
&
type
);
// only id and string are valid
if
((
TK_STRING
!=
t0
.
type
)
&&
(
TK_ID
!=
t0
.
type
))
{
...
...
@@ -628,7 +640,7 @@ SStrToken tStrGetToken(char* str, int32_t* i, bool isPrevOptr) {
}
else
{
// support parse the -/+number format
if
((
isPrevOptr
)
&&
(
t0
.
type
==
TK_MINUS
||
t0
.
type
==
TK_PLUS
))
{
len
=
t
SQL
GetToken
(
&
str
[
*
i
+
t0
.
n
],
&
type
);
len
=
tGetToken
(
&
str
[
*
i
+
t0
.
n
],
&
type
);
if
(
type
==
TK_INTEGER
||
type
==
TK_FLOAT
)
{
t0
.
type
=
type
;
t0
.
n
+=
len
;
...
...
@@ -642,7 +654,9 @@ SStrToken tStrGetToken(char* str, int32_t* i, bool isPrevOptr) {
return
t0
;
}
bool
isKeyWord
(
const
char
*
z
,
int32_t
len
)
{
return
(
tSQLKeywordCode
((
char
*
)
z
,
len
)
!=
TK_ID
);
}
bool
taosIsKeyWordToken
(
const
char
*
z
,
int32_t
len
)
{
return
(
tKeywordCode
((
char
*
)
z
,
len
)
!=
TK_ID
);
}
void
taosCleanupKeywordsTable
()
{
void
*
m
=
keywordHashTable
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录