tdataformat.h 14.6 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 "tarray.h"
H
Hongze Cheng 已提交
22
#include "tencode.h"
H
Haojun Liao 已提交
23
#include "ttypes.h"
H
TD-166  
hzcheng 已提交
24
#include "tutil.h"
H
hzcheng 已提交
25

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

H
Hongze Cheng 已提交
30 31 32
typedef struct SSchema       SSchema;
typedef struct STColumn      STColumn;
typedef struct STSchema      STSchema;
H
Hongze Cheng 已提交
33
typedef struct SValue        SValue;
H
Hongze Cheng 已提交
34
typedef struct SColVal       SColVal;
H
Hongze Cheng 已提交
35 36
typedef struct STSRow2       STSRow2;
typedef struct STSRowBuilder STSRowBuilder;
H
Hongze Cheng 已提交
37 38
typedef struct STagVal       STagVal;
typedef struct STag          STag;
H
Hongze Cheng 已提交
39

H
Hongze Cheng 已提交
40
// bitmap
H
Hongze Cheng 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
#define N1(n)        ((1 << (n)) - 1)
#define BIT1_SIZE(n) (((n)-1) / 8 + 1)
#define BIT2_SIZE(n) (((n)-1) / 4 + 1)
#define SET_BIT1(p, i, v)                            \
  do {                                               \
    (p)[(i) / 8] &= N1((i) % 8);                     \
    (p)[(i) / 8] |= (((uint8_t)(v)) << (((i) % 8))); \
  } while (0)

#define GET_BIT1(p, i) (((p)[(i) / 8] >> ((i) % 8)) & ((uint8_t)1))
#define SET_BIT2(p, i, v)                                \
  do {                                                   \
    p[(i) / 4] &= N1((i) % 4 * 2);                       \
    (p)[(i) / 4] |= (((uint8_t)(v)) << (((i) % 4) * 2)); \
  } while (0)
#define GET_BIT2(p, i) (((p)[(i) / 4] >> (((i) % 4) * 2)) & ((uint8_t)3))
H
Hongze Cheng 已提交
57

H
Hongze Cheng 已提交
58
// STSchema
H
Hongze Cheng 已提交
59
int32_t tTSchemaCreate(int32_t sver, SSchema *pSchema, int32_t nCols, STSchema **ppTSchema);
H
Hongze Cheng 已提交
60
void    tTSchemaDestroy(STSchema *pTSchema);
H
Hongze Cheng 已提交
61

H
more  
Hongze Cheng 已提交
62
// SValue
H
Hongze Cheng 已提交
63 64 65
int32_t tPutValue(uint8_t *p, SValue *pValue, int8_t type);
int32_t tGetValue(uint8_t *p, SValue *pValue, int8_t type);
int     tValueCmprFn(const SValue *pValue1, const SValue *pValue2, int8_t type);
H
more  
Hongze Cheng 已提交
66

H
Hongze Cheng 已提交
67
// STSRow2
H
Hongze Cheng 已提交
68 69 70
#define COL_VAL_NONE(CID, TYPE)     ((SColVal){.cid = (CID), .type = (TYPE), .isNone = 1})
#define COL_VAL_NULL(CID, TYPE)     ((SColVal){.cid = (CID), .type = (TYPE), .isNull = 1})
#define COL_VAL_VALUE(CID, TYPE, V) ((SColVal){.cid = (CID), .type = (TYPE), .value = (V)})
H
more  
Hongze Cheng 已提交
71

H
more  
Hongze Cheng 已提交
72
int32_t tTSRowNew(STSRowBuilder *pBuilder, SArray *pArray, STSchema *pTSchema, STSRow2 **ppRow);
H
Hongze Cheng 已提交
73
int32_t tTSRowClone(const STSRow2 *pRow, STSRow2 **ppRow);
H
more  
Hongze Cheng 已提交
74
void    tTSRowFree(STSRow2 *pRow);
H
Hongze Cheng 已提交
75 76
void    tTSRowGet(STSRow2 *pRow, STSchema *pTSchema, int32_t iCol, SColVal *pColVal);
int32_t tTSRowToArray(STSRow2 *pRow, STSchema *pTSchema, SArray **ppArray);
H
Hongze Cheng 已提交
77 78
int32_t tPutTSRow(uint8_t *p, STSRow2 *pRow);
int32_t tGetTSRow(uint8_t *p, STSRow2 *pRow);
H
Hongze Cheng 已提交
79

