sclInt.h 3.0 KB
Newer Older
D
dapan1121 已提交
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/>.
 */
D
dapan1121 已提交
15 16
#ifndef TDENGINE_SCALARINT_H
#define TDENGINE_SCALARINT_H
D
dapan1121 已提交
17 18 19 20

#ifdef __cplusplus
extern "C" {
#endif
S
common  
Shengliang Guan 已提交
21
#include "tcommon.h"
D
dapan1121 已提交
22 23
#include "thash.h"
#include "query.h"
D
dapan1121 已提交
24

D
dapan1121 已提交
25 26 27 28 29 30
typedef struct SOperatorValueType {
  int32_t opResType;
  int32_t selfType;
  int32_t peerType;
} SOperatorValueType;

D
dapan1121 已提交
31 32
typedef struct SScalarCtx {
  int32_t      code;
D
dapan1121 已提交
33
  bool         dual;
D
dapan 已提交
34
  SArray      *pBlockList;  /* element is SSDataBlock* */
D
dapan1121 已提交
35
  SHashObj    *pRes;  /* element is SScalarParam */
36
  void        *param;      // additional parameter (meta actually) for acquire value such as tbname/tags values
D
dapan1121 已提交
37
  SOperatorValueType type;
D
dapan1121 已提交
38
} SScalarCtx;
D
dapan1121 已提交
39

D
dapan1121 已提交
40 41

#define SCL_DATA_TYPE_DUMMY_HASH 9000
D
dapan1121 已提交
42
#define SCL_DEFAULT_OP_NUM 10
D
dapan1121 已提交
43

D
dapan 已提交
44
#define SCL_IS_CONST_NODE(_node) ((NULL == (_node)) || (QUERY_NODE_VALUE == (_node)->type) || (QUERY_NODE_NODE_LIST == (_node)->type))
D
dapan1121 已提交
45
#define SCL_IS_CONST_CALC(_ctx) (NULL == (_ctx)->pBlockList)
D
dapan1121 已提交
46 47
//#define SCL_IS_NULL_VALUE_NODE(_node) ((QUERY_NODE_VALUE == nodeType(_node)) && (TSDB_DATA_TYPE_NULL == ((SValueNode *)_node)->node.resType.type) && (((SValueNode *)_node)->placeholderNo <= 0))
#define SCL_IS_NULL_VALUE_NODE(_node) ((QUERY_NODE_VALUE == nodeType(_node)) && (TSDB_DATA_TYPE_NULL == ((SValueNode *)_node)->node.resType.type))
D
dapan1121 已提交
48

D
dapan1121 已提交
49 50 51 52 53 54 55 56 57 58 59
#define sclFatal(...)  qFatal(__VA_ARGS__)
#define sclError(...)  qError(__VA_ARGS__)
#define sclWarn(...)   qWarn(__VA_ARGS__)
#define sclInfo(...)   qInfo(__VA_ARGS__)
#define sclDebug(...)  qDebug(__VA_ARGS__)
#define sclTrace(...)  qTrace(__VA_ARGS__)

#define SCL_ERR_RET(c) do { int32_t _code = c; if (_code != TSDB_CODE_SUCCESS) { terrno = _code; return _code; } } while (0)
#define SCL_RET(c) do { int32_t _code = c; if (_code != TSDB_CODE_SUCCESS) { terrno = _code; } return _code; } while (0)
#define SCL_ERR_JRET(c) do { code = c; if (code != TSDB_CODE_SUCCESS) { terrno = code; goto _return; } } while (0)

D
dapan1121 已提交
60
int32_t doConvertDataType(SValueNode* pValueNode, SScalarParam* out, int32_t* overflow);
H
Haojun Liao 已提交
61
int32_t sclCreateColumnInfoData(SDataType* pType, int32_t numOfRows, SScalarParam* pParam);
D
dapan1121 已提交
62
int32_t sclConvertToTsValueNode(int8_t precision, SValueNode* valueNode);
D
dapan1121 已提交
63

D
dapan1121 已提交
64
#define GET_PARAM_TYPE(_c)      ((_c)->columnData ? (_c)->columnData->info.type : (_c)->hashValueType)
65 66
#define GET_PARAM_BYTES(_c)     ((_c)->columnData->info.bytes)
#define GET_PARAM_PRECISON(_c)  ((_c)->columnData->info.precision)
D
dapan1121 已提交
67

D
dapan 已提交
68
void sclFreeParam(SScalarParam *param);
D
dapan1121 已提交
69 70 71 72 73

#ifdef __cplusplus
}
#endif

D
dapan 已提交
74
#endif  // TDENGINE_SCALARINT_H