Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
47850942
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看板
未验证
提交
47850942
编写于
7月 08, 2022
作者:
H
Hongze Cheng
提交者:
GitHub
7月 08, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #14692 from taosdata/fix/tsdb_merge_bug
fix: tsdb merge bug
上级
8209b3a5
abbe8fd7
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
52 addition
and
20 deletion
+52
-20
include/util/tencode.h
include/util/tencode.h
+48
-19
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
+2
-0
source/dnode/vnode/src/tsdb/tsdbUtil.c
source/dnode/vnode/src/tsdb/tsdbUtil.c
+2
-1
未找到文件。
include/util/tencode.h
浏览文件 @
47850942
...
...
@@ -477,22 +477,6 @@ static FORCE_INLINE void* tDecoderMalloc(SDecoder* pCoder, int32_t size) {
return n; \
} while (0)
#define tGetV(p, v) \
do { \
int32_t n = 0; \
if (v) *v = 0; \
for (;;) { \
if (p[n] <= 0x7f) { \
if (v) (*v) |= (p[n] << (7 * n)); \
n++; \
break; \
} \
if (v) (*v) |= ((p[n] & 0x7f) << (7 * n)); \
n++; \
} \
return n; \
} while (0)
// PUT
static
FORCE_INLINE
int32_t
tPutU8
(
uint8_t
*
p
,
uint8_t
v
)
{
if
(
p
)
((
uint8_t
*
)
p
)[
0
]
=
v
;
...
...
@@ -607,7 +591,22 @@ static FORCE_INLINE int32_t tGetI64(uint8_t* p, int64_t* v) {
return
sizeof
(
int64_t
);
}
static
FORCE_INLINE
int32_t
tGetU16v
(
uint8_t
*
p
,
uint16_t
*
v
)
{
tGetV
(
p
,
v
);
}
static
FORCE_INLINE
int32_t
tGetU16v
(
uint8_t
*
p
,
uint16_t
*
v
)
{
int32_t
n
=
0
;
if
(
v
)
*
v
=
0
;
for
(;;)
{
if
(
p
[
n
]
<=
0x7f
)
{
if
(
v
)
(
*
v
)
|=
(((
uint16_t
)
p
[
n
])
<<
(
7
*
n
));
n
++
;
break
;
}
if
(
v
)
(
*
v
)
|=
(((
uint16_t
)(
p
[
n
]
&
0x7f
))
<<
(
7
*
n
));
n
++
;
}
return
n
;
}
static
FORCE_INLINE
int32_t
tGetI16v
(
uint8_t
*
p
,
int16_t
*
v
)
{
int32_t
n
;
...
...
@@ -619,7 +618,22 @@ static FORCE_INLINE int32_t tGetI16v(uint8_t* p, int16_t* v) {
return
n
;
}
static
FORCE_INLINE
int32_t
tGetU32v
(
uint8_t
*
p
,
uint32_t
*
v
)
{
tGetV
(
p
,
v
);
}
static
FORCE_INLINE
int32_t
tGetU32v
(
uint8_t
*
p
,
uint32_t
*
v
)
{
int32_t
n
=
0
;
if
(
v
)
*
v
=
0
;
for
(;;)
{
if
(
p
[
n
]
<=
0x7f
)
{
if
(
v
)
(
*
v
)
|=
(((
uint32_t
)
p
[
n
])
<<
(
7
*
n
));
n
++
;
break
;
}
if
(
v
)
(
*
v
)
|=
(((
uint32_t
)(
p
[
n
]
&
0x7f
))
<<
(
7
*
n
));
n
++
;
}
return
n
;
}
static
FORCE_INLINE
int32_t
tGetI32v
(
uint8_t
*
p
,
int32_t
*
v
)
{
int32_t
n
;
...
...
@@ -631,7 +645,22 @@ static FORCE_INLINE int32_t tGetI32v(uint8_t* p, int32_t* v) {
return
n
;
}
static
FORCE_INLINE
int32_t
tGetU64v
(
uint8_t
*
p
,
uint64_t
*
v
)
{
tGetV
(
p
,
v
);
}
static
FORCE_INLINE
int32_t
tGetU64v
(
uint8_t
*
p
,
uint64_t
*
v
)
{
int32_t
n
=
0
;
if
(
v
)
*
v
=
0
;
for
(;;)
{
if
(
p
[
n
]
<=
0x7f
)
{
if
(
v
)
(
*
v
)
|=
(((
uint64_t
)
p
[
n
])
<<
(
7
*
n
));
n
++
;
break
;
}
if
(
v
)
(
*
v
)
|=
(((
uint64_t
)(
p
[
n
]
&
0x7f
))
<<
(
7
*
n
));
n
++
;
}
return
n
;
}
static
FORCE_INLINE
int32_t
tGetI64v
(
uint8_t
*
p
,
int64_t
*
v
)
{
int32_t
n
;
...
...
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
浏览文件 @
47850942
...
...
@@ -424,10 +424,12 @@ int32_t tsdbReadDelIdx(SDelFReader *pReader, SArray *aDelIdx, uint8_t **ppBuf) {
ASSERT
(
n
==
size
-
sizeof
(
TSCKSUM
));
tFree
(
pBuf
);
return
code
;
_err:
tsdbError
(
"vgId:%d read del idx failed since %s"
,
TD_VID
(
pReader
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
tFree
(
pBuf
);
return
code
;
}
...
...
source/dnode/vnode/src/tsdb/tsdbUtil.c
浏览文件 @
47850942
...
...
@@ -1016,7 +1016,7 @@ int32_t tBlockDataAppendRow(SBlockData *pBlockData, TSDBROW *pRow, STSchema *pTS
SColData
*
pColData
;
SColVal
*
pColVal
;
ASSERT
(
nColData
>
0
)
;
if
(
nColData
==
0
)
goto
_exit
;
tRowIterInit
(
pIter
,
pRow
,
pTSchema
);
pColData
=
tBlockDataGetColDataByIdx
(
pBlockData
,
iColData
);
...
...
@@ -1046,6 +1046,7 @@ int32_t tBlockDataAppendRow(SBlockData *pBlockData, TSDBROW *pRow, STSchema *pTS
}
}
_exit:
pBlockData
->
nRow
++
;
return
code
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录