tdataformat.c 38.3 KB
Newer Older
H
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
common  
Shengliang Guan 已提交
15 16

#define _DEFAULT_SOURCE
S
slguan 已提交
17
#include "tdataformat.h"
S
Shengliang Guan 已提交
18
#include "tcoding.h"
L
Liu Jicong 已提交
19
#include "tdatablock.h"
S
log  
Shengliang Guan 已提交
20
#include "tlog.h"
H
more  
hzcheng 已提交
21

C
Cary Xu 已提交
22 23
static int32_t tGetTagVal(uint8_t *p, STagVal *pTagVal, int8_t isJson);

H
Hongze Cheng 已提交
24 25 26
#pragma pack(push, 1)
typedef struct {
  int16_t nCols;
H
more  
Hongze Cheng 已提交
27
  uint8_t idx[];
H
Hongze Cheng 已提交
28 29 30
} STSKVRow;
#pragma pack(pop)

H
Hongze Cheng 已提交
31 32
#define TSROW_IS_KV_ROW(r) ((r)->flags & TSROW_KV_ROW)

H
Hongze Cheng 已提交
33
// SValue
H
Hongze Cheng 已提交
34
int32_t tPutValue(uint8_t *p, SValue *pValue, int8_t type) {
H
Hongze Cheng 已提交
35 36 37 38 39 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 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
  int32_t n = 0;

  if (IS_VAR_DATA_TYPE(type)) {
    n += tPutBinary(p ? p + n : p, pValue->pData, pValue->nData);
  } else {
    switch (type) {
      case TSDB_DATA_TYPE_BOOL:
        n += tPutI8(p ? p + n : p, pValue->i8 ? 1 : 0);
        break;
      case TSDB_DATA_TYPE_TINYINT:
        n += tPutI8(p ? p + n : p, pValue->i8);
        break;
      case TSDB_DATA_TYPE_SMALLINT:
        n += tPutI16(p ? p + n : p, pValue->i16);
        break;
      case TSDB_DATA_TYPE_INT:
        n += tPutI32(p ? p + n : p, pValue->i32);
        break;
      case TSDB_DATA_TYPE_BIGINT:
        n += tPutI64(p ? p + n : p, pValue->i64);
        break;
      case TSDB_DATA_TYPE_FLOAT:
        n += tPutFloat(p ? p + n : p, pValue->f);
        break;
      case TSDB_DATA_TYPE_DOUBLE:
        n += tPutDouble(p ? p + n : p, pValue->d);
        break;
      case TSDB_DATA_TYPE_TIMESTAMP:
        n += tPutI64(p ? p + n : p, pValue->ts);
        break;
      case TSDB_DATA_TYPE_UTINYINT:
        n += tPutU8(p ? p + n : p, pValue->u8);
        break;
      case TSDB_DATA_TYPE_USMALLINT:
        n += tPutU16(p ? p + n : p, pValue->u16);
        break;
      case TSDB_DATA_TYPE_UINT:
        n += tPutU32(p ? p + n : p, pValue->u32);
        break;
      case TSDB_DATA_TYPE_UBIGINT:
        n += tPutU64(p ? p + n : p, pValue->u64);
        break;
      default:
        ASSERT(0);
    }
  }

  return n;
}

H
Hongze Cheng 已提交
85
int32_t tGetValue(uint8_t *p, SValue *pValue, int8_t type) {
H
Hongze Cheng 已提交
86 87 88
  int32_t n = 0;

  if (IS_VAR_DATA_TYPE(type)) {
H
Hongze Cheng 已提交
89
    n += tGetBinary(p, &pValue->pData, pValue ? &pValue->nData : NULL);
H
Hongze Cheng 已提交
90 91 92
  } else {
    switch (type) {
      case TSDB_DATA_TYPE_BOOL:
H
Hongze Cheng 已提交
93
        n += tGetI8(p, &pValue->i8);
H
Hongze Cheng 已提交
94 95
        break;
      case TSDB_DATA_TYPE_TINYINT:
H
Hongze Cheng 已提交
96
        n += tGetI8(p, &pValue->i8);
H
Hongze Cheng 已提交
97 98
        break;
      case TSDB_DATA_TYPE_SMALLINT:
H
Hongze Cheng 已提交
99
        n += tGetI16(p, &pValue->i16);
H
Hongze Cheng 已提交
100 101
        break;
      case TSDB_DATA_TYPE_INT:
H
Hongze Cheng 已提交
102
        n += tGetI32(p, &pValue->i32);
H
Hongze Cheng 已提交
103 104
        break;
      case TSDB_DATA_TYPE_BIGINT:
H
Hongze Cheng 已提交
105
        n += tGetI64(p, &pValue->i64);
H
Hongze Cheng 已提交
106 107
        break;
      case TSDB_DATA_TYPE_FLOAT:
H
Hongze Cheng 已提交
108
        n += tGetFloat(p, &pValue->f);
H
Hongze Cheng 已提交
109 110
        break;
      case TSDB_DATA_TYPE_DOUBLE:
H
Hongze Cheng 已提交
111
        n += tGetDouble(p, &pValue->d);
H
Hongze Cheng 已提交
112 113
        break;
      case TSDB_DATA_TYPE_TIMESTAMP:
H
Hongze Cheng 已提交
114
        n += tGetI64(p, &pValue->ts);
H
Hongze Cheng 已提交
115 116
        break;
      case TSDB_DATA_TYPE_UTINYINT:
H
Hongze Cheng 已提交
117
        n += tGetU8(p, &pValue->u8);
H
Hongze Cheng 已提交
118 119
        break;
      case TSDB_DATA_TYPE_USMALLINT:
H
Hongze Cheng 已提交
120
        n += tGetU16(p, &pValue->u16);
H
Hongze Cheng 已提交
121 122
        break;
      case TSDB_DATA_TYPE_UINT:
H
Hongze Cheng 已提交
123
        n += tGetU32(p, &pValue->u32);
H
Hongze Cheng 已提交
124 125
        break;
      case TSDB_DATA_TYPE_UBIGINT:
H
Hongze Cheng 已提交
126
        n += tGetU64(p, &pValue->u64);
H
Hongze Cheng 已提交
127 128 129 130 131 132 133 134 135
        break;
      default:
        ASSERT(0);
    }
  }

  return n;
}

H
more  
Hongze Cheng 已提交
136 137 138 139 140
int tValueCmprFn(const SValue *pValue1, const SValue *pValue2, int8_t type) {
  // TODO
  return 0;
}

H
Hongze Cheng 已提交
141
// STSRow2 ========================================================================
H
Hongze Cheng 已提交
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
static void setBitMap(uint8_t *pb, uint8_t v, int32_t idx, uint8_t flags) {
  if (pb) {
    switch (flags & 0xf) {
      case TSROW_HAS_NULL | TSROW_HAS_NONE:
      case TSROW_HAS_VAL | TSROW_HAS_NONE:
        if (v) {
          SET_BIT1(pb, idx, (uint8_t)1);
        } else {
          SET_BIT1(pb, idx, (uint8_t)0);
        }
        break;
      case TSROW_HAS_VAL | TSROW_HAS_NULL:
        v = v - 1;
        SET_BIT1(pb, idx, v);
        break;
      case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
        SET_BIT2(pb, idx, v);
        break;
H
more  
Hongze Cheng 已提交
160

H
Hongze Cheng 已提交
161 162
      default:
        ASSERT(0);
H
more  
Hongze Cheng 已提交
163 164
    }
  }
H
Hongze Cheng 已提交
165 166 167 168 169 170 171 172 173 174 175
}
#define SET_IDX(p, i, n, f)        \
  do {                             \
    if ((f)&TSROW_KV_SMALL) {      \
      ((uint8_t *)(p))[i] = (n);   \
    } else if ((f)&TSROW_KV_MID) { \
      ((uint16_t *)(p))[i] = (n);  \
    } else {                       \
      ((uint32_t *)(p))[i] = (n);  \
    }                              \
  } while (0)
H
more  
Hongze Cheng 已提交
176

