tlosertree.h 1.7 KB
Newer Older
H
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

S
Shengliang Guan 已提交
16 17 18 19
#ifndef _TD_UTIL_LOSERTREE_H_
#define _TD_UTIL_LOSERTREE_H_

#include "os.h"
H
hzcheng 已提交
20 21 22 23 24

#ifdef __cplusplus
extern "C" {
#endif

S
Shengliang Guan 已提交
25
typedef int32_t (*__merge_compare_fn_t)(const void *, const void *, void *param);
H
hzcheng 已提交
26

H
Haojun Liao 已提交
27 28 29 30 31
typedef struct STreeNode {
  int32_t index;
  void   *pData;  // TODO remove it?
} STreeNode;

32 33 34
typedef struct SMultiwayMergeTreeInfo {
  int32_t              numOfSources;
  int32_t              totalSources;
35
  __merge_compare_fn_t comparFn;
S
Shengliang Guan 已提交
36
  void                *param;
37 38
  struct STreeNode    *pNode;
} SMultiwayMergeTreeInfo;
H
hzcheng 已提交
39

H
Haojun Liao 已提交
40 41 42
#define tMergeTreeGetChosenIndex(t_) ((t_)->pNode[0].index)
#define tMergeTreeGetAdjustIndex(t_) (tMergeTreeGetChosenIndex(t_) + (t_)->numOfSources)

S
Shengliang Guan 已提交
43 44
int32_t tMergeTreeCreate(SMultiwayMergeTreeInfo **pTree, uint32_t numOfEntries, void *param,
                         __merge_compare_fn_t compareFn);
H
hzcheng 已提交
45

D
dapan1121 已提交
46
void tMergeTreeDestroy(SMultiwayMergeTreeInfo **pTree);
H
Haojun Liao 已提交
47

48
void tMergeTreeAdjust(SMultiwayMergeTreeInfo *pTree, int32_t idx);
H
hzcheng 已提交
49

50
void tMergeTreeRebuild(SMultiwayMergeTreeInfo *pTree);
H
hzcheng 已提交
51

52
void tMergeTreePrint(const SMultiwayMergeTreeInfo *pTree);
H
hzcheng 已提交
53 54 55 56 57

#ifdef __cplusplus
}
#endif

S
Shengliang Guan 已提交
58
#endif /*_TD_UTIL_LOSERTREE_H_*/