indexTfile.h 3.9 KB
Newer Older
dengyihao's avatar
dengyihao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * 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/>.
 */
#ifndef __INDEX_TFILE_H__
#define __INDEX_TFILE_H__

dengyihao's avatar
dengyihao 已提交
18 19
#include "indexFst.h"
#include "indexFstCountingWriter.h"
dengyihao's avatar
dengyihao 已提交
20
#include "indexInt.h"
dengyihao's avatar
dengyihao 已提交
21 22
#include "indexTfile.h"
#include "indexUtil.h"
23
#include "tlockfree.h"
dengyihao's avatar
dengyihao 已提交
24 25 26 27 28

#ifdef __cplusplus
extern "C" {
#endif

dengyihao's avatar
dengyihao 已提交
29
// tfile header content
dengyihao's avatar
dengyihao 已提交
30 31
// |<---suid--->|<---version--->|<-------colName------>|<---type-->|<--fstOffset->|
// |<-uint64_t->|<---int32_t--->|<--TSDB_COL_NAME_LEN-->|<-uint8_t->|<---int32_t-->|
32

dengyihao's avatar
dengyihao 已提交
33
#pragma pack(push, 1)
dengyihao's avatar
dengyihao 已提交
34
typedef struct TFileHeader {
dengyihao's avatar
dengyihao 已提交
35 36
  uint64_t suid;
  int32_t  version;
dengyihao's avatar
dengyihao 已提交
37
  char     colName[TSDB_COL_NAME_LEN];  //
38
  uint8_t  colType;
dengyihao's avatar
dengyihao 已提交
39
  int32_t  fstOffset;
dengyihao's avatar
dengyihao 已提交
40
} TFileHeader;
dengyihao's avatar
dengyihao 已提交
41
#pragma pack(pop)
dengyihao's avatar
dengyihao 已提交
42

dengyihao's avatar
dengyihao 已提交
43 44
#define TFILE_HEADER_SIZE (sizeof(TFileHeader))
#define TFILE_HEADER_NO_FST (TFILE_HEADER_SIZE - sizeof(int32_t))
dengyihao's avatar
dengyihao 已提交
45 46 47 48 49 50

typedef struct TFileValue {
  char*   colVal;  // null terminated
  SArray* tableId;
  int32_t offset;
} TFileValue;
dengyihao's avatar
dengyihao 已提交
51 52 53 54

// table cache
// refactor to LRU cache later
typedef struct TFileCache {
dengyihao's avatar
dengyihao 已提交
55
  SHashObj* tableCache;
56 57
  int16_t   capacity;
  // add more param
dengyihao's avatar
dengyihao 已提交
58 59
} TFileCache;

dengyihao's avatar
dengyihao 已提交
60
typedef struct TFileWriter {
dengyihao's avatar
dengyihao 已提交
61 62
  FstBuilder* fb;
  WriterCtx*  ctx;
dengyihao's avatar
dengyihao 已提交
63
  TFileHeader header;
dengyihao's avatar
dengyihao 已提交
64
  uint32_t    offset;
dengyihao's avatar
dengyihao 已提交
65 66
} TFileWriter;

dengyihao's avatar
dengyihao 已提交
67
// multi reader and single write
dengyihao's avatar
dengyihao 已提交
68
typedef struct TFileReader {
69
  T_REF_DECLARE()
dengyihao's avatar
dengyihao 已提交
70 71
  Fst*        fst;
  WriterCtx*  ctx;
dengyihao's avatar
dengyihao 已提交
72
  TFileHeader header;
dengyihao's avatar
dengyihao 已提交
73
  bool        remove;
74
} TFileReader;
dengyihao's avatar
dengyihao 已提交
75

dengyihao's avatar
dengyihao 已提交
76
typedef struct IndexTFile {
dengyihao's avatar
dengyihao 已提交
77 78 79
  char*        path;
  TFileCache*  cache;
  TFileWriter* tw;
dengyihao's avatar
dengyihao 已提交
80 81
} IndexTFile;

dengyihao's avatar
dengyihao 已提交
82 83 84
typedef struct TFileWriterOpt {
  uint64_t suid;
  int8_t   colType;
dengyihao's avatar
dengyihao 已提交
85
  char*    colName;
86
  int32_t  nColName;
dengyihao's avatar
dengyihao 已提交
87
  int32_t  version;
88
} TFileWriterOpt;
dengyihao's avatar
dengyihao 已提交
89 90

typedef struct TFileReaderOpt {
91
  uint64_t suid;
dengyihao's avatar
dengyihao 已提交
92
  char*    colName;
93
  int32_t  nColName;
dengyihao's avatar
dengyihao 已提交
94 95
} TFileReaderOpt;

96
// tfile cache, manage tindex reader
dengyihao's avatar
dengyihao 已提交
97 98
TFileCache*  tfileCacheCreate(const char* path);
void         tfileCacheDestroy(TFileCache* tcache);
dengyihao's avatar
dengyihao 已提交
99 100
TFileReader* tfileCacheGet(TFileCache* tcache, ICacheKey* key);
void         tfileCachePut(TFileCache* tcache, ICacheKey* key, TFileReader* reader);
dengyihao's avatar
dengyihao 已提交
101

dengyihao's avatar
dengyihao 已提交
102
TFileReader* tfileGetReaderByCol(IndexTFile* tf, uint64_t suid, char* colName);
dengyihao's avatar
dengyihao 已提交
103

dengyihao's avatar
dengyihao 已提交
104
TFileReader* tfileReaderOpen(char* path, uint64_t suid, int32_t version, const char* colName);
dengyihao's avatar
dengyihao 已提交
105 106
TFileReader* tfileReaderCreate(WriterCtx* ctx);
void         tfileReaderDestroy(TFileReader* reader);
dengyihao's avatar
dengyihao 已提交
107
int          tfileReaderSearch(TFileReader* reader, SIndexTermQuery* query, SIdxTempResult* tr);
dengyihao's avatar
dengyihao 已提交
108 109
void         tfileReaderRef(TFileReader* reader);
void         tfileReaderUnRef(TFileReader* reader);
dengyihao's avatar
dengyihao 已提交
110

dengyihao's avatar
dengyihao 已提交
111
TFileWriter* tfileWriterOpen(char* path, uint64_t suid, int32_t version, const char* colName, uint8_t type);
dengyihao's avatar
dengyihao 已提交
112
void         tfileWriterClose(TFileWriter* tw);
dengyihao's avatar
dengyihao 已提交
113 114
TFileWriter* tfileWriterCreate(WriterCtx* ctx, TFileHeader* header);
void         tfileWriterDestroy(TFileWriter* tw);
dengyihao's avatar
dengyihao 已提交
115
int          tfileWriterPut(TFileWriter* tw, void* data, bool order);
dengyihao's avatar
dengyihao 已提交
116
int          tfileWriterFinish(TFileWriter* tw);
dengyihao's avatar
dengyihao 已提交
117

118
//
dengyihao's avatar
dengyihao 已提交
119
IndexTFile* indexTFileCreate(const char* path);
120
void        indexTFileDestroy(IndexTFile* tfile);
dengyihao's avatar
dengyihao 已提交
121
int         indexTFilePut(void* tfile, SIndexTerm* term, uint64_t uid);
dengyihao's avatar
dengyihao 已提交
122
int         indexTFileSearch(void* tfile, SIndexTermQuery* query, SIdxTempResult* tr);
dengyihao's avatar
dengyihao 已提交
123

dengyihao's avatar
dengyihao 已提交
124 125 126 127 128 129 130 131
Iterate* tfileIteratorCreate(TFileReader* reader);
void     tfileIteratorDestroy(Iterate* iterator);

TFileValue* tfileValueCreate(char* val);

int  tfileValuePush(TFileValue* tf, uint64_t val);
void tfileValueDestroy(TFileValue* tf);

dengyihao's avatar
dengyihao 已提交
132 133 134 135 136 137
#ifdef __cplusplus
}

#endif

#endif