H
Hongze Cheng 已提交
177 178 179 180 181 182
int32_t tTSRowNew(STSRowBuilder *pBuilder, SArray *pArray, STSchema *pTSchema, STSRow2 **ppRow) {
  int32_t   code = 0;
  STColumn *pTColumn;
  SColVal  *pColVal;
  int32_t   nColVal = taosArrayGetSize(pArray);
  int32_t   iColVal;
H
more  
Hongze Cheng 已提交
183

H
Hongze Cheng 已提交
184
  ASSERT(nColVal > 0);
H
more  
Hongze Cheng 已提交
185

H
Hongze Cheng 已提交
186 187 188 189 190 191
  // try
  uint8_t  flags = 0;
  uint32_t ntv = 0;
  uint32_t nkv = 0;
  int16_t  nTag = 0;
  uint32_t maxIdx = 0;
H
more  
Hongze Cheng 已提交
192

H
Hongze Cheng 已提交
193 194
  iColVal = 0;
  for (int32_t iColumn = 0; iColumn < pTSchema->numOfCols; iColumn++) {
H
more  
Hongze Cheng 已提交
195 196 197 198 199 200 201
    pTColumn = &pTSchema->columns[iColumn];
    if (iColVal < nColVal) {
      pColVal = (SColVal *)taosArrayGet(pArray, iColVal);
    } else {
      pColVal = NULL;
    }

H
Hongze Cheng 已提交
202 203 204
    if (iColumn == 0) {
      ASSERT(pColVal->cid == pTColumn->colId);
      ASSERT(pTColumn->type == TSDB_DATA_TYPE_TIMESTAMP);
C
Cary Xu 已提交
205
      ASSERT(pTColumn->colId == PRIMARYKEY_TIMESTAMP_COL_ID);
H
Hongze Cheng 已提交
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231

      iColVal++;
    } else {
      if (pColVal) {
        if (pColVal->cid == pTColumn->colId) {
          iColVal++;

          if (pColVal->isNone) {
            flags |= TSROW_HAS_NONE;
          } else if (pColVal->isNull) {
            flags |= TSROW_HAS_NULL;
            maxIdx = nkv;
            nTag++;
            nkv += tPutI16v(NULL, -pTColumn->colId);
          } else {
            flags |= TSROW_HAS_VAL;
            maxIdx = nkv;
            nTag++;
            nkv += tPutI16v(NULL, pTColumn->colId);
            nkv += tPutValue(NULL, &pColVal->value, pTColumn->type);
            if (IS_VAR_DATA_TYPE(pTColumn->type)) {
              ntv += tPutValue(NULL, &pColVal->value, pTColumn->type);
            }
          }
        } else if (pColVal->cid > pTColumn->colId) {
          flags |= TSROW_HAS_NONE;
H
more  
Hongze Cheng 已提交
232
        } else {
H
Hongze Cheng 已提交
233
          ASSERT(0);
H
more  
Hongze Cheng 已提交
234 235
        }
      } else {
H
Hongze Cheng 已提交
236
        flags |= TSROW_HAS_NONE;
H
more  
Hongze Cheng 已提交
237 238
      }
    }
H
Hongze Cheng 已提交
239
  }
H
more  
Hongze Cheng 已提交
240

C
Cary Xu 已提交
241
  ASSERT(flags);
H
more  
Hongze Cheng 已提交
242

H
Hongze Cheng 已提交
243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264
  // decide
  uint32_t nData = 0;
  uint32_t nDataT = 0;
  uint32_t nDataK = 0;
  if (flags == TSROW_HAS_NONE || flags == TSROW_HAS_NULL) {
    nData = 0;
  } else {
    switch (flags) {
      case TSROW_HAS_VAL:
        nDataT = pTSchema->flen + ntv;
        break;
      case TSROW_HAS_NULL | TSROW_HAS_NONE:
        nDataT = BIT1_SIZE(pTSchema->numOfCols - 1);
        break;
      case TSROW_HAS_VAL | TSROW_HAS_NONE:
      case TSROW_HAS_VAL | TSROW_HAS_NULL:
        nDataT = BIT1_SIZE(pTSchema->numOfCols - 1) + pTSchema->flen + ntv;
        break;
      case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
        nDataT = BIT2_SIZE(pTSchema->numOfCols - 1) + pTSchema->flen + ntv;
        break;
      default:
C
Cary Xu 已提交
265 266
        break;
        ASSERT(0);
H
more  
Hongze Cheng 已提交
267 268
    }

H
Hongze Cheng 已提交
269 270 271 272 273 274 275 276 277 278
    uint8_t tflags = 0;
    if (maxIdx <= UINT8_MAX) {
      nDataK = sizeof(STSKVRow) + sizeof(uint8_t) * nTag + nkv;
      tflags |= TSROW_KV_SMALL;
    } else if (maxIdx <= UINT16_MAX) {
      nDataK = sizeof(STSKVRow) + sizeof(uint16_t) * nTag + nkv;
      tflags |= TSROW_KV_MID;
    } else {
      nDataK = sizeof(STSKVRow) + sizeof(uint32_t) * nTag + nkv;
      tflags |= TSROW_KV_BIG;
H
more  
Hongze Cheng 已提交
279 280
    }

C
Cary Xu 已提交
281
    if (nDataT <= nDataK) {
H
Hongze Cheng 已提交
282
      nData = nDataT;
H
more  
Hongze Cheng 已提交
283
    } else {
H
Hongze Cheng 已提交
284 285
      nData = nDataK;
      flags |= tflags;
H
more  
Hongze Cheng 已提交
286 287
    }
  }
H
more  
Hongze Cheng 已提交
288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305

  // alloc
  if (pBuilder) {
    // create from a builder
    if (nData == 0) {
      pBuilder->tsRow.nData = 0;
      pBuilder->tsRow.pData = NULL;
    } else {
      if (pBuilder->szBuf < nData) {
        uint8_t *p = taosMemoryRealloc(pBuilder->pBuf, nData);
        if (p == NULL) {
          code = TSDB_CODE_OUT_OF_MEMORY;
          goto _exit;
        }
        pBuilder->pBuf = p;
        pBuilder->szBuf = nData;
      }

H
Hongze Cheng 已提交
306
      pBuilder->tsRow.nData = nData;
H
more  
Hongze Cheng 已提交
307 308 309 310 311 312 313 314
      pBuilder->tsRow.pData = pBuilder->pBuf;
    }

    *ppRow = &pBuilder->tsRow;
  } else {
    // create a new one
    *ppRow = (STSRow2 *)taosMemoryMalloc(sizeof(STSRow2));
    if (*ppRow == NULL) {
H
more  
Hongze Cheng 已提交
315 316 317
      code = TSDB_CODE_OUT_OF_MEMORY;
      goto _exit;
    }
H
Hongze Cheng 已提交
318 319 320 321 322
    if (nData == 0) {
      (*ppRow)->nData = 0;
      (*ppRow)->pData = NULL;
    } else {
      (*ppRow)->nData = nData;
H
more  
Hongze Cheng 已提交
323 324
      (*ppRow)->pData = taosMemoryMalloc(nData);
      if ((*ppRow)->pData == NULL) {
H
Hongze Cheng 已提交
325
        taosMemoryFree(*ppRow);
H
more  
Hongze Cheng 已提交
326 327 328 329
        code = TSDB_CODE_OUT_OF_MEMORY;
        goto _exit;
      }
    }
H
more  
Hongze Cheng 已提交
330
  }
H
more  
Hongze Cheng 已提交
331

H
Hongze Cheng 已提交
332 333 334
  // build
  (*ppRow)->flags = flags;
  (*ppRow)->sver = pTSchema->version;
H
more  
Hongze Cheng 已提交
335

H
Hongze Cheng 已提交
336 337 338 339 340 341 342 343 344 345 346 347 348 349
  pColVal = (SColVal *)taosArrayGet(pArray, 0);
  (*ppRow)->ts = pColVal->value.ts;

  if ((*ppRow)->pData) {
    STSKVRow *pTSKVRow = NULL;
    uint8_t  *pidx = NULL;
    uint8_t  *pkv = NULL;
    uint8_t  *pb = NULL;
    uint8_t  *pf = NULL;
    uint8_t  *ptv = NULL;
    nkv = 0;
    ntv = 0;
    iColVal = 1;

C
Cary Xu 已提交
350
    if ((flags & 0xf0) == 0) {
H
Hongze Cheng 已提交
351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370
      switch (flags & 0xf) {
        case TSROW_HAS_VAL:
          pf = (*ppRow)->pData;
          ptv = pf + pTSchema->flen;
          break;
        case TSROW_HAS_NULL | TSROW_HAS_NONE:
          pb = (*ppRow)->pData;
          break;
        case TSROW_HAS_VAL | TSROW_HAS_NONE:
        case TSROW_HAS_VAL | TSROW_HAS_NULL:
          pb = (*ppRow)->pData;
          pf = pb + BIT1_SIZE(pTSchema->numOfCols - 1);
          ptv = pf + pTSchema->flen;
          break;
        case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
          pb = (*ppRow)->pData;
          pf = pb + BIT2_SIZE(pTSchema->numOfCols - 1);
          ptv = pf + pTSchema->flen;
          break;
        default:
C
Cary Xu 已提交
371
          ASSERT(0);
C
Cary Xu 已提交
372
          break;
H
Hongze Cheng 已提交
373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415
      }
    } else {
      pTSKVRow = (STSKVRow *)(*ppRow)->pData;
      pTSKVRow->nCols = 0;
      pidx = pTSKVRow->idx;
      if (flags & TSROW_KV_SMALL) {
        pkv = pidx + sizeof(uint8_t) * nTag;
      } else if (flags & TSROW_KV_MID) {
        pkv = pidx + sizeof(uint16_t) * nTag;
      } else {
        pkv = pidx + sizeof(uint32_t) * nTag;
      }
    }

    for (int32_t iColumn = 1; iColumn < pTSchema->numOfCols; iColumn++) {
      pTColumn = &pTSchema->columns[iColumn];
      if (iColVal < nColVal) {
        pColVal = (SColVal *)taosArrayGet(pArray, iColVal);
      } else {
        pColVal = NULL;
      }

      if (pColVal) {
        if (pColVal->cid == pTColumn->colId) {
          iColVal++;

          if (pColVal->isNone) {
            goto _set_none;
          } else if (pColVal->isNull) {
            goto _set_null;
          } else {
            goto _set_value;
          }
        } else if (pColVal->cid > pTColumn->colId) {
          goto _set_none;
        } else {
          ASSERT(0);
        }
      } else {
        goto _set_none;
      }

    _set_none:
C
Cary Xu 已提交
416
      if ((flags & 0xf0) == 0) {
H
Hongze Cheng 已提交
417
        setBitMap(pb, 0, iColumn - 1, flags);
H
Hongze Cheng 已提交
418
        if (flags & TSROW_HAS_VAL) {  // set 0
C
Cary Xu 已提交
419 420 421 422 423 424
          if (IS_VAR_DATA_TYPE(pTColumn->type)) {
            *(VarDataOffsetT *)(pf + pTColumn->offset) = 0;
          } else {
            tPutValue(pf + pTColumn->offset, &((SValue){0}), pTColumn->type);
          }
        }
H
Hongze Cheng 已提交
425 426 427 428
      }
      continue;

    _set_null:
C
Cary Xu 已提交
429
      if ((flags & 0xf0) == 0) {
H
Hongze Cheng 已提交
430
        setBitMap(pb, 1, iColumn - 1, flags);
H
Hongze Cheng 已提交
431
        if (flags & TSROW_HAS_VAL) {  // set 0
C
Cary Xu 已提交
432 433 434 435 436 437
          if (IS_VAR_DATA_TYPE(pTColumn->type)) {
            *(VarDataOffsetT *)(pf + pTColumn->offset) = 0;
          } else {
            tPutValue(pf + pTColumn->offset, &((SValue){0}), pTColumn->type);
          }
        }
H
Hongze Cheng 已提交
438 439 440 441 442 443
      } else {
        SET_IDX(pidx, pTSKVRow->nCols, nkv, flags);
        pTSKVRow->nCols++;
        nkv += tPutI16v(pkv + nkv, -pTColumn->colId);
      }
      continue;
H
more  
Hongze Cheng 已提交
444

H
Hongze Cheng 已提交
445
    _set_value:
C
Cary Xu 已提交
446
      if ((flags & 0xf0) == 0) {
H
Hongze Cheng 已提交
447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462
        setBitMap(pb, 2, iColumn - 1, flags);

        if (IS_VAR_DATA_TYPE(pTColumn->type)) {
          *(VarDataOffsetT *)(pf + pTColumn->offset) = ntv;
          ntv += tPutValue(ptv + ntv, &pColVal->value, pTColumn->type);
        } else {
          tPutValue(pf + pTColumn->offset, &pColVal->value, pTColumn->type);
        }
      } else {
        SET_IDX(pidx, pTSKVRow->nCols, nkv, flags);
        pTSKVRow->nCols++;
        nkv += tPutI16v(pkv + nkv, pColVal->cid);
        nkv += tPutValue(pkv + nkv, &pColVal->value, pTColumn->type);
      }
      continue;
    }
H
more  
Hongze Cheng 已提交
463 464
  }

H
more  
Hongze Cheng 已提交
465
_exit:
H
Hongze Cheng 已提交
466 467 468
  return code;
}

