tdataformat.h 16.1 KB
Newer Older
H
more  
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
/*
 * 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 已提交
15

16 17
#ifndef _TD_COMMON_DATA_FORMAT_H_
#define _TD_COMMON_DATA_FORMAT_H_
H
more  
Hongze Cheng 已提交
18

S
TD-4088  
Shengliang Guan 已提交
19
#include "os.h"
H
Hongze Cheng 已提交
20
#include "talgo.h"
H
Hongze Cheng 已提交
21
#include "tencode.h"
H
Haojun Liao 已提交
22
#include "ttypes.h"
H
TD-166  
hzcheng 已提交
23
#include "tutil.h"
H
hzcheng 已提交
24

H
more  
hzcheng 已提交
25 26 27
#ifdef __cplusplus
extern "C" {
#endif
H
hzcheng 已提交
28

H
Hongze Cheng 已提交
29 30 31
typedef struct SSchema       SSchema;
typedef struct STColumn      STColumn;
typedef struct STSchema      STSchema;
H
Hongze Cheng 已提交
32
typedef struct SColVal       SColVal;
H
Hongze Cheng 已提交
33 34 35 36
typedef struct STSRow2       STSRow2;
typedef struct STSRowBuilder STSRowBuilder;

// STSchema
H
Hongze Cheng 已提交
37
int32_t tTSchemaCreate(int32_t sver, SSchema *pSchema, int32_t nCols, STSchema **ppTSchema);
H
Hongze Cheng 已提交
38
void    tTSchemaDestroy(STSchema *pTSchema);
H
Hongze Cheng 已提交
39

H
Hongze Cheng 已提交
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
// SColVal
#define COL_VAL_SET_NONE(CV) \
  do {                       \
    (CV)->type = COL_NONE;   \
    (CV)->nData = 0;         \
    (CV)->pData = NULL;      \
  } while (0)

#define COL_VAL_SET_NULL(CV) \
  do {                       \
    (CV)->type = COL_NULL;   \
    (CV)->nData = 0;         \
    (CV)->pData = NULL;      \
  } while (0)

#define COL_VAL_SET_VAL(CV, PDATA, NDATA) \
  do {                                    \
    (CV)->type = COL_VAL;                 \
    (CV)->nData = (NDATA);                \
    (CV)->pData = (PDATA);                \
  } while (0)

// STSRow2
int32_t tEncodeTSRow(SEncoder *pEncoder, const STSRow2 *pRow);
int32_t tDecodeTSRow(SDecoder *pDecoder, STSRow2 *pRow);
int32_t tTSRowGet(const STSRow2 *pRow, STSchema *pTSchema, int32_t iCol, SColVal *pColVal);

H
Hongze Cheng 已提交
67 68
// STSRowBuilder
int32_t tTSRowBuilderInit(STSRowBuilder *pBuilder, int32_t sver, SSchema *pSchema, int32_t nCols);
H
Hongze Cheng 已提交
69 70
void    tTSRowBuilderClear(STSRowBuilder *pBuilder);
void    tTSRowBuilderReset(STSRowBuilder *pBuilder);
H
Hongze Cheng 已提交
71 72 73
int32_t tTSRowBuilderPut(STSRowBuilder *pBuilder, int32_t cid, const uint8_t *pData, uint32_t nData);
int32_t tTSRowBuilderGetRow(STSRowBuilder *pBuilder, const STSRow2 **ppRow);

H
Hongze Cheng 已提交
74 75 76 77 78 79 80 81 82 83
// STRUCT =================
struct STColumn {
  col_id_t colId;
  int8_t   type;
  int8_t   flags;
  int32_t  bytes;
  int32_t  offset;
};

struct STSchema {
H
Hongze Cheng 已提交
84 85 86 87 88 89
  int32_t  numOfCols;
  int32_t  version;
  int32_t  flen;
  int32_t  vlen;
  int32_t  tlen;
  STColumn columns[];
H
Hongze Cheng 已提交
90 91
};

H
Hongze Cheng 已提交
92 93 94 95
#define TSROW_HAS_NONE ((uint8_t)0x1)
#define TSROW_HAS_NULL ((uint8_t)0x2U)
#define TSROW_HAS_VAL  ((uint8_t)0x4U)
#define TSROW_KV_ROW   ((uint8_t)0x10U)
H
Hongze Cheng 已提交
96
struct STSRow2 {
H
Hongze Cheng 已提交
97 98 99 100 101
  TSKEY          ts;
  uint8_t        flags;
  int32_t        sver;
  uint32_t       nData;
  const uint8_t *pData;
H
Hongze Cheng 已提交
102 103 104 105
};

struct STSRowBuilder {
  STSchema *pTSchema;
H
Hongze Cheng 已提交
106 107
  int32_t   szBitMap1;
  int32_t   szBitMap2;
H
Hongze Cheng 已提交
108 109 110 111
  int32_t   szKVBuf;
  uint8_t  *pKVBuf;
  int32_t   szTPBuf;
  uint8_t  *pTPBuf;
H
Hongze Cheng 已提交
112 113 114
  int32_t   iCol;
  int32_t   vlenKV;
  int32_t   vlenTP;
H
Hongze Cheng 已提交
115 116 117
  STSRow2   row;
};

H
Hongze Cheng 已提交
118 119
typedef enum { COL_VAL = 0, COL_NONE = 1, COL_NULL = 2 } EColValT;
struct SColVal {
H
Hongze Cheng 已提交
120 121 122
  EColValT       type;
  uint32_t       nData;
  const uint8_t *pData;
H
Hongze Cheng 已提交
123 124
};

H
Hongze Cheng 已提交
125
#if 1  //====================================
C
Cary Xu 已提交
126 127
// Imported since 3.0 and use bitmap to demonstrate None/Null/Norm, while use Null/Norm below 3.0 without of bitmap.
#define TD_SUPPORT_BITMAP
C
Cary Xu 已提交
128
#define TD_SUPPORT_READ2
K
Kaili Xu 已提交
129 130 131
#define TD_SUPPORT_BACK2  // suppport back compatibility of 2.0

#define TASSERT(x) ASSERT(x)
C
Cary Xu 已提交
132

133 134 135 136 137
#define STR_TO_VARSTR(x, str)                     \
  do {                                            \
    VarDataLenT __len = (VarDataLenT)strlen(str); \
    *(VarDataLenT *)(x) = __len;                  \
    memcpy(varDataVal(x), (str), __len);          \
H
Hongze Cheng 已提交
138 139
  } while (0);

H
Hongze Cheng 已提交
140 141 142 143 144 145
#define STR_TO_NET_VARSTR(x, str)                 \
  do {                                            \
    VarDataLenT __len = (VarDataLenT)strlen(str); \
    *(VarDataLenT *)(x) = htons(__len);           \
    memcpy(varDataVal(x), (str), __len);          \
  } while (0);
D
dapan1121 已提交
146

147 148
#define STR_WITH_MAXSIZE_TO_VARSTR(x, str, _maxs)                         \
  do {                                                                    \
H
Hui Li 已提交
149
    char *_e = stpncpy(varDataVal(x), (str), (_maxs)-VARSTR_HEADER_SIZE); \
150
    varDataSetLen(x, (_e - (x)-VARSTR_HEADER_SIZE));                      \
H
Hongze Cheng 已提交
151 152
  } while (0)

153 154 155 156
#define STR_WITH_SIZE_TO_VARSTR(x, str, _size)  \
  do {                                          \
    *(VarDataLenT *)(x) = (VarDataLenT)(_size); \
    memcpy(varDataVal(x), (str), (_size));      \
H
Hongze Cheng 已提交
157
  } while (0);
H
hjxilinx 已提交
158

159 160
// ----------------- TSDB COLUMN DEFINITION

S
Shengliang Guan 已提交
161
#define colType(col)   ((col)->type)
C
Cary Xu 已提交
162
#define colFlags(col)  ((col)->flags)
S
Shengliang Guan 已提交
163 164
#define colColId(col)  ((col)->colId)
#define colBytes(col)  ((col)->bytes)
165 166
#define colOffset(col) ((col)->offset)

S
Shengliang Guan 已提交
167
#define colSetType(col, t)   (colType(col) = (t))
C
Cary Xu 已提交
168
#define colSetFlags(col, f)  (colFlags(col) = (f))
169
#define colSetColId(col, id) (colColId(col) = (id))
S
Shengliang Guan 已提交
170
#define colSetBytes(col, b)  (colBytes(col) = (b))
171 172 173 174
#define colSetOffset(col, o) (colOffset(col) = (o))

// ----------------- TSDB SCHEMA DEFINITION

S
Shengliang Guan 已提交
175 176 177 178 179
#define schemaNCols(s)    ((s)->numOfCols)
#define schemaVersion(s)  ((s)->version)
#define schemaTLen(s)     ((s)->tlen)
#define schemaFLen(s)     ((s)->flen)
#define schemaVLen(s)     ((s)->vlen)
180
#define schemaColAt(s, i) ((s)->columns + i)
wafwerar's avatar
wafwerar 已提交
181
#define tdFreeSchema(s)   taosMemoryFreeClear((s))
182

H
Hongze Cheng 已提交
183
STSchema *tdDupSchema(const STSchema *pSchema);
S
Shengliang Guan 已提交
184 185
int32_t   tdEncodeSchema(void **buf, STSchema *pSchema);
void     *tdDecodeSchema(void *buf, STSchema **pRSchema);
186

S
Shengliang Guan 已提交
187
static FORCE_INLINE int32_t comparColId(const void *key1, const void *key2) {
188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204
  if (*(int16_t *)key1 > ((STColumn *)key2)->colId) {
    return 1;
  } else if (*(int16_t *)key1 < ((STColumn *)key2)->colId) {
    return -1;
  } else {
    return 0;
  }
}

static FORCE_INLINE STColumn *tdGetColOfID(STSchema *pSchema, int16_t colId) {
  void *ptr = bsearch(&colId, (void *)pSchema->columns, schemaNCols(pSchema), sizeof(STColumn), comparColId);
  if (ptr == NULL) return NULL;
  return (STColumn *)ptr;
}

// ----------------- SCHEMA BUILDER DEFINITION
typedef struct {
C
Cary Xu 已提交
205 206 207 208 209 210 211
  int32_t      tCols;
  int32_t      nCols;
  schema_ver_t version;
  uint16_t     flen;
  int32_t      vlen;
  int32_t      tlen;
  STColumn    *columns;
212 213
} STSchemaBuilder;

C
Cary Xu 已提交
214 215 216 217 218 219 220 221 222 223 224
// use 2 bits for bitmap(default: STSRow/sub block)
#define TD_VTYPE_BITS        2
#define TD_VTYPE_PARTS       4  // PARTITIONS: 1 byte / 2 bits
#define TD_VTYPE_OPTR        3  // OPERATOR: 4 - 1, utilize to get remainder
#define TD_BITMAP_BYTES(cnt) (((cnt) + TD_VTYPE_OPTR) >> 2)

// use 1 bit for bitmap(super block)
#define TD_VTYPE_BITS_I        1
#define TD_VTYPE_PARTS_I       8  // PARTITIONS: 1 byte / 1 bit
#define TD_VTYPE_OPTR_I        7  // OPERATOR: 8 - 1, utilize to get remainder
#define TD_BITMAP_BYTES_I(cnt) (((cnt) + TD_VTYPE_OPTR_I) >> 3)
C
Cary Xu 已提交
225

C
Cary Xu 已提交
226
int32_t   tdInitTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version);
227
void      tdDestroyTSchemaBuilder(STSchemaBuilder *pBuilder);
C
Cary Xu 已提交
228
void      tdResetTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version);
C
Cary Xu 已提交
229
int32_t   tdAddColToSchema(STSchemaBuilder *pBuilder, int8_t type, int8_t flags, col_id_t colId, col_bytes_t bytes);
230
STSchema *tdGetSchemaFromBuilder(STSchemaBuilder *pBuilder);
H
Hongze Cheng 已提交
231

H
TD-1548  
Hongze Cheng 已提交
232
// ----------------- Semantic timestamp key definition
C
Cary Xu 已提交
233 234
// typedef uint64_t TKEY;
#define TKEY TSKEY
C
Cary Xu 已提交
235

S
Shengliang Guan 已提交
236 237
#define TKEY_INVALID       UINT64_MAX
#define TKEY_NULL          TKEY_INVALID
C
Cary Xu 已提交
238
#define TKEY_NEGATIVE_FLAG (((TKEY)1) << 63)
S
Shengliang Guan 已提交
239
#define TKEY_VALUE_FILTER  (~(TKEY_NEGATIVE_FLAG))
C
Cary Xu 已提交
240 241

#define TKEY_IS_NEGATIVE(tkey) (((tkey)&TKEY_NEGATIVE_FLAG) != 0)
S
Shengliang Guan 已提交
242
#define TKEY_IS_DELETED(tkey)  (false)
C
Cary Xu 已提交
243

S
Shengliang Guan 已提交
244
#define tdGetTKEY(key)  (key)
C
Cary Xu 已提交
245
#define tdGetKey(tskey) (tskey)
C
Cary Xu 已提交
246 247 248 249 250 251

#define MIN_TS_KEY ((TSKEY)0x8000000000000001)
#define MAX_TS_KEY ((TSKEY)0x7fffffffffffffff)

#define TD_TO_TKEY(key) tdGetTKEY(((key) < MIN_TS_KEY) ? MIN_TS_KEY : (((key) > MAX_TS_KEY) ? MAX_TS_KEY : key))

D
dapan1121 已提交
252 253 254 255 256 257 258 259 260 261 262
static FORCE_INLINE TKEY keyToTkey(TSKEY key) {
  TSKEY lkey = key;
  if (key > MAX_TS_KEY) {
    lkey = MAX_TS_KEY;
  } else if (key < MIN_TS_KEY) {
    lkey = MIN_TS_KEY;
  }

  return tdGetTKEY(lkey);
}

S
Shengliang Guan 已提交
263
static FORCE_INLINE int32_t tkeyComparFn(const void *tkey1, const void *tkey2) {
H
TD-1548  
Hongze Cheng 已提交
264 265 266 267 268 269 270 271 272 273 274
  TSKEY key1 = tdGetKey(*(TKEY *)tkey1);
  TSKEY key2 = tdGetKey(*(TKEY *)tkey2);

  if (key1 < key2) {
    return -1;
  } else if (key1 > key2) {
    return 1;
  } else {
    return 0;
  }
}
H
hzcheng 已提交
275

H
TD-34  
hzcheng 已提交
276
// ----------------- Data column structure
277
// SDataCol arrangement: data => bitmap => dataOffset
H
TD-34  
hzcheng 已提交
278
typedef struct SDataCol {
C
Cary Xu 已提交
279 280 281
  int8_t          type;        // column type
  uint8_t         bitmap : 1;  // 0: no bitmap if all rows are NORM, 1: has bitmap if has NULL/NORM rows
  uint8_t         reserve : 7;
H
TD-166  
hzcheng 已提交
282
  int16_t         colId;      // column ID
S
Shengliang Guan 已提交
283 284 285 286
  int32_t         bytes;      // column data bytes defined
  int32_t         offset;     // data offset in a SDataRow (including the header size)
  int32_t         spaceSize;  // Total space size for this column
  int32_t         len;        // column data length
H
TD-166  
hzcheng 已提交
287
  VarDataOffsetT *dataOff;    // For binary and nchar data, the offset in the data column
S
Shengliang Guan 已提交
288 289
  void           *pData;      // Actual data pointer
  void           *pBitmap;    // Bitmap pointer
L
lichuang 已提交
290
  TSKEY           ts;         // only used in last NULL column
H
TD-34  
hzcheng 已提交
291 292
} SDataCol;

K
kailixu 已提交
293
#define isAllRowsNull(pCol) ((pCol)->len == 0)
K
Kaili Xu 已提交
294
#define isAllRowsNone(pCol) ((pCol)->len == 0)
H
TD-166  
hzcheng 已提交
295 296
static FORCE_INLINE void dataColReset(SDataCol *pDataCol) { pDataCol->len = 0; }

S
Shengliang Guan 已提交
297
int32_t tdAllocMemForCol(SDataCol *pCol, int32_t maxPoints);
298

S
Shengliang Guan 已提交
299 300 301
void    dataColInit(SDataCol *pDataCol, STColumn *pCol, int32_t maxPoints);
int32_t dataColAppendVal(SDataCol *pCol, const void *value, int32_t numOfRows, int32_t maxPoints);
void   *dataColSetOffset(SDataCol *pCol, int32_t nEle);
H
TD-166  
hzcheng 已提交
302

S
Shengliang Guan 已提交
303
bool isNEleNull(SDataCol *pCol, int32_t nEle);
H
TD-166  
hzcheng 已提交
304

H
TD-34  
hzcheng 已提交
305
typedef struct {
C
update  
Cary Xu 已提交
306 307
  col_id_t  maxCols;    // max number of columns
  col_id_t  numOfCols;  // Total number of cols
S
Shengliang Guan 已提交
308 309
  int32_t   maxPoints;  // max number of points
  int32_t   numOfRows;
C
Cary Xu 已提交
310 311
  int32_t   bitmapMode : 1;  // default is 0(2 bits), otherwise 1(1 bit)
  int32_t   sversion : 31;   // TODO: set sversion(not used yet)
H
Hongze Cheng 已提交
312
  SDataCol *cols;
H
TD-34  
hzcheng 已提交
313 314
} SDataCols;

C
Cary Xu 已提交
315 316 317
static FORCE_INLINE bool tdDataColsIsBitmapI(SDataCols *pCols) { return pCols->bitmapMode != 0; }
static FORCE_INLINE void tdDataColsSetBitmapI(SDataCols *pCols) { pCols->bitmapMode = 1; }

S
Shengliang Guan 已提交
318
#define keyCol(pCols)              (&((pCols)->cols[0]))                    // Key column
C
Cary Xu 已提交
319
#define dataColsTKeyAt(pCols, idx) ((TKEY *)(keyCol(pCols)->pData))[(idx)]  // the idx row of column-wised data
S
Shengliang Guan 已提交
320
#define dataColsKeyAt(pCols, idx)  tdGetKey(dataColsTKeyAt(pCols, idx))
321 322 323 324 325 326 327 328
static FORCE_INLINE TKEY dataColsTKeyFirst(SDataCols *pCols) {
  if (pCols->numOfRows) {
    return dataColsTKeyAt(pCols, 0);
  } else {
    return TKEY_INVALID;
  }
}

S
Shengliang Guan 已提交
329
static FORCE_INLINE TSKEY dataColsKeyAtRow(SDataCols *pCols, int32_t row) {
330
  assert(row < pCols->numOfRows);
331 332 333
  return dataColsKeyAt(pCols, row);
}

334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356
static FORCE_INLINE TSKEY dataColsKeyFirst(SDataCols *pCols) {
  if (pCols->numOfRows) {
    return dataColsKeyAt(pCols, 0);
  } else {
    return TSDB_DATA_TIMESTAMP_NULL;
  }
}

static FORCE_INLINE TKEY dataColsTKeyLast(SDataCols *pCols) {
  if (pCols->numOfRows) {
    return dataColsTKeyAt(pCols, pCols->numOfRows - 1);
  } else {
    return TKEY_INVALID;
  }
}

static FORCE_INLINE TSKEY dataColsKeyLast(SDataCols *pCols) {
  if (pCols->numOfRows) {
    return dataColsKeyAt(pCols, pCols->numOfRows - 1);
  } else {
    return TSDB_DATA_TIMESTAMP_NULL;
  }
}
H
TD-34  
hzcheng 已提交
357

S
Shengliang Guan 已提交
358
SDataCols *tdNewDataCols(int32_t maxCols, int32_t maxRows);
H
TD-34  
hzcheng 已提交
359
void       tdResetDataCols(SDataCols *pCols);
S
Shengliang Guan 已提交
360
int32_t    tdInitDataCols(SDataCols *pCols, STSchema *pSchema);
H
TD-100  
hzcheng 已提交
361
SDataCols *tdDupDataCols(SDataCols *pCols, bool keepData);
H
Hongze Cheng 已提交
362
SDataCols *tdFreeDataCols(SDataCols *pCols);
H
Hongze Cheng 已提交
363 364
int32_t    tdMergeDataCols(SDataCols *target, SDataCols *source, int32_t rowsToMerge, int32_t *pOffset, bool update,
                           TDRowVerT maxVer);
H
more  
Hongze Cheng 已提交
365

H
Hongze Cheng 已提交
366
// ----------------- K-V data row structure
C
Cary Xu 已提交
367 368
/* |<-------------------------------------- len -------------------------------------------->|
 * |<----- header  ----->|<--------------------------- body -------------------------------->|
H
Hongze Cheng 已提交
369
 * +----------+----------+---------------------------------+---------------------------------+
C
Cary Xu 已提交
370
 * | uint16_t |  int16_t |                                 |                                 |
H
Hongze Cheng 已提交
371 372 373 374
 * +----------+----------+---------------------------------+---------------------------------+
 * |    len   |   ncols  |           cols index            |             data part           |
 * +----------+----------+---------------------------------+---------------------------------+
 */
