index_cache.h 1.7 KB
Newer Older
dengyihao's avatar
dengyihao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * 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 __INDEX_CACHE_H__
#define __INDEX_CACHE_H__

#include "index.h"
dengyihao's avatar
dengyihao 已提交
19
#include "indexInt.h"
dengyihao's avatar
dengyihao 已提交
20
#include "tlockfree.h"
dengyihao's avatar
dengyihao 已提交
21
#include "tskiplist.h"
dengyihao's avatar
dengyihao 已提交
22
// ----------------- key structure in skiplist ---------------------
dengyihao's avatar
dengyihao 已提交
23 24

/* A data row, the format is like below:
25 26 27 28
 * content: |<--totalLen-->|<-- fieldid-->|<--field type-->|<-- value len--->|
 *          |<-- value -->|<--uid -->|<--version--->|<-- itermType -->|
 *  len :   |<--int32_t -->|<-- int16_t-->|<--  int8_t --->|<--- int32_t --->|
 *          <--valuelen->|<--uint64_t->| *  <-- int32_t-->|<-- int8_t --->|
dengyihao's avatar
dengyihao 已提交
29 30 31 32 33 34 35
 */

#ifdef __cplusplus
extern "C" {
#endif

typedef struct IndexCache {
36
  T_REF_DECLARE()
dengyihao's avatar
dengyihao 已提交
37
  SSkipList* skiplist;
dengyihao's avatar
dengyihao 已提交
38 39
} IndexCache;

40
//
dengyihao's avatar
dengyihao 已提交
41
IndexCache* indexCacheCreate();
dengyihao's avatar
dengyihao 已提交
42

dengyihao's avatar
dengyihao 已提交
43
void indexCacheDestroy(void* cache);
dengyihao's avatar
dengyihao 已提交
44

dengyihao's avatar
dengyihao 已提交
45
int indexCachePut(void* cache, SIndexTerm* term, int16_t colId, int32_t version, uint64_t uid);
dengyihao's avatar
dengyihao 已提交
46

47
// int indexCacheGet(void *cache, uint64_t *rst);
dengyihao's avatar
dengyihao 已提交
48
int indexCacheSearch(void* cache, SIndexTermQuery* query, int16_t colId, int32_t version, SArray* result, STermValueType* s);
dengyihao's avatar
dengyihao 已提交
49 50 51 52 53 54

#ifdef __cplusplus
}
#endif

#endif