H
Hongze Cheng 已提交
80
// STSRowBuilder
H
more  
Hongze Cheng 已提交
81 82 83 84 85 86 87
#define tsRowBuilderInit() ((STSRowBuilder){0})
#define tsRowBuilderClear(B)     \
  do {                           \
    if ((B)->pBuf) {             \
      taosMemoryFree((B)->pBuf); \
    }                            \
  } while (0)
H
Hongze Cheng 已提交
88

H
Hongze Cheng 已提交
89
// STag
H
Hongze Cheng 已提交
90
int32_t tTagNew(SArray *pArray, int32_t version, int8_t isJson, STag **ppTag);
H
Hongze Cheng 已提交
91
void    tTagFree(STag *pTag);
wmmhello's avatar
wmmhello 已提交
92 93
bool    tTagIsJson(const void *pTag);
bool    tTagIsJsonNull(void *tagVal);
C
Cary Xu 已提交
94
bool    tTagGet(const STag *pTag, STagVal *pTagVal);
H
more  
Hongze Cheng 已提交
95
char   *tTagValToData(const STagVal *pTagVal, bool isJson);
H
more  
Hongze Cheng 已提交
96
int32_t tEncodeTag(SEncoder *pEncoder, const STag *pTag);
H
Hongze Cheng 已提交
97
int32_t tDecodeTag(SDecoder *pDecoder, STag **ppTag);
C
Cary Xu 已提交
98
int32_t tTagToValArray(const STag *pTag, SArray **ppArray);
H
more  
Hongze Cheng 已提交
99
void    debugPrintSTag(STag *pTag, const char *tag, int32_t ln);  // TODO: remove
wmmhello's avatar
wmmhello 已提交
100
int32_t parseJsontoTagData(const char* json, SArray* pTagVals, STag** ppTag, void* pMsgBuf);
H
Hongze Cheng 已提交
101

H
Hongze Cheng 已提交
102 103 104 105 106 107 108 109 110 111
// STRUCT =================
struct STColumn {
  col_id_t colId;
  int8_t   type;
  int8_t   flags;
  int32_t  bytes;
  int32_t  offset;
};

struct STSchema {
H
Hongze Cheng 已提交
112 113 114 115 116 117
  int32_t  numOfCols;
  int32_t  version;
  int32_t  flen;
  int32_t  vlen;
  int32_t  tlen;
  STColumn columns[];
H
Hongze Cheng 已提交
118 119
};

H
Hongze Cheng 已提交
120 121 122
#define TSROW_HAS_NONE ((uint8_t)0x1)
#define TSROW_HAS_NULL ((uint8_t)0x2U)
#define TSROW_HAS_VAL  ((uint8_t)0x4U)
H
Hongze Cheng 已提交
123 124 125
#define TSROW_KV_SMALL ((uint8_t)0x10U)
#define TSROW_KV_MID   ((uint8_t)0x20U)
#define TSROW_KV_BIG   ((uint8_t)0x40U)
H
Hongze Cheng 已提交
126
struct STSRow2 {
H
Hongze Cheng 已提交
127 128 129 130 131
  TSKEY    ts;
  uint8_t  flags;
  int32_t  sver;
  uint32_t nData;
  uint8_t *pData;
H
Hongze Cheng 已提交
132 133 134
};

struct STSRowBuilder {
H
more  
Hongze Cheng 已提交
135 136 137
  STSRow2  tsRow;
  int32_t  szBuf;
  uint8_t *pBuf;
H
Hongze Cheng 已提交
138 139
};

