153 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
| /*
 | |
|  * 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 _TD_INDEX_INT_H_
 | |
| #define _TD_INDEX_INT_H_
 | |
| 
 | |
| #include "index.h"
 | |
| #include "index_fst.h"
 | |
| #include "taos.h"
 | |
| #include "tchecksum.h"
 | |
| #include "thash.h"
 | |
| #include "tlog.h"
 | |
| 
 | |
| #ifdef USE_LUCENE
 | |
| #include <lucene++/Lucene_c.h>
 | |
| #endif
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| typedef enum { kTypeValue, kTypeDeletion } STermValueType;
 | |
| 
 | |
| typedef struct SIndexStat {
 | |
|   int32_t totalAdded;    //
 | |
|   int32_t totalDeled;    //
 | |
|   int32_t totalUpdated;  //
 | |
|   int32_t totalTerms;    //
 | |
|   int32_t distinctCol;   // distinct column
 | |
| } SIndexStat;
 | |
| 
 | |
| struct SIndex {
 | |
| #ifdef USE_LUCENE
 | |
|   index_t* index;
 | |
| #endif
 | |
|   void*     cache;
 | |
|   void*     tindex;
 | |
|   SHashObj* colObj;  // < field name, field id>
 | |
| 
 | |
|   int64_t suid;      // current super table id, -1 is normal table
 | |
|   int32_t cVersion;  // current version allocated to cache
 | |
| 
 | |
|   char* path;
 | |
| 
 | |
|   SIndexStat      stat;
 | |
|   pthread_mutex_t mtx;
 | |
| };
 | |
| 
 | |
| struct SIndexOpts {
 | |
| #ifdef USE_LUCENE
 | |
|   void* opts;
 | |
| #endif
 | |
| 
 | |
| #ifdef USE_INVERTED_INDEX
 | |
|   int32_t cacheSize;  // MB
 | |
|   // add cache module later
 | |
| #endif
 | |
| };
 | |
| 
 | |
| struct SIndexMultiTermQuery {
 | |
|   EIndexOperatorType opera;
 | |
|   SArray*            query;
 | |
| };
 | |
| 
 | |
| // field and key;
 | |
| typedef struct SIndexTerm {
 | |
|   int64_t            suid;
 | |
|   SIndexOperOnColumn operType;  // oper type, add/del/update
 | |
|   uint8_t            colType;   // term data type, str/interger/json
 | |
|   char*              colName;
 | |
|   int32_t            nColName;
 | |
|   char*              colVal;
 | |
|   int32_t            nColVal;
 | |
| } SIndexTerm;
 | |
| 
 | |
| typedef struct SIndexTermQuery {
 | |
|   SIndexTerm*     term;
 | |
|   EIndexQueryType qType;
 | |
| } SIndexTermQuery;
 | |
| 
 | |
| typedef struct Iterate Iterate;
 | |
| 
 | |
| typedef struct IterateValue {
 | |
|   int8_t  type;
 | |
|   char*   colVal;
 | |
|   SArray* val;
 | |
| } IterateValue;
 | |
| 
 | |
| typedef struct Iterate {
 | |
|   void*        iter;
 | |
|   IterateValue val;
 | |
|   bool (*next)(Iterate* iter);
 | |
|   IterateValue* (*getValue)(Iterate* iter);
 | |
| } Iterate;
 | |
| 
 | |
| void iterateValueDestroy(IterateValue* iv, bool destroy);
 | |
| 
 | |
| extern void* indexQhandle;
 | |
| 
 | |
| typedef struct TFileCacheKey {
 | |
|   uint64_t suid;
 | |
|   uint8_t  colType;
 | |
|   char*    colName;
 | |
|   int32_t  nColName;
 | |
| } ICacheKey;
 | |
| 
 | |
| int indexFlushCacheToTFile(SIndex* sIdx, void*);
 | |
| 
 | |
| int32_t indexSerialCacheKey(ICacheKey* key, char* buf);
 | |
| 
 | |
| #define indexFatal(...)                                                               \
 | |
|   do {                                                                                \
 | |
|     if (sDebugFlag & DEBUG_FATAL) { taosPrintLog("index FATAL ", 255, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| #define indexError(...)                                                               \
 | |
|   do {                                                                                \
 | |
|     if (sDebugFlag & DEBUG_ERROR) { taosPrintLog("index ERROR ", 255, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| #define indexWarn(...)                                                              \
 | |
|   do {                                                                              \
 | |
|     if (sDebugFlag & DEBUG_WARN) { taosPrintLog("index WARN ", 255, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| #define indexInfo(...)                                                         \
 | |
|   do {                                                                         \
 | |
|     if (sDebugFlag & DEBUG_INFO) { taosPrintLog("index ", 255, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| #define indexDebug(...)                                                                \
 | |
|   do {                                                                                 \
 | |
|     if (sDebugFlag & DEBUG_DEBUG) { taosPrintLog("index ", sDebugFlag, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| #define indexTrace(...)                                                                \
 | |
|   do {                                                                                 \
 | |
|     if (sDebugFlag & DEBUG_TRACE) { taosPrintLog("index ", sDebugFlag, __VA_ARGS__); } \
 | |
|   } while (0)
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /*_TD_INDEX_INT_H_*/
 |