tast.h 3.3 KB
Newer Older
H
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
/*
 * 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_TAST_H
#define TDENGINE_TAST_H

#ifdef __cplusplus
extern "C" {
#endif

#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>

S
slguan 已提交
27
#include "taosmsg.h"
H
hjxilinx 已提交
28
#include "ttypes.h"
H
hzcheng 已提交
29 30

struct tSQLBinaryExpr;
31
struct SCMSchema;
H
hzcheng 已提交
32 33 34 35 36 37 38 39 40
struct tSkipList;
struct tSkipListNode;

enum {
  TSQL_NODE_EXPR = 0x1,
  TSQL_NODE_COL = 0x2,
  TSQL_NODE_VALUE = 0x4,
};

S
slguan 已提交
41 42 43 44 45 46 47 48 49 50 51
typedef bool (*__result_filter_fn_t)(const void *, void *);
typedef void (*__do_filter_suppl_fn_t)(void *, void *);

/**
 * this structure is used to filter data in tags, so the offset of filtered tag column in tagdata string is required
 *
 */
typedef struct tQueryInfo {
  int32_t       offset;   // offset value in tags
  int32_t       colIdx;   // index of column in schema
  uint8_t       optr;     // expression operator
52
  SCMSchema       sch;      // schema of tags
S
slguan 已提交
53 54 55 56 57 58 59 60 61 62
  tVariant      q;        // query condition value on the specific schema, filter expression
  __compar_fn_t compare;  // filter function
} tQueryInfo;

typedef struct SBinaryFilterSupp {
  __result_filter_fn_t   fp;
  __do_filter_suppl_fn_t setupInfoFn;
  void *                 pExtInfo;
} SBinaryFilterSupp;

H
hzcheng 已提交
63 64 65 66 67
typedef struct tSQLSyntaxNode {
  uint8_t nodeType;
  int16_t colId;  // for schema, the id of column
  union {
    struct tSQLBinaryExpr *pExpr;
68
    struct SCMSchema *       pSchema;
H
hzcheng 已提交
69 70 71 72 73
    tVariant *             pVal;
  };
} tSQLSyntaxNode;

typedef struct tSQLBinaryExpr {
S
slguan 已提交
74 75 76 77 78 79 80 81 82 83
  uint8_t         nSQLBinaryOptr;      // filter operator
  uint8_t         filterOnPrimaryKey;  // 0: do not contain primary filter, 1: contain

  /*
   * provide the information to support filter operation on this expression
   * only available for leaf node
   */
  void *          info;
  tSQLSyntaxNode *pLeft;               // left child pointer
  tSQLSyntaxNode *pRight;              // right child pointer
H
hzcheng 已提交
84 85 86 87 88 89 90
} tSQLBinaryExpr;

typedef struct tQueryResultset {
  void ** pRes;
  int64_t num;
} tQueryResultset;

91
void tSQLBinaryExprFromString(tSQLBinaryExpr **pExpr, SCMSchema *pSchema, int32_t numOfCols, char *src, int32_t len);
H
hzcheng 已提交
92 93 94

void tSQLBinaryExprToString(tSQLBinaryExpr *pExpr, char *dst, int32_t *len);

S
slguan 已提交
95
void tSQLBinaryExprDestroy(tSQLBinaryExpr **pExprs, void (*fp)(void*));
H
hzcheng 已提交
96

S
slguan 已提交
97 98
void tSQLBinaryExprTraverse(tSQLBinaryExpr *pExprs, struct tSkipList *pSkipList, tQueryResultset *result,
                            SBinaryFilterSupp *param);
H
hzcheng 已提交
99 100 101 102 103

void tSQLBinaryExprCalcTraverse(tSQLBinaryExpr *pExprs, int32_t numOfRows, char *pOutput, void *param, int32_t order,
                                char *(*cb)(void *, char *, int32_t));

void tSQLBinaryExprTrv(tSQLBinaryExpr *pExprs, int32_t *val, int16_t *ids);
S
slguan 已提交
104
void tQueryResultClean(tQueryResultset *pRes);
H
hzcheng 已提交
105 106 107 108 109 110

#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TAST_H