H
Hongze Cheng 已提交
469 470
int32_t tTSRowClone(const STSRow2 *pRow, STSRow2 **ppRow) {
  int32_t code = 0;
H
Hongze Cheng 已提交
471

H
Hongze Cheng 已提交
472
  (*ppRow) = (STSRow2 *)taosMemoryMalloc(sizeof(**ppRow));
H
Hongze Cheng 已提交
473
  if (*ppRow == NULL) {
H
Hongze Cheng 已提交
474 475
    code = TSDB_CODE_OUT_OF_MEMORY;
    goto _exit;
H
Hongze Cheng 已提交
476
  }
H
Hongze Cheng 已提交
477 478
  **ppRow = *pRow;
  (*ppRow)->pData = NULL;
H
Hongze Cheng 已提交
479 480

  if (pRow->nData) {
H
Hongze Cheng 已提交
481 482 483 484 485 486
    (*ppRow)->pData = taosMemoryMalloc(pRow->nData);
    if ((*ppRow)->pData == NULL) {
      taosMemoryFree(*ppRow);
      code = TSDB_CODE_OUT_OF_MEMORY;
      goto _exit;
    }
H
Hongze Cheng 已提交
487 488 489
    memcpy((*ppRow)->pData, pRow->pData, pRow->nData);
  }

H
Hongze Cheng 已提交
490 491
_exit:
  return code;
H
Hongze Cheng 已提交
492 493 494
}

void tTSRowFree(STSRow2 *pRow) {
H
Hongze Cheng 已提交
495 496 497 498
  if (pRow) {
    if (pRow->pData) taosMemoryFree(pRow->pData);
    taosMemoryFree(pRow);
  }
H
Hongze Cheng 已提交
499 500
}

H
Hongze Cheng 已提交
501
void tTSRowGet(STSRow2 *pRow, STSchema *pTSchema, int32_t iCol, SColVal *pColVal) {
C
Cary Xu 已提交
502
  uint8_t   isTuple = ((pRow->flags & 0xf0) == 0) ? 1 : 0;
H
Hongze Cheng 已提交
503
  STColumn *pTColumn = &pTSchema->columns[iCol];
H
Hongze Cheng 已提交
504 505
  uint8_t   flags = pRow->flags & (uint8_t)0xf;
  SValue    value;
H
Hongze Cheng 已提交
506

H
Hongze Cheng 已提交
507
  ASSERT(iCol < pTSchema->numOfCols);
C
Cary Xu 已提交
508
  ASSERT(flags);
H
Hongze Cheng 已提交
509
  ASSERT(pRow->sver == pTSchema->version);
H
Hongze Cheng 已提交
510

H
Hongze Cheng 已提交
511 512 513
  if (iCol == 0) {
    value.ts = pRow->ts;
    goto _return_value;
H
Hongze Cheng 已提交
514 515
  }

H
Hongze Cheng 已提交
516
  if (flags == TSROW_HAS_NONE) {
H
more  
Hongze Cheng 已提交
517
    goto _return_none;
C
Cary Xu 已提交
518
  } else if (flags == TSROW_HAS_NULL) {
H
more  
Hongze Cheng 已提交
519
    goto _return_null;
H
Hongze Cheng 已提交
520
  }
H
Hongze Cheng 已提交
521

H
Hongze Cheng 已提交
522 523 524 525 526 527 528 529 530 531 532 533 534 535
  ASSERT(pRow->nData && pRow->pData);

  if (isTuple) {
    uint8_t *pb = pRow->pData;
    uint8_t *pf = NULL;
    uint8_t *pv = NULL;
    uint8_t *p;
    uint8_t  b;

    // bit
    switch (flags) {
      case TSROW_HAS_VAL:
        pf = pb;
        break;
H
Hongze Cheng 已提交
536
      case TSROW_HAS_NULL | TSROW_HAS_NONE:
H
Hongze Cheng 已提交
537 538 539
        b = GET_BIT1(pb, iCol - 1);
        if (b == 0) {
          goto _return_none;
H
Hongze Cheng 已提交
540
        } else {
H
Hongze Cheng 已提交
541
          goto _return_null;
H
Hongze Cheng 已提交
542
        }
H
Hongze Cheng 已提交
543
      case TSROW_HAS_VAL | TSROW_HAS_NONE:
H
Hongze Cheng 已提交
544 545 546
        b = GET_BIT1(pb, iCol - 1);
        if (b == 0) {
          goto _return_none;
H
Hongze Cheng 已提交
547
        } else {
H
Hongze Cheng 已提交
548 549
          pf = pb + BIT1_SIZE(pTSchema->numOfCols - 1);
          break;
H
Hongze Cheng 已提交
550
        }
H
Hongze Cheng 已提交
551
      case TSROW_HAS_VAL | TSROW_HAS_NULL:
H
Hongze Cheng 已提交
552 553 554
        b = GET_BIT1(pb, iCol - 1);
        if (b == 0) {
          goto _return_null;
H
Hongze Cheng 已提交
555
        } else {
H
Hongze Cheng 已提交
556 557
          pf = pb + BIT1_SIZE(pTSchema->numOfCols - 1);
          break;
H
Hongze Cheng 已提交
558
        }
H
Hongze Cheng 已提交
559
      case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
H
Hongze Cheng 已提交
560 561 562 563 564
        b = GET_BIT2(pb, iCol - 1);
        if (b == 0) {
          goto _return_none;
        } else if (b == 1) {
          goto _return_null;
H
Hongze Cheng 已提交
565
        } else {
H
Hongze Cheng 已提交
566 567
          pf = pb + BIT2_SIZE(pTSchema->numOfCols - 1);
          break;
H
Hongze Cheng 已提交
568
        }
H
Hongze Cheng 已提交
569
      default:
H
Hongze Cheng 已提交
570
        ASSERT(0);
H
Hongze Cheng 已提交
571
    }
H
Hongze Cheng 已提交
572

H
Hongze Cheng 已提交
573 574 575
    ASSERT(pf);

    p = pf + pTColumn->offset;
H
Hongze Cheng 已提交
576
    if (IS_VAR_DATA_TYPE(pTColumn->type)) {
H
Hongze Cheng 已提交
577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598
      pv = pf + pTSchema->flen;
      p = pv + *(VarDataOffsetT *)p;
    }
    tGetValue(p, &value, pTColumn->type);
    goto _return_value;
  } else {
    STSKVRow *pRowK = (STSKVRow *)pRow->pData;
    int16_t   lidx = 0;
    int16_t   ridx = pRowK->nCols - 1;
    uint8_t  *p;
    int16_t   midx;
    uint32_t  n;
    int16_t   cid;

    ASSERT(pRowK->nCols > 0);

    if (pRow->flags & TSROW_KV_SMALL) {
      p = pRow->pData + sizeof(STSKVRow) + sizeof(uint8_t) * pRowK->nCols;
    } else if (pRow->flags & TSROW_KV_MID) {
      p = pRow->pData + sizeof(STSKVRow) + sizeof(uint16_t) * pRowK->nCols;
    } else if (pRow->flags & TSROW_KV_BIG) {
      p = pRow->pData + sizeof(STSKVRow) + sizeof(uint32_t) * pRowK->nCols;
H
Hongze Cheng 已提交
599
    } else {
H
Hongze Cheng 已提交
600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628
      ASSERT(0);
    }
    while (lidx <= ridx) {
      midx = (lidx + ridx) / 2;

      if (pRow->flags & TSROW_KV_SMALL) {
        n = ((uint8_t *)pRowK->idx)[midx];
      } else if (pRow->flags & TSROW_KV_MID) {
        n = ((uint16_t *)pRowK->idx)[midx];
      } else {
        n = ((uint32_t *)pRowK->idx)[midx];
      }

      n += tGetI16v(p + n, &cid);

      if (TABS(cid) == pTColumn->colId) {
        if (cid < 0) {
          goto _return_null;
        } else {
          n += tGetValue(p + n, &value, pTColumn->type);
          goto _return_value;
        }

        return;
      } else if (TABS(cid) > pTColumn->colId) {
        ridx = midx - 1;
      } else {
        lidx = midx + 1;
      }
H
Hongze Cheng 已提交
629
    }
H
Hongze Cheng 已提交
630 631 632

    // not found, return NONE
    goto _return_none;
H
Hongze Cheng 已提交
633
  }
H
Hongze Cheng 已提交
634

H
Hongze Cheng 已提交
635
_return_none:
H
Hongze Cheng 已提交
636
  *pColVal = COL_VAL_NONE(pTColumn->colId, pTColumn->type);
H
Hongze Cheng 已提交
637 638 639
  return;

_return_null:
H
Hongze Cheng 已提交
640
  *pColVal = COL_VAL_NULL(pTColumn->colId, pTColumn->type);
H
Hongze Cheng 已提交
641 642 643
  return;

_return_value:
H
Hongze Cheng 已提交
644
  *pColVal = COL_VAL_VALUE(pTColumn->colId, pTColumn->type, value);
H
Hongze Cheng 已提交
645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710
  return;
}

