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

#ifndef TDENGINE_TFILL_H
#define TDENGINE_TFILL_H

#ifdef __cplusplus
extern "C" {
#endif

#include "os.h"
#include "taosdef.h"
25
#include "tcommon.h"
26 27 28

struct SSDataBlock;

29
typedef struct SFillColInfo {
30
  SExprInfo *pExpr;
H
Haojun Liao 已提交
31
  bool       notFillCol;      // denote if this column needs fill operation
32
  SVariant   fillVal;
33 34
} SFillColInfo;

35
typedef struct SFillLinearInfo {
36 37 38 39 40
  SPoint  start;
  SPoint  end;
  bool    hasNull;
  int16_t type;
  int32_t bytes;
41 42
} SFillLinearInfo;

43 44 45 46
typedef struct {
  SSchema col;
  char*   tagVal;
} SFillTagColInfo;
H
Haojun Liao 已提交
47 48 49 50 51

typedef struct {
  int64_t key;
  SArray* pRowVal;
} SRowVal;
H
Haojun Liao 已提交
52

53 54 55 56
typedef struct SFillInfo {
  TSKEY     start;                // start timestamp
  TSKEY     end;                  // endKey for fill
  TSKEY     currentKey;           // current active timestamp, the value may be changed during the fill procedure.
57
  int32_t   tsSlotId;             // primary time stamp slot id
58
  int32_t   srcTsSlotId;          // timestamp column id in the source data block.
59 60 61 62 63 64 65 66
  int32_t   order;                // order [TSDB_ORDER_ASC|TSDB_ORDER_DESC]
  int32_t   type;                 // fill type
  int32_t   numOfRows;            // number of rows in the input data block
  int32_t   index;                // active row index
  int32_t   numOfTotal;           // number of filled rows in one round
  int32_t   numOfCurrent;         // number of filled rows in current results
  int32_t   numOfCols;            // number of columns, including the tags columns
  SInterval interval;
H
Haojun Liao 已提交
67 68
  SRowVal   prev;
  SRowVal   next;
69
  SSDataBlock *pSrcBlock;
70 71 72 73
  int32_t   alloc;                // data buffer size in rows

  SFillColInfo* pFillCol;         // column info for fill operations
  SFillTagColInfo* pTags;         // tags value for filling gap
H
Haojun Liao 已提交
74
  const char* id;
75 76
} SFillInfo;

77
int64_t getNumOfResultsAfterFillGap(SFillInfo* pFillInfo, int64_t ekey, int32_t maxNumOfRows);
78 79


80 81 82
void taosFillSetStartInfo(struct SFillInfo* pFillInfo, int32_t numOfRows, TSKEY endKey);
void taosResetFillInfo(struct SFillInfo* pFillInfo, TSKEY startTimestamp);
void taosFillSetInputDataBlock(struct SFillInfo* pFillInfo, const struct SSDataBlock* pInput);
H
Haojun Liao 已提交
83
struct SFillColInfo* createFillColInfo(SExprInfo* pExpr, int32_t numOfFillExpr, SExprInfo* pNotFillExpr, int32_t numOfNotFillCols, const struct SNodeListNode* val);
84
bool taosFillHasMoreResults(struct SFillInfo* pFillInfo);
85

H
Haojun Liao 已提交
86
SFillInfo* taosCreateFillInfo(TSKEY skey, int32_t numOfFillCols, int32_t numOfNotFillCols, int32_t capacity,
87
                              SInterval* pInterval, int32_t fillType, struct SFillColInfo* pCol, int32_t slotId,
88
                              int32_t order, const char* id);
89 90

void* taosDestroyFillInfo(struct SFillInfo *pFillInfo);
91
int64_t taosFillResultDataBlock(struct SFillInfo* pFillInfo, SSDataBlock* p, int32_t capacity);
92
int64_t getFillInfoStart(struct SFillInfo *pFillInfo);
93 94 95 96 97 98 99


#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TFILL_H