H
Hongze Cheng 已提交
140 141
struct SValue {
  union {
H
more  
Hongze Cheng 已提交
142 143 144 145 146 147 148 149 150 151 152
    int8_t   i8;   // TSDB_DATA_TYPE_BOOL||TSDB_DATA_TYPE_TINYINT
    uint8_t  u8;   // TSDB_DATA_TYPE_UTINYINT
    int16_t  i16;  // TSDB_DATA_TYPE_SMALLINT
    uint16_t u16;  // TSDB_DATA_TYPE_USMALLINT
    int32_t  i32;  // TSDB_DATA_TYPE_INT
    uint32_t u32;  // TSDB_DATA_TYPE_UINT
    int64_t  i64;  // TSDB_DATA_TYPE_BIGINT
    uint64_t u64;  // TSDB_DATA_TYPE_UBIGINT
    TSKEY    ts;   // TSDB_DATA_TYPE_TIMESTAMP
    float    f;    // TSDB_DATA_TYPE_FLOAT
    double   d;    // TSDB_DATA_TYPE_DOUBLE
H
Hongze Cheng 已提交
153 154 155 156 157 158 159
    struct {
      uint32_t nData;
      uint8_t *pData;
    };
  };
};

H
Hongze Cheng 已提交
160
struct SColVal {
H
Hongze Cheng 已提交
161
  int16_t cid;
H
Hongze Cheng 已提交
162
  int8_t  type;
H
Hongze Cheng 已提交
163 164 165
  int8_t  isNone;
  int8_t  isNull;
  SValue  value;
H
Hongze Cheng 已提交
166 167
};

wmmhello's avatar
wmmhello 已提交
168
#pragma pack(push, 1)
H
Hongze Cheng 已提交
169
struct STagVal {
H
Hongze Cheng 已提交
170 171 172 173
  union {
    int16_t cid;
    char   *pKey;
  };
H
Hongze Cheng 已提交
174 175
  int8_t type;
  union {
H
more  
Hongze Cheng 已提交
176
    int64_t i64;
H
Hongze Cheng 已提交
177 178 179 180 181
    struct {
      uint32_t nData;
      uint8_t *pData;
    };
  };
H
Hongze Cheng 已提交
182 183
};

H
more  
Hongze Cheng 已提交
184
#define TD_TAG_JSON  ((int8_t)0x40)  // distinguish JSON string and JSON value with the highest bit
wmmhello's avatar
wmmhello 已提交
185
#define TD_TAG_LARGE ((int8_t)0x20)
C
Cary Xu 已提交
186
struct STag {
C
Cary Xu 已提交
187
  int8_t  flags;
C
Cary Xu 已提交
188 189 190
  int16_t len;
  int16_t nTag;
  int32_t ver;
C
Cary Xu 已提交
191
  int8_t  idx[];
C
Cary Xu 已提交
192 193 194
};
#pragma pack(pop)

H
Hongze Cheng 已提交
195
#if 1  //================================================================================================================================================
C
Cary Xu 已提交
196 197
// 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 已提交
198
#define TD_SUPPORT_READ2
K
Kaili Xu 已提交
199 200 201
#define TD_SUPPORT_BACK2  // suppport back compatibility of 2.0

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

203 204 205 206 207
#define STR_TO_VARSTR(x, str)                     \
  do {                                            \
    VarDataLenT __len = (VarDataLenT)strlen(str); \
    *(VarDataLenT *)(x) = __len;                  \
    memcpy(varDataVal(x), (str), __len);          \
H
Hongze Cheng 已提交
208 209
  } while (0);

H
Hongze Cheng 已提交
210 211 212 213 214 215
#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 已提交
216

217 218
#define STR_WITH_MAXSIZE_TO_VARSTR(x, str, _maxs)                         \
  do {                                                                    \
H
Hui Li 已提交
219
    char *_e = stpncpy(varDataVal(x), (str), (_maxs)-VARSTR_HEADER_SIZE); \
220
    varDataSetLen(x, (_e - (x)-VARSTR_HEADER_SIZE));                      \
H
Hongze Cheng 已提交
221 222
  } while (0)

223 224 225 226
#define STR_WITH_SIZE_TO_VARSTR(x, str, _size)  \
  do {                                          \
    *(VarDataLenT *)(x) = (VarDataLenT)(_size); \
    memcpy(varDataVal(x), (str), (_size));      \
H
Hongze Cheng 已提交
227
  } while (0);