int32_t tTSRowToArray(STSRow2 *pRow, STSchema *pTSchema, SArray **ppArray) {
  int32_t code = 0;
  SColVal cv;

  (*ppArray) = taosArrayInit(pTSchema->numOfCols, sizeof(SColVal));
  if (*ppArray == NULL) {
    code = TSDB_CODE_OUT_OF_MEMORY;
    goto _exit;
  }

  for (int32_t iColumn = 0; iColumn < pTSchema->numOfCols; iColumn++) {
    tTSRowGet(pRow, pTSchema, iColumn, &cv);
    taosArrayPush(*ppArray, &cv);
  }

_exit:
  return code;
}

int32_t tPutTSRow(uint8_t *p, STSRow2 *pRow) {
  int32_t n = 0;

  n += tPutI64(p ? p + n : p, pRow->ts);
  n += tPutI8(p ? p + n : p, pRow->flags);
  n += tPutI32v(p ? p + n : p, pRow->sver);

  ASSERT(pRow->flags & 0xf);

  switch (pRow->flags & 0xf) {
    case TSROW_HAS_NONE:
    case TSROW_HAS_NULL:
      ASSERT(pRow->nData == 0);
      ASSERT(pRow->pData == NULL);
      break;
    default:
      ASSERT(pRow->nData && pRow->pData);
      n += tPutBinary(p ? p + n : p, pRow->pData, pRow->nData);
      break;
  }

  return n;
}

int32_t tGetTSRow(uint8_t *p, STSRow2 *pRow) {
  int32_t n = 0;

  n += tGetI64(p + n, &pRow->ts);
  n += tGetI8(p + n, &pRow->flags);
  n += tGetI32v(p + n, &pRow->sver);

  ASSERT(pRow->flags);
  switch (pRow->flags & 0xf) {
    case TSROW_HAS_NONE:
    case TSROW_HAS_NULL:
      pRow->nData = 0;
      pRow->pData = NULL;
      break;
    default:
      n += tGetBinary(p + n, &pRow->pData, &pRow->nData);
      break;
  }

  return n;
H
Hongze Cheng 已提交
711 712 713
}

// STSchema
H
Hongze Cheng 已提交
714 715 716 717 718 719 720
int32_t tTSchemaCreate(int32_t sver, SSchema *pSchema, int32_t ncols, STSchema **ppTSchema) {
  *ppTSchema = (STSchema *)taosMemoryMalloc(sizeof(STSchema) + sizeof(STColumn) * ncols);
  if (*ppTSchema == NULL) {
    terrno = TSDB_CODE_OUT_OF_MEMORY;
    return -1;
  }

H
Hongze Cheng 已提交
721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745
  (*ppTSchema)->numOfCols = ncols;
  (*ppTSchema)->version = sver;
  (*ppTSchema)->flen = 0;
  (*ppTSchema)->vlen = 0;
  (*ppTSchema)->tlen = 0;

  for (int32_t iCol = 0; iCol < ncols; iCol++) {
    SSchema  *pColumn = &pSchema[iCol];
    STColumn *pTColumn = &((*ppTSchema)->columns[iCol]);

    pTColumn->colId = pColumn->colId;
    pTColumn->type = pColumn->type;
    pTColumn->flags = pColumn->flags;
    pTColumn->bytes = pColumn->bytes;
    pTColumn->offset = (*ppTSchema)->flen;

    // skip first column
    if (iCol) {
      (*ppTSchema)->flen += TYPE_BYTES[pColumn->type];
      if (IS_VAR_DATA_TYPE(pColumn->type)) {
        (*ppTSchema)->vlen += (pColumn->bytes + 5);
      }
    }
  }

H
Hongze Cheng 已提交
746 747 748
  return 0;
}

H
Hongze Cheng 已提交
749 750 751
void tTSchemaDestroy(STSchema *pTSchema) {
  if (pTSchema) taosMemoryFree(pTSchema);
}
H
Hongze Cheng 已提交
752

H
Hongze Cheng 已提交
753
// STSRowBuilder
H
Hongze Cheng 已提交
754

H
more  
Hongze Cheng 已提交
755
// STag
H
Hongze Cheng 已提交
756 757
static int tTagValCmprFn(const void *p1, const void *p2) {
  if (((STagVal *)p1)->cid < ((STagVal *)p2)->cid) {
H
Hongze Cheng 已提交
758
    return -1;
H
Hongze Cheng 已提交
759
  } else if (((STagVal *)p1)->cid > ((STagVal *)p2)->cid) {
H
Hongze Cheng 已提交
760 761
    return 1;
  }
H
Hongze Cheng 已提交
762

H
Hongze Cheng 已提交
763 764
  return 0;
}
H
Hongze Cheng 已提交
765 766 767
static int tTagValJsonCmprFn(const void *p1, const void *p2) {
  return strcmp(((STagVal *)p1)[0].pKey, ((STagVal *)p2)[0].pKey);
}
C
Cary Xu 已提交
768 769 770 771 772 773 774

static void debugPrintTagVal(int8_t type, const void *val, int32_t vlen, const char *tag, int32_t ln) {
  switch (type) {
    case TSDB_DATA_TYPE_JSON:
    case TSDB_DATA_TYPE_VARCHAR:
    case TSDB_DATA_TYPE_NCHAR: {
      char tmpVal[32] = {0};
775
      strncpy(tmpVal, val, vlen > 31 ? 31 : vlen);
C
Cary Xu 已提交
776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813
      printf("%s:%d type:%d vlen:%d, val:\"%s\"\n", tag, ln, (int32_t)type, vlen, tmpVal);
    } break;
    case TSDB_DATA_TYPE_FLOAT:
      printf("%s:%d type:%d vlen:%d, val:%f\n", tag, ln, (int32_t)type, vlen, *(float *)val);
      break;
    case TSDB_DATA_TYPE_DOUBLE:
      printf("%s:%d type:%d vlen:%d, val:%lf\n", tag, ln, (int32_t)type, vlen, *(double *)val);
      break;
    case TSDB_DATA_TYPE_BOOL:
      printf("%s:%d type:%d vlen:%d, val:%" PRIu8 "\n", tag, ln, (int32_t)type, vlen, *(uint8_t *)val);
      break;
    case TSDB_DATA_TYPE_TINYINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi8 "\n", tag, ln, (int32_t)type, vlen, *(int8_t *)val);
      break;
    case TSDB_DATA_TYPE_SMALLINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi16 "\n", tag, ln, (int32_t)type, vlen, *(int16_t *)val);
      break;
    case TSDB_DATA_TYPE_INT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi32 "\n", tag, ln, (int32_t)type, vlen, *(int32_t *)val);
      break;
    case TSDB_DATA_TYPE_BIGINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi64 "\n", tag, ln, (int32_t)type, vlen, *(int64_t *)val);
      break;
    case TSDB_DATA_TYPE_TIMESTAMP:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi64 "\n", tag, ln, (int32_t)type, vlen, *(int64_t *)val);
      break;
    case TSDB_DATA_TYPE_UTINYINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIu8 "\n", tag, ln, (int32_t)type, vlen, *(uint8_t *)val);
      break;
    case TSDB_DATA_TYPE_USMALLINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIu16 "\n", tag, ln, (int32_t)type, vlen, *(uint16_t *)val);
      break;
    case TSDB_DATA_TYPE_UINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIu32 "\n", tag, ln, (int32_t)type, vlen, *(uint32_t *)val);
      break;
    case TSDB_DATA_TYPE_UBIGINT:
      printf("%s:%d type:%d vlen:%d, val:%" PRIu64 "\n", tag, ln, (int32_t)type, vlen, *(uint64_t *)val);
      break;