H
Hongze Cheng 已提交
375
typedef void *SKVRow;
H
Hongze Cheng 已提交
376 377

typedef struct {
C
Cary Xu 已提交
378 379
  int16_t  colId;
  uint16_t offset;
H
Hongze Cheng 已提交
380 381
} SColIdx;

C
Cary Xu 已提交
382
#define TD_KV_ROW_HEAD_SIZE (sizeof(uint16_t) + sizeof(int16_t))
H
Hongze Cheng 已提交
383

384
#define kvRowLen(r)            (*(uint16_t *)(r))
S
Shengliang Guan 已提交
385 386 387 388 389 390
#define kvRowNCols(r)          (*(int16_t *)POINTER_SHIFT(r, sizeof(uint16_t)))
#define kvRowSetLen(r, len)    kvRowLen(r) = (len)
#define kvRowSetNCols(r, n)    kvRowNCols(r) = (n)
#define kvRowColIdx(r)         (SColIdx *)POINTER_SHIFT(r, TD_KV_ROW_HEAD_SIZE)
#define kvRowValues(r)         POINTER_SHIFT(r, TD_KV_ROW_HEAD_SIZE + sizeof(SColIdx) * kvRowNCols(r))
#define kvRowCpy(dst, r)       memcpy((dst), (r), kvRowLen(r))
H
Hongze Cheng 已提交
391
#define kvRowColVal(r, colIdx) POINTER_SHIFT(kvRowValues(r), (colIdx)->offset)
S
Shengliang Guan 已提交
392
#define kvRowColIdxAt(r, i)    (kvRowColIdx(r) + (i))
wafwerar's avatar
wafwerar 已提交
393
#define kvRowFree(r)           taosMemoryFreeClear(r)
S
Shengliang Guan 已提交
394 395 396 397 398 399 400 401 402 403 404 405 406 407
#define kvRowEnd(r)            POINTER_SHIFT(r, kvRowLen(r))
#define kvRowValLen(r)         (kvRowLen(r) - TD_KV_ROW_HEAD_SIZE - sizeof(SColIdx) * kvRowNCols(r))
#define kvRowTKey(r)           (*(TKEY *)(kvRowValues(r)))
#define kvRowKey(r)            tdGetKey(kvRowTKey(r))
#define kvRowKeys(r)           POINTER_SHIFT(r, *(uint16_t *)POINTER_SHIFT(r, TD_KV_ROW_HEAD_SIZE + sizeof(int16_t)))
#define kvRowDeleted(r)        TKEY_IS_DELETED(kvRowTKey(r))

