Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
82aeb1ba
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
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看板
提交
82aeb1ba
编写于
3月 28, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'feature/tdb' of
https://github.com/taosdata/TDengine
into feature/meta
上级
051217da
71e04b29
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
20 addition
and
12 deletion
+20
-12
source/libs/tdb/src/db/tdbBtree.c
source/libs/tdb/src/db/tdbBtree.c
+7
-12
source/libs/tdb/src/inc/tdbPage.h
source/libs/tdb/src/inc/tdbPage.h
+1
-0
source/libs/tdb/src/page/tdbPage.c
source/libs/tdb/src/page/tdbPage.c
+12
-0
未找到文件。
source/libs/tdb/src/db/tdbBtree.c
浏览文件 @
82aeb1ba
...
...
@@ -30,7 +30,6 @@ struct SBTree {
int
valLen
;
SPager
*
pPager
;
FKeyComparator
kcmpr
;
u8
fanout
;
int
pageSize
;
int
maxLocal
;
int
minLocal
;
...
...
@@ -85,6 +84,8 @@ int tdbBtreeOpen(int keyLen, int valLen, SPager *pPager, FKeyComparator kcmpr, S
SBTree
*
pBt
;
int
ret
;
ASSERT
(
keyLen
!=
0
);
*
ppBt
=
NULL
;
pBt
=
(
SBTree
*
)
tdbOsCalloc
(
1
,
sizeof
(
*
pBt
));
...
...
@@ -100,21 +101,14 @@ int tdbBtreeOpen(int keyLen, int valLen, SPager *pPager, FKeyComparator kcmpr, S
pBt
->
pPager
=
pPager
;
// pBt->kcmpr
pBt
->
kcmpr
=
kcmpr
?
kcmpr
:
tdbDefaultKeyCmprFn
;
// pBt->fanout
if
(
keyLen
==
TDB_VARIANT_LEN
)
{
pBt
->
fanout
=
TDB_DEFAULT_FANOUT
;
}
else
{
ASSERT
(
0
);
// TODO: pBt->fanout = 0;
}
// pBt->pageSize
pBt
->
pageSize
=
tdbPagerGetPageSize
(
pPager
);
// pBt->maxLocal
pBt
->
maxLocal
=
(
pBt
->
pageSize
-
14
)
/
pBt
->
fanout
;
pBt
->
maxLocal
=
tdbPageCapacity
(
pBt
->
pageSize
,
sizeof
(
SIntHdr
))
/
4
;
// pBt->minLocal: Should not be allowed smaller than 15, which is [nPayload][nKey][nData]
pBt
->
minLocal
=
(
pBt
->
pageSize
-
14
)
/
pBt
->
fanout
/
2
;
pBt
->
minLocal
=
pBt
->
maxLocal
/
2
;
// pBt->maxLeaf
pBt
->
maxLeaf
=
pBt
->
pageSize
-
14
;
pBt
->
maxLeaf
=
tdbPageCapacity
(
pBt
->
pageSize
,
sizeof
(
SLeafHdr
))
;
// pBt->minLeaf
pBt
->
minLeaf
=
pBt
->
minLocal
;
...
...
@@ -929,7 +923,7 @@ static int tdbBtreeEncodeCell(SPage *pPage, const void *pKey, int kLen, const vo
}
// 2. Encode payload part
if
(
leaf
)
{
if
(
leaf
&&
vLen
>
0
)
{
ret
=
tdbBtreeEncodePayload
(
pPage
,
pCell
+
nHeader
,
pKey
,
kLen
,
pVal
,
vLen
,
&
nPayload
);
}
else
{
ret
=
tdbBtreeEncodePayload
(
pPage
,
pCell
+
nHeader
,
pKey
,
kLen
,
NULL
,
0
,
&
nPayload
);
...
...
@@ -968,6 +962,7 @@ static int tdbBtreeDecodePayload(SPage *pPage, const u8 *pPayload, SCellDecoder
return
0
;
}
// TODO: here has problem
static
int
tdbBtreeDecodeCell
(
SPage
*
pPage
,
const
SCell
*
pCell
,
SCellDecoder
*
pDecoder
)
{
u8
flags
;
u8
leaf
;
...
...
source/libs/tdb/src/inc/tdbPage.h
浏览文件 @
82aeb1ba
...
...
@@ -111,6 +111,7 @@ void tdbPageInit(SPage *pPage, u8 szAmHdr, int (*xCellSize)(const SPage *, SCell
int
tdbPageInsertCell
(
SPage
*
pPage
,
int
idx
,
SCell
*
pCell
,
int
szCell
,
u8
asOvfl
);
int
tdbPageDropCell
(
SPage
*
pPage
,
int
idx
);
void
tdbPageCopy
(
SPage
*
pFromPage
,
SPage
*
pToPage
);
int
tdbPageCapacity
(
int
pageSize
,
int
amHdrSize
);
static
inline
SCell
*
tdbPageGetCell
(
SPage
*
pPage
,
int
idx
)
{
SCell
*
pCell
;
...
...
source/libs/tdb/src/page/tdbPage.c
浏览文件 @
82aeb1ba
...
...
@@ -242,6 +242,18 @@ void tdbPageCopy(SPage *pFromPage, SPage *pToPage) {
pToPage
->
nOverflow
=
pFromPage
->
nOverflow
;
}
int
tdbPageCapacity
(
int
pageSize
,
int
amHdrSize
)
{
int
szPageHdr
;
if
(
pageSize
<
65536
)
{
szPageHdr
=
pageMethods
.
szPageHdr
;
}
else
{
szPageHdr
=
pageLargeMethods
.
szPageHdr
;
}
return
pageSize
-
szPageHdr
-
amHdrSize
;
}
static
int
tdbPageAllocate
(
SPage
*
pPage
,
int
szCell
,
SCell
**
ppCell
)
{
SCell
*
pFreeCell
;
u8
*
pOffset
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录