wmmhello's avatar
wmmhello 已提交
814 815 816
    case TSDB_DATA_TYPE_NULL:
      printf("%s:%d type:%d vlen:%d, val:%" PRIi8 "\n", tag, ln, (int32_t)type, vlen, *(int8_t *)val);
      break;
C
Cary Xu 已提交
817 818 819 820 821 822 823
    default:
      ASSERT(0);
      break;
  }
}

void debugPrintSTag(STag *pTag, const char *tag, int32_t ln) {
H
Hongze Cheng 已提交
824 825
  int8_t   isJson = pTag->flags & TD_TAG_JSON;
  int8_t   isLarge = pTag->flags & TD_TAG_LARGE;
826 827 828 829 830 831 832 833 834 835
  uint8_t *p = NULL;
  int16_t  offset = 0;

  if (isLarge) {
    p = (uint8_t *)&((int16_t *)pTag->idx)[pTag->nTag];
  } else {
    p = (uint8_t *)&pTag->idx[pTag->nTag];
  }
  printf("%s:%d >>> STAG === %s:%s, len: %d, nTag: %d, sver:%d\n", tag, ln, isJson ? "json" : "normal",
         isLarge ? "large" : "small", (int32_t)pTag->len, (int32_t)pTag->nTag, pTag->ver);
C
Cary Xu 已提交
836
  for (uint16_t n = 0; n < pTag->nTag; ++n) {
837 838 839 840 841 842 843 844
    if (isLarge) {
      offset = ((int16_t *)pTag->idx)[n];
    } else {
      offset = pTag->idx[n];
    }
    STagVal tagVal = {0};
    if (isJson) {
      tagVal.pKey = (char *)POINTER_SHIFT(p, offset);
C
Cary Xu 已提交
845
    } else {
846
      tagVal.cid = *(int16_t *)POINTER_SHIFT(p, offset);
C
Cary Xu 已提交
847
    }
848
    printf("%s:%d loop[%d-%d] offset=%d\n", __func__, __LINE__, (int32_t)pTag->nTag, (int32_t)n, (int32_t)offset);
C
Cary Xu 已提交
849
    tGetTagVal(p + offset, &tagVal, isJson);
850
    if (IS_VAR_DATA_TYPE(tagVal.type)) {
wmmhello's avatar
wmmhello 已提交
851
      debugPrintTagVal(tagVal.type, tagVal.pData, tagVal.nData, __func__, __LINE__);
852
    } else {
wmmhello's avatar
wmmhello 已提交
853 854
      debugPrintTagVal(tagVal.type, &tagVal.i64, tDataTypes[tagVal.type].bytes, __func__, __LINE__);
    }
C
Cary Xu 已提交
855 856 857 858
  }
  printf("\n");
}

H
Hongze Cheng 已提交
859 860
static int32_t tPutTagVal(uint8_t *p, STagVal *pTagVal, int8_t isJson) {
  int32_t n = 0;
H
Hongze Cheng 已提交
861

H
Hongze Cheng 已提交
862 863 864 865 866 867
  // key
  if (isJson) {
    n += tPutCStr(p ? p + n : p, pTagVal->pKey);
  } else {
    n += tPutI16v(p ? p + n : p, pTagVal->cid);
  }
H
Hongze Cheng 已提交
868

H
Hongze Cheng 已提交
869 870 871 872 873 874 875
  // type
  n += tPutI8(p ? p + n : p, pTagVal->type);

  // value
  if (IS_VAR_DATA_TYPE(pTagVal->type)) {
    n += tPutBinary(p ? p + n : p, pTagVal->pData, pTagVal->nData);
  } else {
H
Hongze Cheng 已提交
876
    p = p ? p + n : p;
wmmhello's avatar
wmmhello 已提交
877
    n += tDataTypes[pTagVal->type].bytes;
878
    if (p) memcpy(p, &(pTagVal->i64), tDataTypes[pTagVal->type].bytes);
H
Hongze Cheng 已提交
879 880
  }

H
Hongze Cheng 已提交
881 882 883 884 885 886 887 888 889 890
  return n;
}
static int32_t tGetTagVal(uint8_t *p, STagVal *pTagVal, int8_t isJson) {
  int32_t n = 0;

  // key
  if (isJson) {
    n += tGetCStr(p + n, &pTagVal->pKey);
  } else {
    n += tGetI16v(p + n, &pTagVal->cid);
H
Hongze Cheng 已提交
891 892
  }

H
Hongze Cheng 已提交
893 894
  // type
  n += tGetI8(p + n, &pTagVal->type);
H
Hongze Cheng 已提交
895

H
Hongze Cheng 已提交
896 897 898 899
  // value
  if (IS_VAR_DATA_TYPE(pTagVal->type)) {
    n += tGetBinary(p + n, &pTagVal->pData, &pTagVal->nData);
  } else {
wmmhello's avatar
wmmhello 已提交
900
    memcpy(&(pTagVal->i64), p + n, tDataTypes[pTagVal->type].bytes);
wmmhello's avatar
wmmhello 已提交
901
    n += tDataTypes[pTagVal->type].bytes;
H
Hongze Cheng 已提交
902 903 904 905
  }

  return n;
}
wmmhello's avatar
wmmhello 已提交
906 907 908 909 910 911 912 913 914 915 916 917

bool tTagIsJson(const void *pTag){
  return (((const STag *)pTag)->flags & TD_TAG_JSON);
}

bool tTagIsJsonNull(void *data){
  STag *pTag = (STag*)data;
  int8_t   isJson = tTagIsJson(pTag);
  if(!isJson) return false;
  return ((STag*)data)->nTag == 0;
}

H
Hongze Cheng 已提交
918
int32_t tTagNew(SArray *pArray, int32_t version, int8_t isJson, STag **ppTag) {
H
Hongze Cheng 已提交
919 920 921
  int32_t  code = 0;
  uint8_t *p = NULL;
  int16_t  n = 0;
H
Hongze Cheng 已提交
922
  int16_t  nTag = taosArrayGetSize(pArray);
H
Hongze Cheng 已提交
923 924
  int32_t  szTag = 0;
  int8_t   isLarge = 0;
H
Hongze Cheng 已提交
925 926 927

  // sort
  if (isJson) {
wafwerar's avatar
wafwerar 已提交
928
    taosSort(pArray->pData, nTag, sizeof(STagVal), tTagValJsonCmprFn);
H
Hongze Cheng 已提交
929
  } else {
wafwerar's avatar
wafwerar 已提交
930
    taosSort(pArray->pData, nTag, sizeof(STagVal), tTagValCmprFn);
H
Hongze Cheng 已提交
931 932 933
  }

  // get size
H
Hongze Cheng 已提交
934
  for (int16_t iTag = 0; iTag < nTag; iTag++) {
H
Hongze Cheng 已提交
935
    szTag += tPutTagVal(NULL, (STagVal *)taosArrayGet(pArray, iTag), isJson);
H
Hongze Cheng 已提交
936
  }
H
Hongze Cheng 已提交
937 938 939 940 941 942
  if (szTag <= INT8_MAX) {
    szTag = szTag + sizeof(STag) + sizeof(int8_t) * nTag;
  } else {
    szTag = szTag + sizeof(STag) + sizeof(int16_t) * nTag;
    isLarge = 1;
  }
H
Hongze Cheng 已提交
943

H
Hongze Cheng 已提交
944
  ASSERT(szTag <= INT16_MAX);
H
Hongze Cheng 已提交
945 946

  // build tag
C
Cary Xu 已提交
947
  (*ppTag) = (STag *)taosMemoryCalloc(szTag, 1);
H
Hongze Cheng 已提交
948 949 950 951
  if ((*ppTag) == NULL) {
    code = TSDB_CODE_OUT_OF_MEMORY;
    goto _err;
  }
H
Hongze Cheng 已提交
952 953 954 955 956 957 958
  (*ppTag)->flags = 0;
  if (isJson) {
    (*ppTag)->flags |= TD_TAG_JSON;
  }
  if (isLarge) {
    (*ppTag)->flags |= TD_TAG_LARGE;
  }
H
Hongze Cheng 已提交
959 960 961
  (*ppTag)->len = szTag;
  (*ppTag)->nTag = nTag;
  (*ppTag)->ver = version;
H
Hongze Cheng 已提交
962

H
Hongze Cheng 已提交
963 964 965 966 967
  if (isLarge) {
    p = (uint8_t *)&((int16_t *)(*ppTag)->idx)[nTag];
  } else {
    p = (uint8_t *)&(*ppTag)->idx[nTag];
  }
H
Hongze Cheng 已提交
968 969
  n = 0;
  for (int16_t iTag = 0; iTag < nTag; iTag++) {
H
Hongze Cheng 已提交
970 971 972 973 974
    if (isLarge) {
      ((int16_t *)(*ppTag)->idx)[iTag] = n;
    } else {
      (*ppTag)->idx[iTag] = n;
    }
H
Hongze Cheng 已提交
975
    n += tPutTagVal(p + n, (STagVal *)taosArrayGet(pArray, iTag), isJson);
H
Hongze Cheng 已提交
976
  }
977
#ifdef TD_DEBUG_PRINT_TAG
C
Cary Xu 已提交
978
  debugPrintSTag(*ppTag, __func__, __LINE__);
979
#endif
C
Cary Xu 已提交
980

H
Hongze Cheng 已提交
981 982 983 984
  return code;

_err:
  return code;
H
Hongze Cheng 已提交
985 986 987 988 989 990
}