H
hjxilinx 已提交
228

229 230
// ----------------- TSDB COLUMN DEFINITION

S
Shengliang Guan 已提交
231
#define colType(col)   ((col)->type)
C
Cary Xu 已提交
232
#define colFlags(col)  ((col)->flags)
S
Shengliang Guan 已提交
233 234
#define colColId(col)  ((col)->colId)
#define colBytes(col)  ((col)->bytes)
235 236
#define colOffset(col) ((col)->offset)

S
Shengliang Guan 已提交
237
#define colSetType(col, t)   (colType(col) = (t))
C
Cary Xu 已提交
238
#define colSetFlags(col, f)  (colFlags(col) = (f))
239
#define colSetColId(col, id) (colColId(col) = (id))
S
Shengliang Guan 已提交
240
#define colSetBytes(col, b)  (colBytes(col) = (b))
241 242 243 244
#define colSetOffset(col, o) (colOffset(col) = (o))

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

S
Shengliang Guan 已提交
245 246 247 248 249
#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)
250
#define schemaColAt(s, i) ((s)->columns + i)
wafwerar's avatar
wafwerar 已提交
251
#define tdFreeSchema(s)   taosMemoryFreeClear((s))
252

H
Hongze Cheng 已提交
253
STSchema *tdDupSchema(const STSchema *pSchema);
S
Shengliang Guan 已提交
254 255
int32_t   tdEncodeSchema(void **buf, STSchema *pSchema);
void     *tdDecodeSchema(void *buf, STSchema **pRSchema);
256

S
Shengliang Guan 已提交
257
static FORCE_INLINE int32_t comparColId(const void *key1, const void *key2) {
258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274
  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 已提交
275 276 277 278 279 280 281
  int32_t      tCols;
  int32_t      nCols;
  schema_ver_t version;
  uint16_t     flen;
  int32_t      vlen;
  int32_t      tlen;
  STColumn    *columns;
282 283
} STSchemaBuilder;

C
Cary Xu 已提交
284 285 286 287 288 289 290 291 292 293 294
// 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 已提交
295

C
Cary Xu 已提交
296
int32_t   tdInitTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version);
297
void      tdDestroyTSchemaBuilder(STSchemaBuilder *pBuilder);
C
Cary Xu 已提交
298
void      tdResetTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version);
C
Cary Xu 已提交
299
int32_t   tdAddColToSchema(STSchemaBuilder *pBuilder, int8_t type, int8_t flags, col_id_t colId, col_bytes_t bytes);
300
STSchema *tdGetSchemaFromBuilder(STSchemaBuilder *pBuilder);
H
Hongze Cheng 已提交
301

H
TD-1548  
Hongze Cheng 已提交
302
// ----------------- Semantic timestamp key definition
C
Cary Xu 已提交
303 304
// typedef uint64_t TKEY;
#define TKEY TSKEY
C
Cary Xu 已提交
305

S
Shengliang Guan 已提交
306 307
#define TKEY_INVALID       UINT64_MAX
#define TKEY_NULL          TKEY_INVALID
C
Cary Xu 已提交
308
#define TKEY_NEGATIVE_FLAG (((TKEY)1) << 63)
S
Shengliang Guan 已提交
309
#define TKEY_VALUE_FILTER  (~(TKEY_NEGATIVE_FLAG))
C
Cary Xu 已提交
310 311

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

S
Shengliang Guan 已提交
314
#define tdGetTKEY(key)  (key)
C
Cary Xu 已提交
315
#define tdGetKey(tskey) (tskey)
C
Cary Xu 已提交
316 317 318 319 320 321

