index_cache.h 1.6 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:
dengyihao's avatar
dengyihao 已提交
25
 * content: |<--totalLen-->|<-- fieldid-->|<--field type -->|<-- value len--->|<-- value -->|<--  uid  -->|<--version--->|<-- itermType -->|
dengyihao's avatar
dengyihao 已提交
26
 * len    : |<--int32_t -->|<-- int16_t-->|<--  int8_t --->|<--- int32_t --->|<--valuelen->|<--uint64_t->|<-- int32_t-->|<--  int8_t  --->| 
dengyihao's avatar
dengyihao 已提交
27 28 29 30 31 32 33 34
 */

#ifdef __cplusplus
extern "C" {
#endif

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


// 
IndexCache *indexCacheCreate();

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

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

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

#ifdef __cplusplus
}
#endif



#endif