void tTagFree(STag *pTag) {
  if (pTag) taosMemoryFree(pTag);
}

991 992 993
char *tTagValToData(const STagVal *value, bool isJson) {
  if (!value) return NULL;
  char  *data = NULL;
wmmhello's avatar
wmmhello 已提交
994 995 996 997
  int8_t typeBytes = 0;
  if (isJson) {
    typeBytes = CHAR_BYTES;
  }
998
  if (IS_VAR_DATA_TYPE(value->type)) {
wmmhello's avatar
wmmhello 已提交
999
    data = taosMemoryCalloc(1, typeBytes + VARSTR_HEADER_SIZE + value->nData);
1000 1001
    if (data == NULL) return NULL;
    if (isJson) *data = value->type;
wmmhello's avatar
wmmhello 已提交
1002 1003
    varDataLen(data + typeBytes) = value->nData;
    memcpy(varDataVal(data + typeBytes), value->pData, value->nData);
1004 1005
  } else {
    data = ((char *)&(value->i64)) - typeBytes;  // json with type
wmmhello's avatar
wmmhello 已提交
1006 1007 1008 1009 1010
  }

  return data;
}

C
Cary Xu 已提交
1011
bool tTagGet(const STag *pTag, STagVal *pTagVal) {
H
Hongze Cheng 已提交
1012 1013 1014
  int16_t  lidx = 0;
  int16_t  ridx = pTag->nTag - 1;
  int16_t  midx;
H
Hongze Cheng 已提交
1015 1016 1017 1018
  uint8_t *p;
  int8_t   isJson = pTag->flags & TD_TAG_JSON;
  int8_t   isLarge = pTag->flags & TD_TAG_LARGE;
  int16_t  offset;
H
Hongze Cheng 已提交
1019 1020 1021
  STagVal  tv;
  int      c;

H
Hongze Cheng 已提交
1022 1023 1024 1025 1026 1027
  if (isLarge) {
    p = (uint8_t *)&((int16_t *)pTag->idx)[pTag->nTag];
  } else {
    p = (uint8_t *)&pTag->idx[pTag->nTag];
  }

H
Hongze Cheng 已提交
1028 1029 1030 1031 1032
  pTagVal->type = TSDB_DATA_TYPE_NULL;
  pTagVal->pData = NULL;
  pTagVal->nData = 0;
  while (lidx <= ridx) {
    midx = (lidx + ridx) / 2;
H
Hongze Cheng 已提交
1033 1034 1035 1036 1037
    if (isLarge) {
      offset = ((int16_t *)pTag->idx)[midx];
    } else {
      offset = pTag->idx[midx];
    }
H
Hongze Cheng 已提交
1038

H
Hongze Cheng 已提交
1039 1040
    tGetTagVal(p + offset, &tv, isJson);
    if (isJson) {
H
Hongze Cheng 已提交
1041
      c = tTagValJsonCmprFn(pTagVal, &tv);
H
Hongze Cheng 已提交
1042
    } else {
H
Hongze Cheng 已提交
1043
      c = tTagValCmprFn(pTagVal, &tv);
H
Hongze Cheng 已提交
1044 1045
    }

H
Hongze Cheng 已提交
1046 1047 1048 1049
    if (c < 0) {
      ridx = midx - 1;
    } else if (c > 0) {
      lidx = midx + 1;
H
Hongze Cheng 已提交
1050
    } else {
H
Hongze Cheng 已提交
1051
      memcpy(pTagVal, &tv, sizeof(tv));
C
Cary Xu 已提交
1052
      return true;
H
Hongze Cheng 已提交
1053 1054
    }
  }
C
Cary Xu 已提交
1055
  return false;
H
Hongze Cheng 已提交
1056 1057
}

H
more  
Hongze Cheng 已提交
1058 1059
int32_t tEncodeTag(SEncoder *pEncoder, const STag *pTag) {
  return tEncodeBinary(pEncoder, (const uint8_t *)pTag, pTag->len);
H
Hongze Cheng 已提交
1060 1061
}

H
more  
Hongze Cheng 已提交
1062
int32_t tDecodeTag(SDecoder *pDecoder, STag **ppTag) { return tDecodeBinary(pDecoder, (uint8_t **)ppTag, NULL); }
H
Hongze Cheng 已提交
1063

C
Cary Xu 已提交
1064
int32_t tTagToValArray(const STag *pTag, SArray **ppArray) {
H
Hongze Cheng 已提交
1065
  int32_t  code = 0;
1066 1067 1068 1069 1070 1071 1072 1073 1074 1075
  uint8_t *p = NULL;
  STagVal  tv = {0};
  int8_t   isLarge = pTag->flags & TD_TAG_LARGE;
  int16_t  offset = 0;

  if (isLarge) {
    p = (uint8_t *)&((int16_t *)pTag->idx)[pTag->nTag];
  } else {
    p = (uint8_t *)&pTag->idx[pTag->nTag];
  }
H
Hongze Cheng 已提交
1076

H
more  
Hongze Cheng 已提交
1077
  (*ppArray) = taosArrayInit(pTag->nTag + 1, sizeof(STagVal));
H
Hongze Cheng 已提交
1078
  if (*ppArray == NULL) {
H
Hongze Cheng 已提交
1079 1080 1081 1082 1083
    code = TSDB_CODE_OUT_OF_MEMORY;
    goto _err;
  }

  for (int16_t iTag = 0; iTag < pTag->nTag; iTag++) {
1084 1085 1086 1087 1088 1089
    if (isLarge) {
      offset = ((int16_t *)pTag->idx)[iTag];
    } else {
      offset = pTag->idx[iTag];
    }
    tGetTagVal(p + offset, &tv, pTag->flags & TD_TAG_JSON);
H
Hongze Cheng 已提交
1090
    taosArrayPush(*ppArray, &tv);
H
Hongze Cheng 已提交
1091 1092 1093 1094 1095 1096 1097 1098
  }

  return code;

_err:
  return code;
}

H
Hongze Cheng 已提交
1099
#if 1  // ===================================================================================================================
1100
static void dataColSetNEleNull(SDataCol *pCol, int nEle);
H
Hongze Cheng 已提交
1101
int         tdAllocMemForCol(SDataCol *pCol, int maxPoints) {
H
Hongze Cheng 已提交
1102 1103 1104
          int spaceNeeded = pCol->bytes * maxPoints;
          if (IS_VAR_DATA_TYPE(pCol->type)) {
            spaceNeeded += sizeof(VarDataOffsetT) * maxPoints;
L
Liu Jicong 已提交
1105
  }
C
Cary Xu 已提交
1106
#ifdef TD_SUPPORT_BITMAP
C
Cary Xu 已提交
1107 1108 1109 1110
  int32_t nBitmapBytes = (int32_t)TD_BITMAP_BYTES(maxPoints);
  spaceNeeded += (int)nBitmapBytes;
  // TODO: Currently, the compression of bitmap parts is affiliated to the column data parts, thus allocate 1 more
  // TYPE_BYTES as to comprise complete TYPE_BYTES. Otherwise, invalid read/write would be triggered.
H
Hongze Cheng 已提交
1111 1112
  // spaceNeeded += TYPE_BYTES[pCol->type]; // the bitmap part is append as a single part since 2022.04.03, thus
  // remove the additional space
C
Cary Xu 已提交
1113
#endif
C
Cary Xu 已提交
1114

S
Shengliang Guan 已提交
1115
  if (pCol->spaceSize < spaceNeeded) {
wafwerar's avatar
wafwerar 已提交
1116
    void *ptr = taosMemoryRealloc(pCol->pData, spaceNeeded);
S
Shengliang Guan 已提交
1117 1118
    if (ptr == NULL) {
      uDebug("malloc failure, size:%" PRId64 " failed, reason:%s", (int64_t)spaceNeeded, strerror(errno));
L
Liu Jicong 已提交
1119
      return -1;
L
Liu Jicong 已提交
1120 1121 1122
    } else {
      pCol->pData = ptr;
      pCol->spaceSize = spaceNeeded;
1123 1124
    }
  }
C
Cary Xu 已提交
1125
#ifdef TD_SUPPORT_BITMAP
1126

C
Cary Xu 已提交
1127 1128 1129 1130
  if (IS_VAR_DATA_TYPE(pCol->type)) {
    pCol->pBitmap = POINTER_SHIFT(pCol->pData, pCol->bytes * maxPoints);
    pCol->dataOff = POINTER_SHIFT(pCol->pBitmap, nBitmapBytes);
  } else {
C
Cary Xu 已提交
1131
    pCol->pBitmap = POINTER_SHIFT(pCol->pData, pCol->bytes * maxPoints);
L
Liu Jicong 已提交
1132
  }
C
Cary Xu 已提交
1133 1134 1135 1136
#else
  if (IS_VAR_DATA_TYPE(pCol->type)) {
    pCol->dataOff = POINTER_SHIFT(pCol->pData, pCol->bytes * maxPoints);
  }
C
Cary Xu 已提交
1137
#endif
L
Liu Jicong 已提交
1138
  return 0;
1139 1140
}

