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 19
/*
 * 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"
#include "tlockfree.h"
dengyihao's avatar
dengyihao 已提交
20
#include "tskiplist.h"
dengyihao's avatar
dengyihao 已提交
21 22 23
// ----------------- row structure in skiplist ---------------------

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

#ifdef __cplusplus
extern "C" {
#endif

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


// 
IndexCache *indexCacheCreate();

void indexCacheDestroy(IndexCache *cache);

dengyihao's avatar
dengyihao 已提交
43 44
int indexCachePut(IndexCache *cache, int16_t fieldId, int16_t fieldType, const char *fieldValue,  int32_t fvLen, 
              uint32_t version, uint64_t uid, int8_t operType);
dengyihao's avatar
dengyihao 已提交
45 46 47 48 49 50 51 52 53 54 55

int indexCacheGet(IndexCache *cache, uint64_t *rst);
int indexCacheSearch(IndexCache *cache, SIndexMultiTermQuery *query, SArray *result);

#ifdef __cplusplus
}
#endif



#endif