vnodeQuery.c 2.1 KB
Newer Older
D
dapan1121 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/*
 * 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/>.
 */

#include "vnodeQuery.h"
H
more  
Hongze Cheng 已提交
17
#include "vnodeDef.h"
D
dapan1121 已提交
18

H
more  
Hongze Cheng 已提交
19
int vnodeQueryOpen(SVnode *pVnode) { return qWorkerInit(NULL, &pVnode->pQuery); }
D
dapan1121 已提交
20 21 22

int vnodeProcessQueryReq(SVnode *pVnode, SRpcMsg *pMsg, SRpcMsg **pRsp) {
  vInfo("query message is processed");
D
dapan1121 已提交
23
  return qWorkerProcessQueryMsg(pVnode, pVnode->pQuery, pMsg);
D
dapan1121 已提交
24 25 26 27
}

int vnodeProcessFetchReq(SVnode *pVnode, SRpcMsg *pMsg, SRpcMsg **pRsp) {
  vInfo("fetch message is processed");
D
dapan1121 已提交
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
  switch (pMsg->msgType) {
    case TDMT_VND_FETCH:
      return qWorkerProcessFetchMsg(pVnode, pVnode->pQuery, pMsg);
    case TDMT_VND_RES_READY:
      return qWorkerProcessReadyMsg(pVnode, pVnode->pQuery, pMsg);
    case TDMT_VND_TASKS_STATUS:
      return qWorkerProcessStatusMsg(pVnode, pVnode->pQuery, pMsg);
    case TDMT_VND_CANCEL_TASK:
      return qWorkerProcessCancelMsg(pVnode, pVnode->pQuery, pMsg);
    case TDMT_VND_DROP_TASK:
      return qWorkerProcessDropMsg(pVnode, pVnode->pQuery, pMsg);
    default:
      vError("unknown msg type:%d in fetch queue", pMsg->msgType);
      return TSDB_CODE_VND_APP_ERROR;
      break;
  }
D
dapan1121 已提交
44 45 46
  return 0;
}

H
more  
Hongze Cheng 已提交
47 48
static int vnodeGetTableMeta(SVnode *pVnode, SRpcMsg *pMsg, SRpcMsg **pRsp) {
  STableInfoMsg *pReq = (STableInfoMsg *)(pMsg->pCont);
H
more  
Hongze Cheng 已提交
49 50 51 52 53 54 55 56 57 58 59 60 61 62
  STableMetaMsg *pRspMsg;
  int            ret;

  if (metaGetTableInfo(pVnode->pMeta, pReq->tableFname, &pRspMsg) < 0) {
    return -1;
  }

  *pRsp = malloc(sizeof(SRpcMsg));
  if (TD_IS_NULL(*pRsp)) {
    terrno = TSDB_CODE_OUT_OF_MEMORY;
    free(pMsg);
    return -1;
  }

H
more  
Hongze Cheng 已提交
63
  // TODO
H
more  
Hongze Cheng 已提交
64 65
  (*pRsp)->pCont = pRspMsg;

H
more  
Hongze Cheng 已提交
66 67
  return 0;
}