H
hzcheng 已提交
1141 1142 1143
/**
 * Duplicate the schema and return a new object
 */
H
Hongze Cheng 已提交
1144
STSchema *tdDupSchema(const STSchema *pSchema) {
S
Shengliang Guan 已提交
1145
  int       tlen = sizeof(STSchema) + sizeof(STColumn) * schemaNCols(pSchema);
wafwerar's avatar
wafwerar 已提交
1146
  STSchema *tSchema = (STSchema *)taosMemoryMalloc(tlen);
H
hzcheng 已提交
1147 1148
  if (tSchema == NULL) return NULL;

H
Hongze Cheng 已提交
1149
  memcpy((void *)tSchema, (void *)pSchema, tlen);
H
hzcheng 已提交
1150 1151 1152 1153

  return tSchema;
}

H
TD-27  
hzcheng 已提交
1154 1155 1156
/**
 * Encode a schema to dst, and return the next pointer
 */
H
TD-353  
Hongze Cheng 已提交
1157 1158 1159 1160
int tdEncodeSchema(void **buf, STSchema *pSchema) {
  int tlen = 0;
  tlen += taosEncodeFixedI32(buf, schemaVersion(pSchema));
  tlen += taosEncodeFixedI32(buf, schemaNCols(pSchema));
H
TD-166  
hzcheng 已提交
1161

H
TD-27  
hzcheng 已提交
1162 1163
  for (int i = 0; i < schemaNCols(pSchema); i++) {
    STColumn *pCol = schemaColAt(pSchema, i);
H
TD-353  
Hongze Cheng 已提交
1164
    tlen += taosEncodeFixedI8(buf, colType(pCol));
C
Cary Xu 已提交
1165
    tlen += taosEncodeFixedI8(buf, colFlags(pCol));
H
TD-353  
Hongze Cheng 已提交
1166
    tlen += taosEncodeFixedI16(buf, colColId(pCol));
1167
    tlen += taosEncodeFixedI16(buf, colBytes(pCol));
H
TD-27  
hzcheng 已提交
1168 1169
  }

H
TD-353  
Hongze Cheng 已提交
1170
  return tlen;
H
TD-27  
hzcheng 已提交
1171 1172 1173 1174 1175
}

/**
 * Decode a schema from a binary.
 */
H
TD-353  
Hongze Cheng 已提交
1176
void *tdDecodeSchema(void *buf, STSchema **pRSchema) {
S
Shengliang Guan 已提交
1177 1178
  int             version = 0;
  int             numOfCols = 0;
H
TD-353  
Hongze Cheng 已提交
1179
  STSchemaBuilder schemaBuilder;
H
TD-27  
hzcheng 已提交
1180

H
TD-353  
Hongze Cheng 已提交
1181 1182
  buf = taosDecodeFixedI32(buf, &version);
  buf = taosDecodeFixedI32(buf, &numOfCols);
H
TD-27  
hzcheng 已提交
1183

H
Hongze Cheng 已提交
1184 1185
  if (tdInitTSchemaBuilder(&schemaBuilder, version) < 0) return NULL;

H
TD-353  
Hongze Cheng 已提交
1186
  for (int i = 0; i < numOfCols; i++) {
1187
    col_type_t  type = 0;
C
Cary Xu 已提交
1188
    int8_t      flags = 0;
1189 1190
    col_id_t    colId = 0;
    col_bytes_t bytes = 0;
H
TD-353  
Hongze Cheng 已提交
1191
    buf = taosDecodeFixedI8(buf, &type);
C
Cary Xu 已提交
1192
    buf = taosDecodeFixedI8(buf, &flags);
H
TD-353  
Hongze Cheng 已提交
1193
    buf = taosDecodeFixedI16(buf, &colId);
1194
    buf = taosDecodeFixedI32(buf, &bytes);
C
Cary Xu 已提交
1195
    if (tdAddColToSchema(&schemaBuilder, type, flags, colId, bytes) < 0) {
H
Hongze Cheng 已提交
1196 1197 1198
      tdDestroyTSchemaBuilder(&schemaBuilder);
      return NULL;
    }
H
TD-27  
hzcheng 已提交
1199 1200
  }

H
TD-353  
Hongze Cheng 已提交
1201
  *pRSchema = tdGetSchemaFromBuilder(&schemaBuilder);
H
Hongze Cheng 已提交
1202
  tdDestroyTSchemaBuilder(&schemaBuilder);
H
TD-353  
Hongze Cheng 已提交
1203
  return buf;
H
Hongze Cheng 已提交
1204 1205
}

C
Cary Xu 已提交
1206
int tdInitTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version) {
H
Hongze Cheng 已提交
1207 1208 1209
  if (pBuilder == NULL) return -1;

  pBuilder->tCols = 256;
wafwerar's avatar
wafwerar 已提交
1210
  pBuilder->columns = (STColumn *)taosMemoryMalloc(sizeof(STColumn) * pBuilder->tCols);
H
Hongze Cheng 已提交
1211 1212 1213 1214 1215 1216 1217 1218
  if (pBuilder->columns == NULL) return -1;

  tdResetTSchemaBuilder(pBuilder, version);
  return 0;
}

void tdDestroyTSchemaBuilder(STSchemaBuilder *pBuilder) {
  if (pBuilder) {
wafwerar's avatar
wafwerar 已提交
1219
    taosMemoryFreeClear(pBuilder->columns);
H
Hongze Cheng 已提交
1220 1221 1222
  }
}

C
Cary Xu 已提交
1223
void tdResetTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version) {
H
Hongze Cheng 已提交
1224 1225 1226
  pBuilder->nCols = 0;
  pBuilder->tlen = 0;
  pBuilder->flen = 0;
T
Tao Liu 已提交
1227
  pBuilder->vlen = 0;
H
Hongze Cheng 已提交
1228 1229 1230
  pBuilder->version = version;
}

C
Cary Xu 已提交
1231
int32_t tdAddColToSchema(STSchemaBuilder *pBuilder, int8_t type, int8_t flags, col_id_t colId, col_bytes_t bytes) {
1232
  if (!isValidDataType(type)) return -1;
H
Hongze Cheng 已提交
1233 1234 1235

  if (pBuilder->nCols >= pBuilder->tCols) {
    pBuilder->tCols *= 2;
wafwerar's avatar
wafwerar 已提交
1236
    STColumn *columns = (STColumn *)taosMemoryRealloc(pBuilder->columns, sizeof(STColumn) * pBuilder->tCols);
T
tickduan 已提交
1237 1238
    if (columns == NULL) return -1;
    pBuilder->columns = columns;
H
Hongze Cheng 已提交
1239 1240 1241 1242 1243
  }

  STColumn *pCol = &(pBuilder->columns[pBuilder->nCols]);
  colSetType(pCol, type);
  colSetColId(pCol, colId);
C
Cary Xu 已提交
1244
  colSetFlags(pCol, flags);
H
Hongze Cheng 已提交
1245 1246 1247
  if (pBuilder->nCols == 0) {
    colSetOffset(pCol, 0);
  } else {
S
Shengliang Guan 已提交
1248
    STColumn *pTCol = &(pBuilder->columns[pBuilder->nCols - 1]);
H
Hongze Cheng 已提交
1249 1250 1251 1252 1253
    colSetOffset(pCol, pTCol->offset + TYPE_BYTES[pTCol->type]);
  }

  if (IS_VAR_DATA_TYPE(type)) {
    colSetBytes(pCol, bytes);
T
Tao Liu 已提交
1254 1255
    pBuilder->tlen += (TYPE_BYTES[type] + bytes);
    pBuilder->vlen += bytes - sizeof(VarDataLenT);
H
Hongze Cheng 已提交
1256 1257 1258
  } else {
    colSetBytes(pCol, TYPE_BYTES[type]);
    pBuilder->tlen += TYPE_BYTES[type];
T
Tao Liu 已提交
1259
    pBuilder->vlen += TYPE_BYTES[type];
H
Hongze Cheng 已提交
1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274
  }

  pBuilder->nCols++;
  pBuilder->flen += TYPE_BYTES[type];

  ASSERT(pCol->offset < pBuilder->flen);

  return 0;
}

STSchema *tdGetSchemaFromBuilder(STSchemaBuilder *pBuilder) {
  if (pBuilder->nCols <= 0) return NULL;

  int tlen = sizeof(STSchema) + sizeof(STColumn) * pBuilder->nCols;

wafwerar's avatar
wafwerar 已提交
1275
  STSchema *pSchema = (STSchema *)taosMemoryMalloc(tlen);
H
Hongze Cheng 已提交
1276 1277 1278 1279 1280 1281
  if (pSchema == NULL) return NULL;

  schemaVersion(pSchema) = pBuilder->version;
  schemaNCols(pSchema) = pBuilder->nCols;
  schemaTLen(pSchema) = pBuilder->tlen;
  schemaFLen(pSchema) = pBuilder->flen;
T
Tao Liu 已提交
1282
  schemaVLen(pSchema) = pBuilder->vlen;
H
Hongze Cheng 已提交
1283

C
Cary Xu 已提交
1284
#ifdef TD_SUPPORT_BITMAP
C
Cary Xu 已提交
1285
  schemaTLen(pSchema) += (int)TD_BITMAP_BYTES(schemaNCols(pSchema));
C
Cary Xu 已提交
1286 1287
#endif

H
Hongze Cheng 已提交
1288 1289
  memcpy(schemaColAt(pSchema, 0), pBuilder->columns, sizeof(STColumn) * pBuilder->nCols);

H
TD-27  
hzcheng 已提交
1290 1291 1292
  return pSchema;
}

