Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
426519d6
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
426519d6
编写于
2月 28, 2022
作者:
S
Shengliang Guan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
encode
上级
3f5f6b9f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
135 addition
and
128 deletion
+135
-128
include/util/tencode.h
include/util/tencode.h
+89
-83
source/util/src/tencode.c
source/util/src/tencode.c
+3
-2
source/util/test/encodeTest.cpp
source/util/test/encodeTest.cpp
+43
-43
未找到文件。
include/util/tencode.h
浏览文件 @
426519d6
...
@@ -81,52 +81,52 @@ void tCoderInit(SCoder* pCoder, td_endian_t endian, uint8_t* data, int32_t size,
...
@@ -81,52 +81,52 @@ void tCoderInit(SCoder* pCoder, td_endian_t endian, uint8_t* data, int32_t size,
void
tCoderClear
(
SCoder
*
pCoder
);
void
tCoderClear
(
SCoder
*
pCoder
);
/* ------------------------ ENCODE ------------------------ */
/* ------------------------ ENCODE ------------------------ */
int
tStartEncode
(
SCoder
*
pEncoder
);
int
32_t
tStartEncode
(
SCoder
*
pEncoder
);
void
tEndEncode
(
SCoder
*
pEncoder
);
void
tEndEncode
(
SCoder
*
pEncoder
);
static
int
tEncodeU8
(
SCoder
*
pEncoder
,
uint8_t
val
);
static
int
32_t
tEncodeU8
(
SCoder
*
pEncoder
,
uint8_t
val
);
static
int
tEncodeI8
(
SCoder
*
pEncoder
,
int8_t
val
);
static
int
32_t
tEncodeI8
(
SCoder
*
pEncoder
,
int8_t
val
);
static
int
tEncodeU16
(
SCoder
*
pEncoder
,
uint16_t
val
);
static
int
32_t
tEncodeU16
(
SCoder
*
pEncoder
,
uint16_t
val
);
static
int
tEncodeI16
(
SCoder
*
pEncoder
,
int16_t
val
);
static
int
32_t
tEncodeI16
(
SCoder
*
pEncoder
,
int16_t
val
);
static
int
tEncodeU32
(
SCoder
*
pEncoder
,
uint32_t
val
);
static
int
32_t
tEncodeU32
(
SCoder
*
pEncoder
,
uint32_t
val
);
static
int
tEncodeI32
(
SCoder
*
pEncoder
,
int32_t
val
);
static
int
32_t
tEncodeI32
(
SCoder
*
pEncoder
,
int32_t
val
);
static
int
tEncodeU64
(
SCoder
*
pEncoder
,
uint64_t
val
);
static
int
32_t
tEncodeU64
(
SCoder
*
pEncoder
,
uint64_t
val
);
static
int
tEncodeI64
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
32_t
tEncodeI64
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
tEncodeU16v
(
SCoder
*
pEncoder
,
uint16_t
val
);
static
int
32_t
tEncodeU16v
(
SCoder
*
pEncoder
,
uint16_t
val
);
static
int
tEncodeI16v
(
SCoder
*
pEncoder
,
int16_t
val
);
static
int
32_t
tEncodeI16v
(
SCoder
*
pEncoder
,
int16_t
val
);
static
int
tEncodeU32v
(
SCoder
*
pEncoder
,
uint32_t
val
);
static
int
32_t
tEncodeU32v
(
SCoder
*
pEncoder
,
uint32_t
val
);
static
int
tEncodeI32v
(
SCoder
*
pEncoder
,
int32_t
val
);
static
int
32_t
tEncodeI32v
(
SCoder
*
pEncoder
,
int32_t
val
);
static
int
tEncodeU64v
(
SCoder
*
pEncoder
,
uint64_t
val
);
static
int
32_t
tEncodeU64v
(
SCoder
*
pEncoder
,
uint64_t
val
);
static
int
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
32_t
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
);
static
int
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
);
static
int
32_t
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
);
static
int
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
);
static
int
32_t
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
);
static
int
tEncodeBinary
(
SCoder
*
pEncoder
,
const
void
*
val
,
uint64_t
len
);
static
int
32_t
tEncodeBinary
(
SCoder
*
pEncoder
,
const
void
*
val
,
uint64_t
len
);
static
int
tEncodeCStrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64_t
len
);
static
int
32_t
tEncodeCStrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64_t
len
);
static
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
);
static
int
32_t
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
);
/* ------------------------ DECODE ------------------------ */
/* ------------------------ DECODE ------------------------ */
int
tStartDecode
(
SCoder
*
pDecoder
);
int
32_t
tStartDecode
(
SCoder
*
pDecoder
);
void
tEndDecode
(
SCoder
*
pDecoder
);
void
tEndDecode
(
SCoder
*
pDecoder
);
static
bool
tDecodeIsEnd
(
SCoder
*
pCoder
);
static
bool
tDecodeIsEnd
(
SCoder
*
pCoder
);
static
int
tDecodeU8
(
SCoder
*
pDecoder
,
uint8_t
*
val
);
static
int
32_t
tDecodeU8
(
SCoder
*
pDecoder
,
uint8_t
*
val
);
static
int
tDecodeI8
(
SCoder
*
pDecoder
,
int8_t
*
val
);
static
int
32_t
tDecodeI8
(
SCoder
*
pDecoder
,
int8_t
*
val
);
static
int
tDecodeU16
(
SCoder
*
pDecoder
,
uint16_t
*
val
);
static
int
32_t
tDecodeU16
(
SCoder
*
pDecoder
,
uint16_t
*
val
);
static
int
tDecodeI16
(
SCoder
*
pDecoder
,
int16_t
*
val
);
static
int
32_t
tDecodeI16
(
SCoder
*
pDecoder
,
int16_t
*
val
);
static
int
tDecodeU32
(
SCoder
*
pDecoder
,
uint32_t
*
val
);
static
int
32_t
tDecodeU32
(
SCoder
*
pDecoder
,
uint32_t
*
val
);
static
int
tDecodeI32
(
SCoder
*
pDecoder
,
int32_t
*
val
);
static
int
32_t
tDecodeI32
(
SCoder
*
pDecoder
,
int32_t
*
val
);
static
int
tDecodeU64
(
SCoder
*
pDecoder
,
uint64_t
*
val
);
static
int
32_t
tDecodeU64
(
SCoder
*
pDecoder
,
uint64_t
*
val
);
static
int
tDecodeI64
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
32_t
tDecodeI64
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
tDecodeU16v
(
SCoder
*
pDecoder
,
uint16_t
*
val
);
static
int
32_t
tDecodeU16v
(
SCoder
*
pDecoder
,
uint16_t
*
val
);
static
int
tDecodeI16v
(
SCoder
*
pDecoder
,
int16_t
*
val
);
static
int
32_t
tDecodeI16v
(
SCoder
*
pDecoder
,
int16_t
*
val
);
static
int
tDecodeU32v
(
SCoder
*
pDecoder
,
uint32_t
*
val
);
static
int
32_t
tDecodeU32v
(
SCoder
*
pDecoder
,
uint32_t
*
val
);
static
int
tDecodeI32v
(
SCoder
*
pDecoder
,
int32_t
*
val
);
static
int
32_t
tDecodeI32v
(
SCoder
*
pDecoder
,
int32_t
*
val
);
static
int
tDecodeU64v
(
SCoder
*
pDecoder
,
uint64_t
*
val
);
static
int
32_t
tDecodeU64v
(
SCoder
*
pDecoder
,
uint64_t
*
val
);
static
int
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
32_t
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
);
static
int
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
);
static
int
32_t
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
);
static
int
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
);
static
int
32_t
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
);
static
int
tDecodeBinary
(
SCoder
*
pDecoder
,
const
void
**
val
,
uint64_t
*
len
);
static
int
32_t
tDecodeBinary
(
SCoder
*
pDecoder
,
const
void
**
val
,
uint64_t
*
len
);
static
int
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
);
static
int
32_t
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
);
static
int
tDecodeCStr
(
SCoder
*
pDecoder
,
const
char
**
val
);
static
int
32_t
tDecodeCStr
(
SCoder
*
pDecoder
,
const
char
**
val
);
static
int
tDecodeCStrTo
(
SCoder
*
pDecoder
,
char
*
val
);
static
int
32_t
tDecodeCStrTo
(
SCoder
*
pDecoder
,
char
*
val
);
/* ------------------------ IMPL ------------------------ */
/* ------------------------ IMPL ------------------------ */
#define TD_ENCODE_MACRO(CODER, VAL, TYPE, BITS) \
#define TD_ENCODE_MACRO(CODER, VAL, TYPE, BITS) \
...
@@ -190,7 +190,7 @@ static int tDecodeCStrTo(SCoder* pDecoder, char* val);
...
@@ -190,7 +190,7 @@ static int tDecodeCStrTo(SCoder* pDecoder, char* val);
return 0;
return 0;
// 8
// 8
static
FORCE_INLINE
int
tEncodeU8
(
SCoder
*
pEncoder
,
uint8_t
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeU8
(
SCoder
*
pEncoder
,
uint8_t
val
)
{
if
(
pEncoder
->
data
)
{
if
(
pEncoder
->
data
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
sizeof
(
val
)))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
sizeof
(
val
)))
return
-
1
;
tPut
(
uint8_t
,
TD_CODER_CURRENT
(
pEncoder
),
val
);
tPut
(
uint8_t
,
TD_CODER_CURRENT
(
pEncoder
),
val
);
...
@@ -199,7 +199,7 @@ static FORCE_INLINE int tEncodeU8(SCoder* pEncoder, uint8_t val) {
...
@@ -199,7 +199,7 @@ static FORCE_INLINE int tEncodeU8(SCoder* pEncoder, uint8_t val) {
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tEncodeI8
(
SCoder
*
pEncoder
,
int8_t
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeI8
(
SCoder
*
pEncoder
,
int8_t
val
)
{
if
(
pEncoder
->
data
)
{
if
(
pEncoder
->
data
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
sizeof
(
val
)))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
sizeof
(
val
)))
return
-
1
;
tPut
(
int8_t
,
TD_CODER_CURRENT
(
pEncoder
),
val
);
tPut
(
int8_t
,
TD_CODER_CURRENT
(
pEncoder
),
val
);
...
@@ -209,31 +209,31 @@ static FORCE_INLINE int tEncodeI8(SCoder* pEncoder, int8_t val) {
...
@@ -209,31 +209,31 @@ static FORCE_INLINE int tEncodeI8(SCoder* pEncoder, int8_t val) {
}
}
// 16
// 16
static
FORCE_INLINE
int
tEncodeU16
(
SCoder
*
pEncoder
,
uint16_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint16_t
,
16
);
}
static
FORCE_INLINE
int
32_t
tEncodeU16
(
SCoder
*
pEncoder
,
uint16_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint16_t
,
16
);
}
static
FORCE_INLINE
int
tEncodeI16
(
SCoder
*
pEncoder
,
int16_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int16_t
,
16
);
}
static
FORCE_INLINE
int
32_t
tEncodeI16
(
SCoder
*
pEncoder
,
int16_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int16_t
,
16
);
}
// 32
// 32
static
FORCE_INLINE
int
tEncodeU32
(
SCoder
*
pEncoder
,
uint32_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint32_t
,
32
);
}
static
FORCE_INLINE
int
32_t
tEncodeU32
(
SCoder
*
pEncoder
,
uint32_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint32_t
,
32
);
}
static
FORCE_INLINE
int
tEncodeI32
(
SCoder
*
pEncoder
,
int32_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int32_t
,
32
);
}
static
FORCE_INLINE
int
32_t
tEncodeI32
(
SCoder
*
pEncoder
,
int32_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int32_t
,
32
);
}
// 64
// 64
static
FORCE_INLINE
int
tEncodeU64
(
SCoder
*
pEncoder
,
uint64_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint64_t
,
64
);
}
static
FORCE_INLINE
int
32_t
tEncodeU64
(
SCoder
*
pEncoder
,
uint64_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
uint64_t
,
64
);
}
static
FORCE_INLINE
int
tEncodeI64
(
SCoder
*
pEncoder
,
int64_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int64_t
,
64
);
}
static
FORCE_INLINE
int
32_t
tEncodeI64
(
SCoder
*
pEncoder
,
int64_t
val
)
{
TD_ENCODE_MACRO
(
pEncoder
,
val
,
int64_t
,
64
);
}
// 16v
// 16v
static
FORCE_INLINE
int
tEncodeU16v
(
SCoder
*
pEncoder
,
uint16_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
32_t
tEncodeU16v
(
SCoder
*
pEncoder
,
uint16_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
tEncodeI16v
(
SCoder
*
pEncoder
,
int16_t
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeI16v
(
SCoder
*
pEncoder
,
int16_t
val
)
{
return
tEncodeU16v
(
pEncoder
,
ZIGZAGE
(
int16_t
,
val
));
return
tEncodeU16v
(
pEncoder
,
ZIGZAGE
(
int16_t
,
val
));
}
}
// 32v
// 32v
static
FORCE_INLINE
int
tEncodeU32v
(
SCoder
*
pEncoder
,
uint32_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
32_t
tEncodeU32v
(
SCoder
*
pEncoder
,
uint32_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
tEncodeI32v
(
SCoder
*
pEncoder
,
int32_t
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeI32v
(
SCoder
*
pEncoder
,
int32_t
val
)
{
return
tEncodeU32v
(
pEncoder
,
ZIGZAGE
(
int32_t
,
val
));
return
tEncodeU32v
(
pEncoder
,
ZIGZAGE
(
int32_t
,
val
));
}
}
// 64v
// 64v
static
FORCE_INLINE
int
tEncodeU64v
(
SCoder
*
pEncoder
,
uint64_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
32_t
tEncodeU64v
(
SCoder
*
pEncoder
,
uint64_t
val
)
{
TD_ENCODE_VARIANT_MACRO
(
pEncoder
,
val
);
}
static
FORCE_INLINE
int
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeI64v
(
SCoder
*
pEncoder
,
int64_t
val
)
{
return
tEncodeU64v
(
pEncoder
,
ZIGZAGE
(
int64_t
,
val
));
return
tEncodeU64v
(
pEncoder
,
ZIGZAGE
(
int64_t
,
val
));
}
}
static
FORCE_INLINE
int
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeFloat
(
SCoder
*
pEncoder
,
float
val
)
{
union
{
union
{
uint32_t
ui
;
uint32_t
ui
;
float
f
;
float
f
;
...
@@ -242,7 +242,7 @@ static FORCE_INLINE int tEncodeFloat(SCoder* pEncoder, float val) {
...
@@ -242,7 +242,7 @@ static FORCE_INLINE int tEncodeFloat(SCoder* pEncoder, float val) {
return
tEncodeU32
(
pEncoder
,
v
.
ui
);
return
tEncodeU32
(
pEncoder
,
v
.
ui
);
}
}
static
FORCE_INLINE
int
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeDouble
(
SCoder
*
pEncoder
,
double
val
)
{
union
{
union
{
uint64_t
ui
;
uint64_t
ui
;
double
d
;
double
d
;
...
@@ -251,7 +251,7 @@ static FORCE_INLINE int tEncodeDouble(SCoder* pEncoder, double val) {
...
@@ -251,7 +251,7 @@ static FORCE_INLINE int tEncodeDouble(SCoder* pEncoder, double val) {
return
tEncodeU64
(
pEncoder
,
v
.
ui
);
return
tEncodeU64
(
pEncoder
,
v
.
ui
);
}
}
static
FORCE_INLINE
int
tEncodeBinary
(
SCoder
*
pEncoder
,
const
void
*
val
,
uint64_t
len
)
{
static
FORCE_INLINE
int
32_t
tEncodeBinary
(
SCoder
*
pEncoder
,
const
void
*
val
,
uint64_t
len
)
{
if
(
tEncodeU64v
(
pEncoder
,
len
)
<
0
)
return
-
1
;
if
(
tEncodeU64v
(
pEncoder
,
len
)
<
0
)
return
-
1
;
if
(
pEncoder
->
data
)
{
if
(
pEncoder
->
data
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
len
))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pEncoder
,
len
))
return
-
1
;
...
@@ -262,24 +262,24 @@ static FORCE_INLINE int tEncodeBinary(SCoder* pEncoder, const void* val, uint64_
...
@@ -262,24 +262,24 @@ static FORCE_INLINE int tEncodeBinary(SCoder* pEncoder, const void* val, uint64_
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tEncodeCStrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64_t
len
)
{
static
FORCE_INLINE
int
32_t
tEncodeCStrWithLen
(
SCoder
*
pEncoder
,
const
char
*
val
,
uint64_t
len
)
{
return
tEncodeBinary
(
pEncoder
,
(
void
*
)
val
,
len
+
1
);
return
tEncodeBinary
(
pEncoder
,
(
void
*
)
val
,
len
+
1
);
}
}
static
FORCE_INLINE
int
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
)
{
static
FORCE_INLINE
int
32_t
tEncodeCStr
(
SCoder
*
pEncoder
,
const
char
*
val
)
{
return
tEncodeCStrWithLen
(
pEncoder
,
val
,
(
uint64_t
)
strlen
(
val
));
return
tEncodeCStrWithLen
(
pEncoder
,
val
,
(
uint64_t
)
strlen
(
val
));
}
}
/* ------------------------ FOR DECODER ------------------------ */
/* ------------------------ FOR DECODER ------------------------ */
// 8
// 8
static
FORCE_INLINE
int
tDecodeU8
(
SCoder
*
pDecoder
,
uint8_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeU8
(
SCoder
*
pDecoder
,
uint8_t
*
val
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
sizeof
(
*
val
)))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
sizeof
(
*
val
)))
return
-
1
;
tGet
(
uint8_t
,
TD_CODER_CURRENT
(
pDecoder
),
*
val
);
tGet
(
uint8_t
,
TD_CODER_CURRENT
(
pDecoder
),
*
val
);
TD_CODER_MOVE_POS
(
pDecoder
,
sizeof
(
*
val
));
TD_CODER_MOVE_POS
(
pDecoder
,
sizeof
(
*
val
));
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeI8
(
SCoder
*
pDecoder
,
int8_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeI8
(
SCoder
*
pDecoder
,
int8_t
*
val
)
{
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
sizeof
(
*
val
)))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
sizeof
(
*
val
)))
return
-
1
;
tGet
(
int8_t
,
TD_CODER_CURRENT
(
pDecoder
),
*
val
);
tGet
(
int8_t
,
TD_CODER_CURRENT
(
pDecoder
),
*
val
);
TD_CODER_MOVE_POS
(
pDecoder
,
sizeof
(
*
val
));
TD_CODER_MOVE_POS
(
pDecoder
,
sizeof
(
*
val
));
...
@@ -287,21 +287,27 @@ static FORCE_INLINE int tDecodeI8(SCoder* pDecoder, int8_t* val) {
...
@@ -287,21 +287,27 @@ static FORCE_INLINE int tDecodeI8(SCoder* pDecoder, int8_t* val) {
}
}
// 16
// 16
static
FORCE_INLINE
int
tDecodeU16
(
SCoder
*
pDecoder
,
uint16_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint16_t
,
16
);
}
static
FORCE_INLINE
int32_t
tDecodeU16
(
SCoder
*
pDecoder
,
uint16_t
*
val
)
{
static
FORCE_INLINE
int
tDecodeI16
(
SCoder
*
pDecoder
,
int16_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int16_t
,
16
);
}
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint16_t
,
16
);
}
static
FORCE_INLINE
int32_t
tDecodeI16
(
SCoder
*
pDecoder
,
int16_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int16_t
,
16
);
}
// 32
// 32
static
FORCE_INLINE
int
tDecodeU32
(
SCoder
*
pDecoder
,
uint32_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint32_t
,
32
);
}
static
FORCE_INLINE
int32_t
tDecodeU32
(
SCoder
*
pDecoder
,
uint32_t
*
val
)
{
static
FORCE_INLINE
int
tDecodeI32
(
SCoder
*
pDecoder
,
int32_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int32_t
,
32
);
}
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint32_t
,
32
);
}
static
FORCE_INLINE
int32_t
tDecodeI32
(
SCoder
*
pDecoder
,
int32_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int32_t
,
32
);
}
// 64
// 64
static
FORCE_INLINE
int
tDecodeU64
(
SCoder
*
pDecoder
,
uint64_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint64_t
,
64
);
}
static
FORCE_INLINE
int32_t
tDecodeU64
(
SCoder
*
pDecoder
,
uint64_t
*
val
)
{
static
FORCE_INLINE
int
tDecodeI64
(
SCoder
*
pDecoder
,
int64_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int64_t
,
64
);
}
TD_DECODE_MACRO
(
pDecoder
,
val
,
uint64_t
,
64
);
}
static
FORCE_INLINE
int32_t
tDecodeI64
(
SCoder
*
pDecoder
,
int64_t
*
val
)
{
TD_DECODE_MACRO
(
pDecoder
,
val
,
int64_t
,
64
);
}
// 16v
// 16v
static
FORCE_INLINE
int
tDecodeU16v
(
SCoder
*
pDecoder
,
uint16_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeU16v
(
SCoder
*
pDecoder
,
uint16_t
*
val
)
{
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint16_t
);
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint16_t
);
}
}
static
FORCE_INLINE
int
tDecodeI16v
(
SCoder
*
pDecoder
,
int16_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeI16v
(
SCoder
*
pDecoder
,
int16_t
*
val
)
{
uint16_t
tval
;
uint16_t
tval
;
if
(
tDecodeU16v
(
pDecoder
,
&
tval
)
<
0
)
{
if
(
tDecodeU16v
(
pDecoder
,
&
tval
)
<
0
)
{
return
-
1
;
return
-
1
;
...
@@ -311,11 +317,11 @@ static FORCE_INLINE int tDecodeI16v(SCoder* pDecoder, int16_t* val) {
...
@@ -311,11 +317,11 @@ static FORCE_INLINE int tDecodeI16v(SCoder* pDecoder, int16_t* val) {
}
}
// 32v
// 32v
static
FORCE_INLINE
int
tDecodeU32v
(
SCoder
*
pDecoder
,
uint32_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeU32v
(
SCoder
*
pDecoder
,
uint32_t
*
val
)
{
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint32_t
);
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint32_t
);
}
}
static
FORCE_INLINE
int
tDecodeI32v
(
SCoder
*
pDecoder
,
int32_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeI32v
(
SCoder
*
pDecoder
,
int32_t
*
val
)
{
uint32_t
tval
;
uint32_t
tval
;
if
(
tDecodeU32v
(
pDecoder
,
&
tval
)
<
0
)
{
if
(
tDecodeU32v
(
pDecoder
,
&
tval
)
<
0
)
{
return
-
1
;
return
-
1
;
...
@@ -325,11 +331,11 @@ static FORCE_INLINE int tDecodeI32v(SCoder* pDecoder, int32_t* val) {
...
@@ -325,11 +331,11 @@ static FORCE_INLINE int tDecodeI32v(SCoder* pDecoder, int32_t* val) {
}
}
// 64v
// 64v
static
FORCE_INLINE
int
tDecodeU64v
(
SCoder
*
pDecoder
,
uint64_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeU64v
(
SCoder
*
pDecoder
,
uint64_t
*
val
)
{
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint64_t
);
TD_DECODE_VARIANT_MACRO
(
pDecoder
,
val
,
uint64_t
);
}
}
static
FORCE_INLINE
int
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeI64v
(
SCoder
*
pDecoder
,
int64_t
*
val
)
{
uint64_t
tval
;
uint64_t
tval
;
if
(
tDecodeU64v
(
pDecoder
,
&
tval
)
<
0
)
{
if
(
tDecodeU64v
(
pDecoder
,
&
tval
)
<
0
)
{
return
-
1
;
return
-
1
;
...
@@ -338,7 +344,7 @@ static FORCE_INLINE int tDecodeI64v(SCoder* pDecoder, int64_t* val) {
...
@@ -338,7 +344,7 @@ static FORCE_INLINE int tDecodeI64v(SCoder* pDecoder, int64_t* val) {
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeFloat
(
SCoder
*
pDecoder
,
float
*
val
)
{
union
{
union
{
uint32_t
ui
;
uint32_t
ui
;
float
f
;
float
f
;
...
@@ -352,7 +358,7 @@ static FORCE_INLINE int tDecodeFloat(SCoder* pDecoder, float* val) {
...
@@ -352,7 +358,7 @@ static FORCE_INLINE int tDecodeFloat(SCoder* pDecoder, float* val) {
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeDouble
(
SCoder
*
pDecoder
,
double
*
val
)
{
union
{
union
{
uint64_t
ui
;
uint64_t
ui
;
double
d
;
double
d
;
...
@@ -366,7 +372,7 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
...
@@ -366,7 +372,7 @@ static FORCE_INLINE int tDecodeDouble(SCoder* pDecoder, double* val) {
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeBinary
(
SCoder
*
pDecoder
,
const
void
**
val
,
uint64_t
*
len
)
{
static
FORCE_INLINE
int
32_t
tDecodeBinary
(
SCoder
*
pDecoder
,
const
void
**
val
,
uint64_t
*
len
)
{
if
(
tDecodeU64v
(
pDecoder
,
len
)
<
0
)
return
-
1
;
if
(
tDecodeU64v
(
pDecoder
,
len
)
<
0
)
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
*
len
))
return
-
1
;
if
(
TD_CODER_CHECK_CAPACITY_FAILED
(
pDecoder
,
*
len
))
return
-
1
;
...
@@ -376,18 +382,18 @@ static FORCE_INLINE int tDecodeBinary(SCoder* pDecoder, const void** val, uint64
...
@@ -376,18 +382,18 @@ static FORCE_INLINE int tDecodeBinary(SCoder* pDecoder, const void** val, uint64
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
)
{
static
FORCE_INLINE
int
32_t
tDecodeCStrAndLen
(
SCoder
*
pDecoder
,
const
char
**
val
,
uint64_t
*
len
)
{
if
(
tDecodeBinary
(
pDecoder
,
(
const
void
**
)
val
,
len
)
<
0
)
return
-
1
;
if
(
tDecodeBinary
(
pDecoder
,
(
const
void
**
)
val
,
len
)
<
0
)
return
-
1
;
(
*
len
)
-=
1
;
(
*
len
)
-=
1
;
return
0
;
return
0
;
}
}
static
FORCE_INLINE
int
tDecodeCStr
(
SCoder
*
pDecoder
,
const
char
**
val
)
{
static
FORCE_INLINE
int
32_t
tDecodeCStr
(
SCoder
*
pDecoder
,
const
char
**
val
)
{
uint64_t
len
;
uint64_t
len
;
return
tDecodeCStrAndLen
(
pDecoder
,
val
,
&
len
);
return
tDecodeCStrAndLen
(
pDecoder
,
val
,
&
len
);
}
}
static
int
tDecodeCStrTo
(
SCoder
*
pDecoder
,
char
*
val
)
{
static
int
32_t
tDecodeCStrTo
(
SCoder
*
pDecoder
,
char
*
val
)
{
const
char
*
pStr
;
const
char
*
pStr
;
uint64_t
len
;
uint64_t
len
;
if
(
tDecodeCStrAndLen
(
pDecoder
,
&
pStr
,
&
len
)
<
0
)
return
-
1
;
if
(
tDecodeCStrAndLen
(
pDecoder
,
&
pStr
,
&
len
)
<
0
)
return
-
1
;
...
...
source/util/src/tencode.c
浏览文件 @
426519d6
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
#define _DEFAULT_SOURCE
#include "tencode.h"
#include "tencode.h"
#if __STDC_VERSION__ >= 201112L
#if __STDC_VERSION__ >= 201112L
...
@@ -47,7 +48,7 @@ void tCoderClear(SCoder* pCoder) {
...
@@ -47,7 +48,7 @@ void tCoderClear(SCoder* pCoder) {
}
}
}
}
int
tStartEncode
(
SCoder
*
pCoder
)
{
int
32_t
tStartEncode
(
SCoder
*
pCoder
)
{
struct
SCoderNode
*
pNode
;
struct
SCoderNode
*
pNode
;
ASSERT
(
pCoder
->
type
==
TD_ENCODER
);
ASSERT
(
pCoder
->
type
==
TD_ENCODER
);
...
@@ -96,7 +97,7 @@ void tEndEncode(SCoder* pCoder) {
...
@@ -96,7 +97,7 @@ void tEndEncode(SCoder* pCoder) {
}
}
}
}
int
tStartDecode
(
SCoder
*
pCoder
)
{
int
32_t
tStartDecode
(
SCoder
*
pCoder
)
{
int32_t
len
;
int32_t
len
;
struct
SCoderNode
*
pNode
;
struct
SCoderNode
*
pNode
;
...
...
source/util/test/encodeTest.cpp
浏览文件 @
426519d6
...
@@ -12,41 +12,41 @@
...
@@ -12,41 +12,41 @@
#define BUF_SIZE 64
#define BUF_SIZE 64
td_endian_t
endian_arr
[
2
]
=
{
TD_LITTLE_ENDIAN
,
TD_BIG_ENDIAN
};
td_endian_t
endian_arr
[
2
]
=
{
TD_LITTLE_ENDIAN
,
TD_BIG_ENDIAN
};
static
int
encode
(
SCoder
*
pCoder
,
int8_t
val
)
{
return
tEncodeI8
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
int8_t
val
)
{
return
tEncodeI8
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
uint8_t
val
)
{
return
tEncodeU8
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
uint8_t
val
)
{
return
tEncodeU8
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
int16_t
val
)
{
return
tEncodeI16
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
int16_t
val
)
{
return
tEncodeI16
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
uint16_t
val
)
{
return
tEncodeU16
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
uint16_t
val
)
{
return
tEncodeU16
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
int32_t
val
)
{
return
tEncodeI32
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
int32_t
val
)
{
return
tEncodeI32
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
uint32_t
val
)
{
return
tEncodeU32
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
uint32_t
val
)
{
return
tEncodeU32
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
int64_t
val
)
{
return
tEncodeI64
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
int64_t
val
)
{
return
tEncodeI64
(
pCoder
,
val
);
}
static
int
encode
(
SCoder
*
pCoder
,
uint64_t
val
)
{
return
tEncodeU64
(
pCoder
,
val
);
}
static
int
32_t
encode
(
SCoder
*
pCoder
,
uint64_t
val
)
{
return
tEncodeU64
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
int8_t
*
val
)
{
return
tDecodeI8
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
int8_t
*
val
)
{
return
tDecodeI8
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
uint8_t
*
val
)
{
return
tDecodeU8
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
uint8_t
*
val
)
{
return
tDecodeU8
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
int16_t
*
val
)
{
return
tDecodeI16
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
int16_t
*
val
)
{
return
tDecodeI16
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
uint16_t
*
val
)
{
return
tDecodeU16
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
uint16_t
*
val
)
{
return
tDecodeU16
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
int32_t
*
val
)
{
return
tDecodeI32
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
int32_t
*
val
)
{
return
tDecodeI32
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
uint32_t
*
val
)
{
return
tDecodeU32
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
uint32_t
*
val
)
{
return
tDecodeU32
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
int64_t
*
val
)
{
return
tDecodeI64
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
int64_t
*
val
)
{
return
tDecodeI64
(
pCoder
,
val
);
}
static
int
decode
(
SCoder
*
pCoder
,
uint64_t
*
val
)
{
return
tDecodeU64
(
pCoder
,
val
);
}
static
int
32_t
decode
(
SCoder
*
pCoder
,
uint64_t
*
val
)
{
return
tDecodeU64
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
int8_t
val
)
{
return
tEncodeI8
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
int8_t
val
)
{
return
tEncodeI8
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
uint8_t
val
)
{
return
tEncodeU8
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
uint8_t
val
)
{
return
tEncodeU8
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
int16_t
val
)
{
return
tEncodeI16v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
int16_t
val
)
{
return
tEncodeI16v
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
uint16_t
val
)
{
return
tEncodeU16v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
uint16_t
val
)
{
return
tEncodeU16v
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
int32_t
val
)
{
return
tEncodeI32v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
int32_t
val
)
{
return
tEncodeI32v
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
uint32_t
val
)
{
return
tEncodeU32v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
uint32_t
val
)
{
return
tEncodeU32v
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
int64_t
val
)
{
return
tEncodeI64v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
int64_t
val
)
{
return
tEncodeI64v
(
pCoder
,
val
);
}
static
int
encodev
(
SCoder
*
pCoder
,
uint64_t
val
)
{
return
tEncodeU64v
(
pCoder
,
val
);
}
static
int
32_t
encodev
(
SCoder
*
pCoder
,
uint64_t
val
)
{
return
tEncodeU64v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
int8_t
*
val
)
{
return
tDecodeI8
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
int8_t
*
val
)
{
return
tDecodeI8
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
uint8_t
*
val
)
{
return
tDecodeU8
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
uint8_t
*
val
)
{
return
tDecodeU8
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
int16_t
*
val
)
{
return
tDecodeI16v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
int16_t
*
val
)
{
return
tDecodeI16v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
uint16_t
*
val
)
{
return
tDecodeU16v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
uint16_t
*
val
)
{
return
tDecodeU16v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
int32_t
*
val
)
{
return
tDecodeI32v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
int32_t
*
val
)
{
return
tDecodeI32v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
uint32_t
*
val
)
{
return
tDecodeU32v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
uint32_t
*
val
)
{
return
tDecodeU32v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
int64_t
*
val
)
{
return
tDecodeI64v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
int64_t
*
val
)
{
return
tDecodeI64v
(
pCoder
,
val
);
}
static
int
decodev
(
SCoder
*
pCoder
,
uint64_t
*
val
)
{
return
tDecodeU64v
(
pCoder
,
val
);
}
static
int
32_t
decodev
(
SCoder
*
pCoder
,
uint64_t
*
val
)
{
return
tDecodeU64v
(
pCoder
,
val
);
}
template
<
typename
T
>
template
<
typename
T
>
static
void
simple_encode_decode_func
(
bool
var_len
)
{
static
void
simple_encode_decode_func
(
bool
var_len
)
{
...
@@ -211,7 +211,7 @@ typedef struct {
...
@@ -211,7 +211,7 @@ typedef struct {
char
*
A_c
;
char
*
A_c
;
}
SStructA_v1
;
}
SStructA_v1
;
static
int
tSStructA_v1_encode
(
SCoder
*
pCoder
,
const
SStructA_v1
*
pSAV1
)
{
static
int
32_t
tSStructA_v1_encode
(
SCoder
*
pCoder
,
const
SStructA_v1
*
pSAV1
)
{
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tEncodeI32
(
pCoder
,
pSAV1
->
A_a
)
<
0
)
return
-
1
;
if
(
tEncodeI32
(
pCoder
,
pSAV1
->
A_a
)
<
0
)
return
-
1
;
...
@@ -222,7 +222,7 @@ static int tSStructA_v1_encode(SCoder *pCoder, const SStructA_v1 *pSAV1) {
...
@@ -222,7 +222,7 @@ static int tSStructA_v1_encode(SCoder *pCoder, const SStructA_v1 *pSAV1) {
return
0
;
return
0
;
}
}
static
int
tSStructA_v1_decode
(
SCoder
*
pCoder
,
SStructA_v1
*
pSAV1
)
{
static
int
32_t
tSStructA_v1_decode
(
SCoder
*
pCoder
,
SStructA_v1
*
pSAV1
)
{
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tDecodeI32
(
pCoder
,
&
pSAV1
->
A_a
)
<
0
)
return
-
1
;
if
(
tDecodeI32
(
pCoder
,
&
pSAV1
->
A_a
)
<
0
)
return
-
1
;
...
@@ -246,7 +246,7 @@ typedef struct {
...
@@ -246,7 +246,7 @@ typedef struct {
int16_t
A_e
;
int16_t
A_e
;
}
SStructA_v2
;
}
SStructA_v2
;
static
int
tSStructA_v2_encode
(
SCoder
*
pCoder
,
const
SStructA_v2
*
pSAV2
)
{
static
int
32_t
tSStructA_v2_encode
(
SCoder
*
pCoder
,
const
SStructA_v2
*
pSAV2
)
{
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tEncodeI32
(
pCoder
,
pSAV2
->
A_a
)
<
0
)
return
-
1
;
if
(
tEncodeI32
(
pCoder
,
pSAV2
->
A_a
)
<
0
)
return
-
1
;
...
@@ -261,7 +261,7 @@ static int tSStructA_v2_encode(SCoder *pCoder, const SStructA_v2 *pSAV2) {
...
@@ -261,7 +261,7 @@ static int tSStructA_v2_encode(SCoder *pCoder, const SStructA_v2 *pSAV2) {
return
0
;
return
0
;
}
}
static
int
tSStructA_v2_decode
(
SCoder
*
pCoder
,
SStructA_v2
*
pSAV2
)
{
static
int
32_t
tSStructA_v2_decode
(
SCoder
*
pCoder
,
SStructA_v2
*
pSAV2
)
{
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tDecodeI32
(
pCoder
,
&
pSAV2
->
A_a
)
<
0
)
return
-
1
;
if
(
tDecodeI32
(
pCoder
,
&
pSAV2
->
A_a
)
<
0
)
return
-
1
;
...
@@ -291,7 +291,7 @@ typedef struct {
...
@@ -291,7 +291,7 @@ typedef struct {
int8_t
v_b
;
int8_t
v_b
;
}
SFinalReq_v1
;
}
SFinalReq_v1
;
static
int
tSFinalReq_v1_encode
(
SCoder
*
pCoder
,
const
SFinalReq_v1
*
ps1
)
{
static
int
32_t
tSFinalReq_v1_encode
(
SCoder
*
pCoder
,
const
SFinalReq_v1
*
ps1
)
{
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tSStructA_v1_encode
(
pCoder
,
ps1
->
pA
)
<
0
)
return
-
1
;
if
(
tSStructA_v1_encode
(
pCoder
,
ps1
->
pA
)
<
0
)
return
-
1
;
...
@@ -302,7 +302,7 @@ static int tSFinalReq_v1_encode(SCoder *pCoder, const SFinalReq_v1 *ps1) {
...
@@ -302,7 +302,7 @@ static int tSFinalReq_v1_encode(SCoder *pCoder, const SFinalReq_v1 *ps1) {
return
0
;
return
0
;
}
}
static
int
tSFinalReq_v1_decode
(
SCoder
*
pCoder
,
SFinalReq_v1
*
ps1
)
{
static
int
32_t
tSFinalReq_v1_decode
(
SCoder
*
pCoder
,
SFinalReq_v1
*
ps1
)
{
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
ps1
->
pA
=
(
SStructA_v1
*
)
TCODER_MALLOC
(
sizeof
(
*
(
ps1
->
pA
)),
pCoder
);
ps1
->
pA
=
(
SStructA_v1
*
)
TCODER_MALLOC
(
sizeof
(
*
(
ps1
->
pA
)),
pCoder
);
...
@@ -322,7 +322,7 @@ typedef struct {
...
@@ -322,7 +322,7 @@ typedef struct {
int16_t
v_c
;
int16_t
v_c
;
}
SFinalReq_v2
;
}
SFinalReq_v2
;
static
int
tSFinalReq_v2_encode
(
SCoder
*
pCoder
,
const
SFinalReq_v2
*
ps2
)
{
static
int
32_t
tSFinalReq_v2_encode
(
SCoder
*
pCoder
,
const
SFinalReq_v2
*
ps2
)
{
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartEncode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tSStructA_v2_encode
(
pCoder
,
ps2
->
pA
)
<
0
)
return
-
1
;
if
(
tSStructA_v2_encode
(
pCoder
,
ps2
->
pA
)
<
0
)
return
-
1
;
...
@@ -336,7 +336,7 @@ static int tSFinalReq_v2_encode(SCoder *pCoder, const SFinalReq_v2 *ps2) {
...
@@ -336,7 +336,7 @@ static int tSFinalReq_v2_encode(SCoder *pCoder, const SFinalReq_v2 *ps2) {
return
0
;
return
0
;
}
}
static
int
tSFinalReq_v2_decode
(
SCoder
*
pCoder
,
SFinalReq_v2
*
ps2
)
{
static
int
32_t
tSFinalReq_v2_decode
(
SCoder
*
pCoder
,
SFinalReq_v2
*
ps2
)
{
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
if
(
tStartDecode
(
pCoder
)
<
0
)
return
-
1
;
ps2
->
pA
=
(
SStructA_v2
*
)
TCODER_MALLOC
(
sizeof
(
*
(
ps2
->
pA
)),
pCoder
);
ps2
->
pA
=
(
SStructA_v2
*
)
TCODER_MALLOC
(
sizeof
(
*
(
ps2
->
pA
)),
pCoder
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录