#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 已提交
322 323 324 325 326 327 328 329 330 331 332
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 已提交
333
static FORCE_INLINE int32_t tkeyComparFn(const void *tkey1, const void *tkey2) {
H
TD-1548  
Hongze Cheng 已提交
334 335 336 337 338 339 340 341 342 343 344
  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 已提交
345

H
TD-34  
hzcheng 已提交
346
// ----------------- Data column structure
347
// SDataCol arrangement: data => bitmap => dataOffset
H
TD-34  
hzcheng 已提交
348
typedef struct SDataCol {
C
Cary Xu 已提交
349 350 351
  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 已提交
352
  int16_t         colId;      // column ID
S
Shengliang Guan 已提交
353 354 355 356
  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 已提交
357
  VarDataOffsetT *dataOff;    // For binary and nchar data, the offset in the data column
S
Shengliang Guan 已提交
358 359
  void           *pData;      // Actual data pointer
  void           *pBitmap;    // Bitmap pointer
L
lichuang 已提交
360
  TSKEY           ts;         // only used in last NULL column
H
TD-34  
hzcheng 已提交
361 362
} SDataCol;

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

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

S
Shengliang Guan 已提交
369 370 371
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 已提交
372

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

H
TD-34  
hzcheng 已提交
375
typedef struct {
C
update  
Cary Xu 已提交
376 377
  col_id_t  maxCols;    // max number of columns
  col_id_t  numOfCols;  // Total number of cols
S
Shengliang Guan 已提交
378 379
  int32_t   maxPoints;  // max number of points
  int32_t   numOfRows;
C
Cary Xu 已提交
380 381
  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 已提交
382
  SDataCol *cols;
H
TD-34  
hzcheng 已提交
383 384
} SDataCols;

385 386 387
static FORCE_INLINE bool tdDataColsIsBitmapI(SDataCols *pCols) { return pCols->bitmapMode != TSDB_BITMODE_DEFAULT; }
static FORCE_INLINE void tdDataColsSetBitmapI(SDataCols *pCols) { pCols->bitmapMode = TSDB_BITMODE_ONE_BIT; }
static FORCE_INLINE bool tdIsBitmapModeI(int8_t bitmapMode) { return bitmapMode != TSDB_BITMODE_DEFAULT; }
C
Cary Xu 已提交
388

S
Shengliang Guan 已提交
389
#define keyCol(pCols)              (&((pCols)->cols[0]))                    // Key column
C
Cary Xu 已提交
390
#define dataColsTKeyAt(pCols, idx) ((TKEY *)(keyCol(pCols)->pData))[(idx)]  // the idx row of column-wised data
S
Shengliang Guan 已提交
391
#define dataColsKeyAt(pCols, idx)  tdGetKey(dataColsTKeyAt(pCols, idx))
392 393 394 395 396 397 398 399
static FORCE_INLINE TKEY dataColsTKeyFirst(SDataCols *pCols) {
  if (pCols->numOfRows) {
    return dataColsTKeyAt(pCols, 0);
  } else {
    return TKEY_INVALID;
  }
}

S
Shengliang Guan 已提交
400
static FORCE_INLINE TSKEY dataColsKeyAtRow(SDataCols *pCols, int32_t row) {
401
  assert(row < pCols->numOfRows);
402 403 404
  return dataColsKeyAt(pCols, row);
}

405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427
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 已提交
428

S
Shengliang Guan 已提交
429
SDataCols *tdNewDataCols(int32_t maxCols, int32_t maxRows);
H
TD-34  
hzcheng 已提交
430
void       tdResetDataCols(SDataCols *pCols);
S
Shengliang Guan 已提交
431
int32_t    tdInitDataCols(SDataCols *pCols, STSchema *pSchema);
H
TD-100  
hzcheng 已提交
432
SDataCols *tdDupDataCols(SDataCols *pCols, bool keepData);
H
Hongze Cheng 已提交
433
SDataCols *tdFreeDataCols(SDataCols *pCols);
H
Hongze Cheng 已提交
434 435
int32_t    tdMergeDataCols(SDataCols *target, SDataCols *source, int32_t rowsToMerge, int32_t *pOffset, bool update,
                           TDRowVerT maxVer);
H
more  
Hongze Cheng 已提交
436

H
Hongze Cheng 已提交
437
#endif
438

H
more  
hzcheng 已提交
439 440 441 442
#ifdef __cplusplus
}
#endif

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