1293
void dataColInit(SDataCol *pDataCol, STColumn *pCol, int maxPoints) {
H
TD-166  
hzcheng 已提交
1294 1295 1296
  pDataCol->type = colType(pCol);
  pDataCol->colId = colColId(pCol);
  pDataCol->bytes = colBytes(pCol);
S
Shengliang Guan 已提交
1297
  pDataCol->offset = colOffset(pCol) + 0;  // TD_DATA_ROW_HEAD_SIZE;
H
TD-166  
hzcheng 已提交
1298 1299 1300

  pDataCol->len = 0;
}
C
Cary Xu 已提交
1301

L
Liu Jicong 已提交
1302 1303 1304 1305 1306 1307
static FORCE_INLINE const void *tdGetColDataOfRowUnsafe(SDataCol *pCol, int row) {
  if (IS_VAR_DATA_TYPE(pCol->type)) {
    return POINTER_SHIFT(pCol->pData, pCol->dataOff[row]);
  } else {
    return POINTER_SHIFT(pCol->pData, TYPE_BYTES[pCol->type] * row);
  }
H
TD-166  
hzcheng 已提交
1308 1309
}

H
TD-166  
hzcheng 已提交
1310
bool isNEleNull(SDataCol *pCol, int nEle) {
S
Shengliang Guan 已提交
1311
  if (isAllRowsNull(pCol)) return true;
1312
  for (int i = 0; i < nEle; ++i) {
L
Liu Jicong 已提交
1313
    if (!isNull(tdGetColDataOfRowUnsafe(pCol, i), pCol->type)) return false;
H
TD-166  
hzcheng 已提交
1314
  }
H
Hongze Cheng 已提交
1315
  return true;
H
TD-166  
hzcheng 已提交
1316 1317
}

C
Cary Xu 已提交
1318
void *dataColSetOffset(SDataCol *pCol, int nEle) {
H
TD-166  
hzcheng 已提交
1319 1320
  ASSERT(((pCol->type == TSDB_DATA_TYPE_BINARY) || (pCol->type == TSDB_DATA_TYPE_NCHAR)));

H
Hongze Cheng 已提交
1321
  void *tptr = pCol->pData;
H
TD-166  
hzcheng 已提交
1322
  // char *tptr = (char *)(pCol->pData);
H
TD-166  
hzcheng 已提交
1323

H
TD-166  
hzcheng 已提交
1324
  VarDataOffsetT offset = 0;
1325
  for (int i = 0; i < nEle; ++i) {
H
TD-166  
hzcheng 已提交
1326
    pCol->dataOff[i] = offset;
H
TD-166  
hzcheng 已提交
1327
    offset += varDataTLen(tptr);
H
hzcheng 已提交
1328
    tptr = POINTER_SHIFT(tptr, varDataTLen(tptr));
H
TD-166  
hzcheng 已提交
1329
  }
C
Cary Xu 已提交
1330
  return POINTER_SHIFT(tptr, varDataTLen(tptr));
H
TD-166  
hzcheng 已提交
1331 1332
}

L
Liu Jicong 已提交
1333
SDataCols *tdNewDataCols(int maxCols, int maxRows) {
wafwerar's avatar
wafwerar 已提交
1334
  SDataCols *pCols = (SDataCols *)taosMemoryCalloc(1, sizeof(SDataCols));
H
Haojun Liao 已提交
1335
  if (pCols == NULL) {
S
Shengliang Guan 已提交
1336
    uDebug("malloc failure, size:%" PRId64 " failed, reason:%s", (int64_t)sizeof(SDataCols), strerror(errno));
H
Haojun Liao 已提交
1337 1338
    return NULL;
  }
H
TD-34  
hzcheng 已提交
1339

H
Hongze Cheng 已提交
1340
  pCols->maxPoints = maxRows;
L
Liu Jicong 已提交
1341 1342 1343
  pCols->maxCols = maxCols;
  pCols->numOfRows = 0;
  pCols->numOfCols = 0;
1344
  pCols->bitmapMode = TSDB_BITMODE_DEFAULT;
H
Hongze Cheng 已提交
1345 1346

  if (maxCols > 0) {
wafwerar's avatar
wafwerar 已提交
1347
    pCols->cols = (SDataCol *)taosMemoryCalloc(maxCols, sizeof(SDataCol));
H
Hongze Cheng 已提交
1348 1349 1350 1351 1352 1353
    if (pCols->cols == NULL) {
      uDebug("malloc failure, size:%" PRId64 " failed, reason:%s", (int64_t)sizeof(SDataCol) * maxCols,
             strerror(errno));
      tdFreeDataCols(pCols);
      return NULL;
    }
1354
#if 0  // no need as calloc used
L
Liu Jicong 已提交
1355
    int i;
S
Shengliang Guan 已提交
1356
    for (i = 0; i < maxCols; i++) {
L
Liu Jicong 已提交
1357
      pCols->cols[i].spaceSize = 0;
L
Liu Jicong 已提交
1358
      pCols->cols[i].len = 0;
L
Liu Jicong 已提交
1359 1360 1361
      pCols->cols[i].pData = NULL;
      pCols->cols[i].dataOff = NULL;
    }
1362
#endif
H
Hongze Cheng 已提交
1363 1364
  }

H
TD-34  
hzcheng 已提交
1365 1366 1367
  return pCols;
}

H
Hongze Cheng 已提交
1368
int tdInitDataCols(SDataCols *pCols, STSchema *pSchema) {
1369 1370
  int i;
  int oldMaxCols = pCols->maxCols;
L
Liu Jicong 已提交
1371
  if (schemaNCols(pSchema) > oldMaxCols) {
H
Hongze Cheng 已提交
1372
    pCols->maxCols = schemaNCols(pSchema);
wafwerar's avatar
wafwerar 已提交
1373
    void *ptr = (SDataCol *)taosMemoryRealloc(pCols->cols, sizeof(SDataCol) * pCols->maxCols);
L
Liu Jicong 已提交
1374 1375
    if (ptr == NULL) return -1;
    pCols->cols = ptr;
1376
    for (i = oldMaxCols; i < pCols->maxCols; ++i) {
1377 1378
      pCols->cols[i].pData = NULL;
      pCols->cols[i].dataOff = NULL;
1379
      pCols->cols[i].pBitmap = NULL;
L
Liu Jicong 已提交
1380
      pCols->cols[i].spaceSize = 0;
1381
    }
L
Liu Jicong 已提交
1382
  }
1383 1384 1385
#if 0
  tdResetDataCols(pCols); // redundant loop to reset len/blen to 0, already reset in following dataColInit(...)
#endif
H
Hongze Cheng 已提交
1386

1387
  pCols->numOfRows = 0;
1388
  pCols->bitmapMode = TSDB_BITMODE_DEFAULT;
H
TD-34  
hzcheng 已提交
1389 1390
  pCols->numOfCols = schemaNCols(pSchema);

1391
  for (i = 0; i < schemaNCols(pSchema); ++i) {
1392
    dataColInit(pCols->cols + i, schemaColAt(pSchema, i), pCols->maxPoints);
H
TD-34  
hzcheng 已提交
1393
  }
S
Shengliang Guan 已提交
1394

H
Hongze Cheng 已提交
1395
  return 0;
H
TD-34  
hzcheng 已提交
1396 1397
}

H
Hongze Cheng 已提交
1398
SDataCols *tdFreeDataCols(SDataCols *pCols) {
1399
  int i;
H
TD-34  
hzcheng 已提交
1400
  if (pCols) {
S
Shengliang Guan 已提交
1401
    if (pCols->cols) {
1402
      int maxCols = pCols->maxCols;
1403
      for (i = 0; i < maxCols; ++i) {
1404
        SDataCol *pCol = &pCols->cols[i];
wafwerar's avatar
wafwerar 已提交
1405
        taosMemoryFreeClear(pCol->pData);
1406
      }
wafwerar's avatar
wafwerar 已提交
1407
      taosMemoryFree(pCols->cols);
1408 1409
      pCols->cols = NULL;
    }
wafwerar's avatar
wafwerar 已提交
1410
    taosMemoryFree(pCols);
H
TD-34  
hzcheng 已提交
1411
  }
H
Hongze Cheng 已提交
1412
  return NULL;
H
TD-34  
hzcheng 已提交
1413 1414 1415
}

void tdResetDataCols(SDataCols *pCols) {
B
Bomin Zhang 已提交
1416 1417
  if (pCols != NULL) {
    pCols->numOfRows = 0;
C
Cary Xu 已提交
1418
    pCols->bitmapMode = 0;
1419
    for (int i = 0; i < pCols->maxCols; ++i) {
B
Bomin Zhang 已提交
1420 1421
      dataColReset(pCols->cols + i);
    }
H
TD-34  
hzcheng 已提交
1422 1423
  }
}
H
Hongze Cheng 已提交
1424

H
Hongze Cheng 已提交
1425
#endif