SKVRow  tdKVRowDup(SKVRow row);
int32_t tdSetKVRowDataOfCol(SKVRow *orow, int16_t colId, int8_t type, void *value);
int32_t tdEncodeKVRow(void **buf, SKVRow row);
void   *tdDecodeKVRow(void *buf, SKVRow *row);
void    tdSortKVRowByColIdx(SKVRow row);

static FORCE_INLINE int32_t comparTagId(const void *key1, const void *key2) {
H
Hongze Cheng 已提交
408 409 410 411 412 413 414 415 416
  if (*(int16_t *)key1 > ((SColIdx *)key2)->colId) {
    return 1;
  } else if (*(int16_t *)key1 < ((SColIdx *)key2)->colId) {
    return -1;
  } else {
    return 0;
  }
}

H
Hongze Cheng 已提交
417
static FORCE_INLINE void *tdGetKVRowValOfCol(const SKVRow row, int16_t colId) {
H
Hongze Cheng 已提交
418
  void *ret = taosbsearch(&colId, kvRowColIdx(row), kvRowNCols(row), sizeof(SColIdx), comparTagId, TD_EQ);
H
Hongze Cheng 已提交
419
  if (ret == NULL) return NULL;
H
Hongze Cheng 已提交
420
  return kvRowColVal(row, (SColIdx *)ret);
H
Hongze Cheng 已提交
421 422
}

