Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
02d509e6
T
TDengine
项目概览
taosdata
/
TDengine
大约 1 年 前同步成功
通知
1185
Star
22015
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
02d509e6
编写于
12月 09, 2019
作者:
F
fang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
solve static check questions
上级
5c4654fd
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
23 addition
and
23 deletion
+23
-23
src/client/src/tscPrepare.c
src/client/src/tscPrepare.c
+1
-1
src/client/src/tscProfile.c
src/client/src/tscProfile.c
+1
-1
src/client/src/tscSQLParser.c
src/client/src/tscSQLParser.c
+21
-21
未找到文件。
src/client/src/tscPrepare.c
浏览文件 @
02d509e6
...
...
@@ -65,6 +65,7 @@ static int normalStmtAddPart(SNormalStmt* stmt, bool isParam, char* str, uint32_
}
stmt
->
sizeParts
=
size
;
stmt
->
parts
=
(
SNormalStmtPart
*
)
tmp
;
free
(
tmp
);
//fang memory leak
}
stmt
->
parts
[
stmt
->
numParts
].
isParam
=
isParam
;
...
...
@@ -75,7 +76,6 @@ static int normalStmtAddPart(SNormalStmt* stmt, bool isParam, char* str, uint32_
if
(
isParam
)
{
++
stmt
->
numParams
;
}
return
TSDB_CODE_SUCCESS
;
}
...
...
src/client/src/tscProfile.c
浏览文件 @
02d509e6
...
...
@@ -198,7 +198,7 @@ void tscKillStream(STscObj *pObj, uint32_t killId) {
pthread_mutex_unlock
(
&
pObj
->
mutex
);
tscTrace
(
"%p stream:%p is killed, streamId:%d"
,
pStream
->
pSql
,
pStream
,
killId
);
tscTrace
(
"%p stream:%p is killed, streamId:%d"
,
pStream
->
pSql
,
pStream
,
killId
);
//fang, pStream could be null
taos_close_stream
(
pStream
);
if
(
pStream
->
callback
)
{
...
...
src/client/src/tscSQLParser.c
浏览文件 @
02d509e6
...
...
@@ -248,7 +248,6 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
}
case
USE_DATABASE
:
{
const
char
*
msg
=
"db name too long"
;
pCmd
->
command
=
TSDB_SQL_USE_DB
;
SSQLToken
*
pToken
=
&
pInfo
->
pDCLInfo
->
a
[
0
];
...
...
@@ -258,6 +257,7 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
}
if
(
pToken
->
n
>
TSDB_DB_NAME_LEN
)
{
const
char
*
msg
=
"db name too long"
;
//fang, reduce scope
return
invalidSqlErrMsg
(
pCmd
,
msg
);
}
...
...
@@ -295,8 +295,6 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
case
ALTER_DATABASE
:
case
CREATE_DATABASE
:
{
const
char
*
msg2
=
"name too long"
;
const
char
*
msg3
=
"invalid db name"
;
if
(
pInfo
->
sqlType
==
ALTER_DATABASE
)
{
pCmd
->
command
=
TSDB_SQL_ALTER_DB
;
...
...
@@ -307,11 +305,13 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
SCreateDBInfo
*
pCreateDB
=
&
(
pInfo
->
pDCLInfo
->
dbOpt
);
if
(
tscValidateName
(
&
pCreateDB
->
dbname
)
!=
TSDB_CODE_SUCCESS
)
{
return
invalidSqlErrMsg
(
pCmd
,
msg3
);
const
char
*
msg3
=
"invalid db name"
;
return
invalidSqlErrMsg
(
pCmd
,
msg3
);
//fang reduce scope
}
int32_t
ret
=
setObjFullName
(
pMeterMetaInfo
->
name
,
getAccountId
(
pSql
),
&
(
pCreateDB
->
dbname
),
NULL
,
NULL
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
const
char
*
msg2
=
"name too long"
;
//fang reduce scope
return
invalidSqlErrMsg
(
pCmd
,
msg2
);
}
...
...
@@ -347,14 +347,9 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
pCmd
->
command
=
(
pInfo
->
sqlType
==
CREATE_USER
)
?
TSDB_SQL_CREATE_USER
:
TSDB_SQL_CREATE_ACCT
;
assert
(
pInfo
->
pDCLInfo
->
nTokens
>=
2
);
const
char
*
msg
=
"name or password too long"
;
const
char
*
msg1
=
"password can not be empty"
;
const
char
*
msg2
=
"invalid user/account name"
;
const
char
*
msg3
=
"password needs single quote marks enclosed"
;
const
char
*
msg4
=
"invalid state option, available options[no, r, w, all]"
;
if
(
pInfo
->
pDCLInfo
->
a
[
1
].
type
!=
TK_STRING
)
{
return
invalidSqlErrMsg
(
pCmd
,
msg3
);
const
char
*
msg3
=
"password needs single quote marks enclosed"
;
return
invalidSqlErrMsg
(
pCmd
,
msg3
);
//fang reduce scope
}
strdequote
(
pInfo
->
pDCLInfo
->
a
[
1
].
z
);
...
...
@@ -362,15 +357,18 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
pInfo
->
pDCLInfo
->
a
[
1
].
n
=
strlen
(
pInfo
->
pDCLInfo
->
a
[
1
].
z
);
if
(
pInfo
->
pDCLInfo
->
a
[
1
].
n
<=
0
)
{
return
invalidSqlErrMsg
(
pCmd
,
msg1
);
const
char
*
msg1
=
"password can not be empty"
;
return
invalidSqlErrMsg
(
pCmd
,
msg1
);
//fang reduce scope
}
if
(
pInfo
->
pDCLInfo
->
a
[
0
].
n
>
TSDB_USER_LEN
||
pInfo
->
pDCLInfo
->
a
[
1
].
n
>
TSDB_PASSWORD_LEN
)
{
return
invalidSqlErrMsg
(
pCmd
,
msg
);
const
char
*
msg
=
"name or password too long"
;
return
invalidSqlErrMsg
(
pCmd
,
msg
);
//fang reduce scope
}
if
(
tscValidateName
(
&
pInfo
->
pDCLInfo
->
a
[
0
])
!=
TSDB_CODE_SUCCESS
)
{
return
invalidSqlErrMsg
(
pCmd
,
msg2
);
const
char
*
msg2
=
"invalid user/account name"
;
return
invalidSqlErrMsg
(
pCmd
,
msg2
);
//fang reduce scope
}
strncpy
(
pMeterMetaInfo
->
name
,
pInfo
->
pDCLInfo
->
a
[
0
].
z
,
pInfo
->
pDCLInfo
->
a
[
0
].
n
);
// name
...
...
@@ -403,7 +401,8 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
}
else
if
(
strncmp
(
pAcctOpt
->
stat
.
z
,
"no"
,
2
)
==
0
&&
pAcctOpt
->
stat
.
n
==
2
)
{
pCmd
->
defaultVal
[
8
]
=
0
;
}
else
{
return
invalidSqlErrMsg
(
pCmd
,
msg4
);
const
char
*
msg4
=
"invalid state option, available options[no, r, w, all]"
;
return
invalidSqlErrMsg
(
pCmd
,
msg4
);
//fang reduce scope
}
}
}
...
...
@@ -415,13 +414,10 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
assert
(
num
>=
1
&&
num
<=
2
);
const
char
*
msg
=
"password too long"
;
const
char
*
msg1
=
"password can not be empty"
;
const
char
*
msg2
=
"invalid user/account name"
;
const
char
*
msg3
=
"password needs single quote marks enclosed"
;
const
char
*
msg4
=
"invalid state option, available options[no, r, w, all]"
;
if
(
num
==
2
)
{
if
(
pInfo
->
pDCLInfo
->
a
[
1
].
type
!=
TK_STRING
)
{
const
char
*
msg3
=
"password needs single quote marks enclosed"
;
return
invalidSqlErrMsg
(
pCmd
,
msg3
);
}
...
...
@@ -430,6 +426,7 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
pInfo
->
pDCLInfo
->
a
[
1
].
n
=
strlen
(
pInfo
->
pDCLInfo
->
a
[
1
].
z
);
if
(
pInfo
->
pDCLInfo
->
a
[
1
].
n
<=
0
)
{
const
char
*
msg1
=
"password can not be empty"
;
return
invalidSqlErrMsg
(
pCmd
,
msg1
);
}
...
...
@@ -445,6 +442,7 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
}
if
(
tscValidateName
(
&
pInfo
->
pDCLInfo
->
a
[
0
])
!=
TSDB_CODE_SUCCESS
)
{
const
char
*
msg2
=
"invalid user/account name"
;
return
invalidSqlErrMsg
(
pCmd
,
msg2
);
}
...
...
@@ -475,6 +473,7 @@ int32_t tscToSQLCmd(SSqlObj* pSql, struct SSqlInfo* pInfo) {
}
else
if
(
strncmp
(
pAcctOpt
->
stat
.
z
,
"no"
,
2
)
==
0
&&
pAcctOpt
->
stat
.
n
==
2
)
{
pCmd
->
defaultVal
[
8
]
=
0
;
}
else
{
const
char
*
msg4
=
"invalid state option, available options[no, r, w, all]"
;
return
invalidSqlErrMsg
(
pCmd
,
msg4
);
}
}
...
...
@@ -1868,8 +1867,6 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, int32_t colIdx, tSQLExprItem* pItem
SMeterMetaInfo
*
pMeterMetaInfo
=
NULL
;
int32_t
optr
=
pItem
->
pNode
->
nSQLOptr
;
int32_t
numOfAddedColumn
=
1
;
const
char
*
msg1
=
"not support column types"
;
const
char
*
msg2
=
"invalid parameters"
;
const
char
*
msg3
=
"illegal column name"
;
...
...
@@ -2166,6 +2163,7 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, int32_t colIdx, tSQLExprItem* pItem
int16_t
resultSize
=
pSchema
[
index
.
columnIndex
].
bytes
;
char
val
[
8
]
=
{
0
};
int32_t
numOfAddedColumn
=
1
;
//fang reduce scope
if
(
optr
==
TK_PERCENTILE
||
optr
==
TK_APERCENTILE
)
{
tVariantDump
(
pVariant
,
val
,
TSDB_DATA_TYPE_DOUBLE
);
...
...
@@ -2190,6 +2188,7 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, int32_t colIdx, tSQLExprItem* pItem
SSqlExpr
*
pExpr
=
tscSqlExprInsert
(
pCmd
,
colIdx
,
functionId
,
&
index
,
resultType
,
resultSize
,
resultSize
);
addExprParams
(
pExpr
,
val
,
TSDB_DATA_TYPE_DOUBLE
,
sizeof
(
double
),
0
);
}
else
{
tVariantDump
(
pVariant
,
val
,
TSDB_DATA_TYPE_BIGINT
);
int64_t
nTop
=
*
((
int32_t
*
)
val
);
...
...
@@ -2928,6 +2927,7 @@ static SColumnFilterInfo* addColumnFilterInfo(SColumnBase* pColumn) {
char
*
tmp
=
realloc
(
pColumn
->
filterInfo
,
sizeof
(
SColumnFilterInfo
)
*
(
size
));
if
(
tmp
!=
NULL
)
{
pColumn
->
filterInfo
=
(
SColumnFilterInfo
*
)
tmp
;
free
(
tmp
);
//fang, memory leak
}
pColumn
->
numOfFilters
++
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录