Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
6835e495
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
6835e495
编写于
1月 02, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more
上级
82be83a2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
6 deletion
+18
-6
include/util/encode.h
include/util/encode.h
+18
-6
未找到文件。
include/util/encode.h
浏览文件 @
6835e495
...
@@ -98,6 +98,7 @@ static int tEncodeU64v(SCoder* pEncoder, uint64_t val);
...
@@ -98,6 +98,7 @@ static int tEncodeU64v(SCoder* pEncoder, uint64_t val);
static
int
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
);
static
int
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
);
static
int
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
);
static
int
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
);
static
int
tEncodeCstrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64_t
len
);
static
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
);
static
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
);
/* ------------------------ DECODE ------------------------ */
/* ------------------------ DECODE ------------------------ */
...
@@ -119,6 +120,7 @@ static int tDecodeU64v(SCoder* pDecoder, uint64_t* val);
...
@@ -119,6 +120,7 @@ static int tDecodeU64v(SCoder* pDecoder, uint64_t* val);
static
int
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
);
static
int
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
);
static
int
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
);
static
int
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
);
static
int
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
);
static
int
tDecodeCStr
(
SCoder
*
pEncoder
,
const
char
**
val
);
static
int
tDecodeCStr
(
SCoder
*
pEncoder
,
const
char
**
val
);
/* ------------------------ IMPL ------------------------ */
/* ------------------------ IMPL ------------------------ */
...
@@ -244,8 +246,8 @@ static FORCE_INLINE int tEncodeDouble(SCoder* pEncoder, double val) {
...
@@ -244,8 +246,8 @@ static FORCE_INLINE int tEncodeDouble(SCoder* pEncoder, double val) {
return
tEncodeU64
(
pEncoder
,
v
.
ui
);
return
tEncodeU64
(
pEncoder
,
v
.
ui
);
}
}
static
FORCE_INLINE
int
tEncodeCstrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
size
_t
len
)
{
static
FORCE_INLINE
int
tEncodeCstrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64
_t
len
)
{
if
(
tEncode
I32
v
(
pEncoder
,
len
)
<
0
)
return
-
1
;
if
(
tEncode
U64
v
(
pEncoder
,
len
)
<
0
)
return
-
1
;
if
(
pEncoder
->
data
)
{
if
(
pEncoder
->
data
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
len
+
1
))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
len
+
1
))
return
-
1
;
memcpy
(
TD_CODER_CURRENT
(
pEncoder
),
val
,
len
+
1
);
memcpy
(
TD_CODER_CURRENT
(
pEncoder
),
val
,
len
+
1
);
...
@@ -255,7 +257,7 @@ static FORCE_INLINE int tEncodeCstrWithLen(SCoder* pEncoder, const char* val, si
...
@@ -255,7 +257,7 @@ static FORCE_INLINE int tEncodeCstrWithLen(SCoder* pEncoder, const char* val, si
}
}
static
FORCE_INLINE
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
)
{
static
FORCE_INLINE
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
)
{
return
tEncodeCstrWithLen
(
pEncoder
,
val
,
strlen
(
val
));
return
tEncodeCstrWithLen
(
pEncoder
,
val
,
(
uint64_t
)
strlen
(
val
));
}
}
/* ------------------------ FOR DECODER ------------------------ */
/* ------------------------ FOR DECODER ------------------------ */
...
@@ -346,7 +348,7 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
...
@@ -346,7 +348,7 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
double
d
;
double
d
;
}
v
;
}
v
;
if
(
tDecodeU64
(
p
En
coder
,
&
(
v
.
ui
))
<
0
)
{
if
(
tDecodeU64
(
p
De
coder
,
&
(
v
.
ui
))
<
0
)
{
return
-
1
;
return
-
1
;
}
}
...
@@ -354,11 +356,21 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
...
@@ -354,11 +356,21 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeCStr
(
SCoder
*
pEncoder
,
const
char
**
val
)
{
static
FORCE_INLINE
int
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
)
{
// TODO
if
(
tDecodeU64v
(
pDecoder
,
len
)
<
0
)
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
*
len
+
1
))
return
-
1
;
*
val
=
(
char
*
)
TD_CODER_CURRENT
(
pDecoder
);
TD_CODER_MOVE_POS
(
pDecoder
,
*
len
+
1
);
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeCStr
(
SCoder
*
pDecoder
,
const
char
**
val
)
{
uint64_t
len
;
return
tDecodeCStrAndLen
(
pDecoder
,
val
,
&
len
);
}
#ifdef __cplusplus
#ifdef __cplusplus
}
}
#endif
#endif
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录