L
liuyq-617 已提交
423 424 425 426
static FORCE_INLINE void *tdGetKVRowIdxOfCol(SKVRow row, int16_t colId) {
  return taosbsearch(&colId, kvRowColIdx(row), kvRowNCols(row), sizeof(SColIdx), comparTagId, TD_EQ);
}

H
Hongze Cheng 已提交
427 428 429 430 431
// ----------------- K-V data row builder
typedef struct {
  int16_t  tCols;
  int16_t  nCols;
  SColIdx *pColIdx;
C
Cary Xu 已提交
432 433
  uint16_t alloc;
  uint16_t size;
S
Shengliang Guan 已提交
434
  void    *buf;
H
Hongze Cheng 已提交
435
} SKVRowBuilder;
H
Hongze Cheng 已提交
436

S
Shengliang Guan 已提交
437 438 439 440
int32_t tdInitKVRowBuilder(SKVRowBuilder *pBuilder);
void    tdDestroyKVRowBuilder(SKVRowBuilder *pBuilder);
void    tdResetKVRowBuilder(SKVRowBuilder *pBuilder);
SKVRow  tdGetKVRowFromBuilder(SKVRowBuilder *pBuilder);
H
Hongze Cheng 已提交
441

442
static FORCE_INLINE int32_t tdAddColToKVRow(SKVRowBuilder *pBuilder, col_id_t colId, const void *value, int32_t tlen) {
H
Hongze Cheng 已提交
443 444
  if (pBuilder->nCols >= pBuilder->tCols) {
    pBuilder->tCols *= 2;
wafwerar's avatar
wafwerar 已提交
445
    SColIdx *pColIdx = (SColIdx *)taosMemoryRealloc((void *)(pBuilder->pColIdx), sizeof(SColIdx) * pBuilder->tCols);
T
tickduan 已提交
446 447
    if (pColIdx == NULL) return -1;
    pBuilder->pColIdx = pColIdx;
H
Hongze Cheng 已提交
448 449 450 451 452 453 454 455 456 457 458
  }

  pBuilder->pColIdx[pBuilder->nCols].colId = colId;
  pBuilder->pColIdx[pBuilder->nCols].offset = pBuilder->size;

  pBuilder->nCols++;

  if (tlen > pBuilder->alloc - pBuilder->size) {
    while (tlen > pBuilder->alloc - pBuilder->size) {
      pBuilder->alloc *= 2;
    }
wafwerar's avatar
wafwerar 已提交
459
    void *buf = taosMemoryRealloc(pBuilder->buf, pBuilder->alloc);
T
tickduan 已提交
460 461
    if (buf == NULL) return -1;
    pBuilder->buf = buf;
H
Hongze Cheng 已提交
462 463 464 465 466 467 468
  }

  memcpy(POINTER_SHIFT(pBuilder->buf, pBuilder->size), value, tlen);
  pBuilder->size += tlen;

  return 0;
}
H
Hongze Cheng 已提交
469
#endif
470

H
more  
hzcheng 已提交
471 472 473 474
#ifdef __cplusplus
}
#endif

H
Hongze Cheng 已提交
475
#endif /*_TD_COMMON_DATA_FORMAT_H_*/