| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #ifndef _FTSINT_H |
| | #define _FTSINT_H |
| |
|
| | |
| | |
| | |
| | #if !defined(NDEBUG) && !defined(SQLITE_DEBUG) |
| | # define NDEBUG 1 |
| | #endif |
| |
|
| | #include <assert.h> |
| | #include <stdlib.h> |
| | #include <stddef.h> |
| | #include <stdio.h> |
| | #include <string.h> |
| | #include <stdarg.h> |
| |
|
| | |
| | #ifdef SQLITE_OMIT_VIRTUALTABLE |
| | # undef SQLITE_ENABLE_FTS3 |
| | # undef SQLITE_ENABLE_FTS4 |
| | #endif |
| |
|
| | |
| | |
| | |
| | |
| | |
| | #if defined(SQLITE_ENABLE_FTS4) && !defined(SQLITE_ENABLE_FTS3) |
| | # define SQLITE_ENABLE_FTS3 |
| | #endif |
| |
|
| | #if !defined(SQLITE_CORE) || defined(SQLITE_ENABLE_FTS3) |
| |
|
| | |
| | #ifndef SQLITE_CORE |
| | # include "sqlite3ext.h" |
| | SQLITE_EXTENSION_INIT3 |
| | #endif |
| |
|
| | #include "sqlite3.h" |
| | #include "fts3_tokenizer.h" |
| | #include "fts3_hash.h" |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #ifndef SQLITE_FTS3_MAX_EXPR_DEPTH |
| | # define SQLITE_FTS3_MAX_EXPR_DEPTH 12 |
| | #endif |
| |
|
| |
|
| | |
| | |
| | |
| | |
| | |
| | #define FTS3_MERGE_COUNT 16 |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #define FTS3_MAX_PENDING_DATA (1*1024*1024) |
| |
|
| | |
| | |
| | |
| | |
| | |
| | #define SizeofArray(X) ((int)(sizeof(X)/sizeof(X[0]))) |
| |
|
| |
|
| | #ifndef MIN |
| | # define MIN(x,y) ((x)<(y)?(x):(y)) |
| | #endif |
| | #ifndef MAX |
| | # define MAX(x,y) ((x)>(y)?(x):(y)) |
| | #endif |
| |
|
| | |
| | |
| | |
| | |
| | #define FTS3_VARINT_MAX 10 |
| |
|
| | #define FTS3_BUFFER_PADDING 8 |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #define FTS3_SEGDIR_MAXLEVEL 1024 |
| | #define FTS3_SEGDIR_MAXLEVEL_STR "1024" |
| |
|
| | |
| | |
| | |
| | |
| | #ifndef testcase |
| | # define testcase(X) |
| | #endif |
| |
|
| | |
| | |
| | |
| | #define POS_COLUMN (1) |
| | #define POS_END (0) |
| |
|
| | |
| | |
| | |
| | |
| | |
| | #ifdef SQLITE_DEBUG |
| | extern int sqlite3_fts3_may_be_corrupt; |
| | # define assert_fts3_nc(x) assert(sqlite3_fts3_may_be_corrupt || (x)) |
| | #else |
| | # define assert_fts3_nc(x) assert(x) |
| | #endif |
| |
|
| | |
| | |
| | |
| | |
| | |
| | #ifndef SQLITE_AMALGAMATION |
| | |
| | |
| | |
| | |
| | #if defined(SQLITE_COVERAGE_TEST) || defined(SQLITE_MUTATION_TEST) |
| | # define SQLITE_OMIT_AUXILIARY_SAFETY_CHECKS 1 |
| | #endif |
| | #if defined(SQLITE_OMIT_AUXILIARY_SAFETY_CHECKS) |
| | # define ALWAYS(X) (1) |
| | # define NEVER(X) (0) |
| | #elif !defined(NDEBUG) |
| | # define ALWAYS(X) ((X)?1:(assert(0),0)) |
| | # define NEVER(X) ((X)?(assert(0),1):0) |
| | #else |
| | # define ALWAYS(X) (X) |
| | # define NEVER(X) (X) |
| | #endif |
| |
|
| | |
| | |
| | |
| | typedef unsigned char u8; |
| | typedef short int i16; |
| | typedef unsigned int u32; |
| | typedef sqlite3_uint64 u64; |
| | typedef sqlite3_int64 i64; |
| |
|
| | |
| | |
| | |
| | #define UNUSED_PARAMETER(x) (void)(x) |
| |
|
| | |
| | |
| | |
| | |
| | |
| | #if defined(SQLITE_DEBUG) || defined(SQLITE_COVERAGE_TEST) |
| | # define TESTONLY(X) X |
| | #else |
| | # define TESTONLY(X) |
| | #endif |
| |
|
| | #define LARGEST_INT64 (0xffffffff|(((i64)0x7fffffff)<<32)) |
| | #define SMALLEST_INT64 (((i64)-1) - LARGEST_INT64) |
| |
|
| | #define deliberate_fall_through |
| |
|
| | |
| | |
| | |
| | #ifndef offsetof |
| | # define offsetof(ST,M) ((size_t)((char*)&((ST*)0)->M - (char*)0)) |
| | #endif |
| | #if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) |
| | # define FLEXARRAY |
| | #else |
| | # define FLEXARRAY 1 |
| | #endif |
| |
|
| |
|
| | #endif |
| |
|
| | #ifdef SQLITE_DEBUG |
| | int sqlite3Fts3Corrupt(void); |
| | # define FTS_CORRUPT_VTAB sqlite3Fts3Corrupt() |
| | #else |
| | # define FTS_CORRUPT_VTAB SQLITE_CORRUPT_VTAB |
| | #endif |
| |
|
| | typedef struct Fts3Table Fts3Table; |
| | typedef struct Fts3Cursor Fts3Cursor; |
| | typedef struct Fts3Expr Fts3Expr; |
| | typedef struct Fts3Phrase Fts3Phrase; |
| | typedef struct Fts3PhraseToken Fts3PhraseToken; |
| |
|
| | typedef struct Fts3Doclist Fts3Doclist; |
| | typedef struct Fts3SegFilter Fts3SegFilter; |
| | typedef struct Fts3DeferredToken Fts3DeferredToken; |
| | typedef struct Fts3SegReader Fts3SegReader; |
| | typedef struct Fts3MultiSegReader Fts3MultiSegReader; |
| |
|
| | typedef struct MatchinfoBuffer MatchinfoBuffer; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | struct Fts3Table { |
| | sqlite3_vtab base; |
| | sqlite3 *db; |
| | const char *zDb; |
| | const char *zName; |
| | int nColumn; |
| | char **azColumn; |
| | u8 *abNotindexed; |
| | sqlite3_tokenizer *pTokenizer; |
| | char *zContentTbl; |
| | char *zLanguageid; |
| | int nAutoincrmerge; |
| | u32 nLeafAdd; |
| | int bLock; |
| |
|
| | |
| | |
| | |
| | sqlite3_stmt *aStmt[40]; |
| | sqlite3_stmt *pSeekStmt; |
| |
|
| | char *zReadExprlist; |
| | char *zWriteExprlist; |
| |
|
| | int nNodeSize; |
| | u8 bFts4; |
| | u8 bHasStat; |
| | u8 bHasDocsize; |
| | u8 bDescIdx; |
| | u8 bIgnoreSavepoint; |
| | int nPgsz; |
| | char *zSegmentsTbl; |
| | sqlite3_blob *pSegments; |
| | int iSavepoint; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | int nIndex; |
| | struct Fts3Index { |
| | int nPrefix; |
| | Fts3Hash hPending; |
| | } *aIndex; |
| | int nMaxPendingData; |
| | int nPendingData; |
| | sqlite_int64 iPrevDocid; |
| | int iPrevLangid; |
| | int bPrevDelete; |
| |
|
| | #if defined(SQLITE_DEBUG) || defined(SQLITE_COVERAGE_TEST) |
| | |
| | |
| | |
| | |
| | |
| | int inTransaction; |
| | int mxSavepoint; |
| | #endif |
| |
|
| | #if defined(SQLITE_DEBUG) || defined(SQLITE_TEST) |
| | |
| | |
| | int bNoIncrDoclist; |
| |
|
| | |
| | int nMergeCount; |
| | #endif |
| | }; |
| |
|
| | |
| | #if defined(SQLITE_DEBUG) || defined(SQLITE_TEST) |
| | # define MergeCount(P) ((P)->nMergeCount) |
| | #else |
| | # define MergeCount(P) FTS3_MERGE_COUNT |
| | #endif |
| |
|
| | |
| | |
| | |
| | |
| | |
| | struct Fts3Cursor { |
| | sqlite3_vtab_cursor base; |
| | i16 eSearch; |
| | u8 isEof; |
| | u8 isRequireSeek; |
| | u8 bSeekStmt; |
| | sqlite3_stmt *pStmt; |
| | Fts3Expr *pExpr; |
| | int iLangid; |
| | int nPhrase; |
| | Fts3DeferredToken *pDeferred; |
| | sqlite3_int64 iPrevId; |
| | char *pNextId; |
| | char *aDoclist; |
| | int nDoclist; |
| | u8 bDesc; |
| | int eEvalmode; |
| | int nRowAvg; |
| | sqlite3_int64 nDoc; |
| | i64 iMinDocid; |
| | i64 iMaxDocid; |
| | int isMatchinfoNeeded; |
| | MatchinfoBuffer *pMIBuffer; |
| | }; |
| |
|
| | #define FTS3_EVAL_FILTER 0 |
| | #define FTS3_EVAL_NEXT 1 |
| | #define FTS3_EVAL_MATCHINFO 2 |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #define FTS3_FULLSCAN_SEARCH 0 |
| | #define FTS3_DOCID_SEARCH 1 |
| | #define FTS3_FULLTEXT_SEARCH 2 |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | #define FTS3_HAVE_LANGID 0x00010000 |
| | #define FTS3_HAVE_DOCID_GE 0x00020000 |
| | #define FTS3_HAVE_DOCID_LE 0x00040000 |
| |
|
| | struct Fts3Doclist { |
| | char *aAll; |
| | int nAll; |
| | char *pNextDocid; |
| |
|
| | sqlite3_int64 iDocid; |
| | int bFreeList; |
| | char *pList; |
| | int nList; |
| | }; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | struct Fts3PhraseToken { |
| | char *z; |
| | int n; |
| | int isPrefix; |
| | int bFirst; |
| |
|
| | |
| | |
| | |
| | Fts3DeferredToken *pDeferred; |
| | Fts3MultiSegReader *pSegcsr; |
| | }; |
| |
|
| | struct Fts3Phrase { |
| | |
| | Fts3Doclist doclist; |
| | int bIncr; |
| | int iDoclistToken; |
| |
|
| | |
| | |
| | char *pOrPoslist; |
| | i64 iOrDocid; |
| |
|
| | |
| | |
| | |
| | int nToken; |
| | int iColumn; |
| | Fts3PhraseToken aToken[FLEXARRAY]; |
| | }; |
| |
|
| | |
| | #define SZ_FTS3PHRASE(N) \ |
| | (offsetof(Fts3Phrase,aToken)+(N)*sizeof(Fts3PhraseToken)) |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | struct Fts3Expr { |
| | int eType; |
| | int nNear; |
| | Fts3Expr *pParent; |
| | Fts3Expr *pLeft; |
| | Fts3Expr *pRight; |
| | Fts3Phrase *pPhrase; |
| |
|
| | |
| | sqlite3_int64 iDocid; |
| | u8 bEof; |
| | u8 bStart; |
| | u8 bDeferred; |
| |
|
| | |
| | int iPhrase; |
| | u32 *aMI; |
| | }; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #define FTSQUERY_NEAR 1 |
| | #define FTSQUERY_NOT 2 |
| | #define FTSQUERY_AND 3 |
| | #define FTSQUERY_OR 4 |
| | #define FTSQUERY_PHRASE 5 |
| |
|
| |
|
| | |
| | int sqlite3Fts3UpdateMethod(sqlite3_vtab*,int,sqlite3_value**,sqlite3_int64*); |
| | int sqlite3Fts3PendingTermsFlush(Fts3Table *); |
| | void sqlite3Fts3PendingTermsClear(Fts3Table *); |
| | int sqlite3Fts3Optimize(Fts3Table *); |
| | int sqlite3Fts3SegReaderNew(int, int, sqlite3_int64, |
| | sqlite3_int64, sqlite3_int64, const char *, int, Fts3SegReader**); |
| | int sqlite3Fts3SegReaderPending( |
| | Fts3Table*,int,const char*,int,int,Fts3SegReader**); |
| | void sqlite3Fts3SegReaderFree(Fts3SegReader *); |
| | int sqlite3Fts3AllSegdirs(Fts3Table*, int, int, int, sqlite3_stmt **); |
| | int sqlite3Fts3ReadBlock(Fts3Table*, sqlite3_int64, char **, int*, int*); |
| |
|
| | int sqlite3Fts3SelectDoctotal(Fts3Table *, sqlite3_stmt **); |
| | int sqlite3Fts3SelectDocsize(Fts3Table *, sqlite3_int64, sqlite3_stmt **); |
| |
|
| | #ifndef SQLITE_DISABLE_FTS4_DEFERRED |
| | void sqlite3Fts3FreeDeferredTokens(Fts3Cursor *); |
| | int sqlite3Fts3DeferToken(Fts3Cursor *, Fts3PhraseToken *, int); |
| | int sqlite3Fts3CacheDeferredDoclists(Fts3Cursor *); |
| | void sqlite3Fts3FreeDeferredDoclists(Fts3Cursor *); |
| | int sqlite3Fts3DeferredTokenList(Fts3DeferredToken *, char **, int *); |
| | #else |
| | # define sqlite3Fts3FreeDeferredTokens(x) |
| | # define sqlite3Fts3DeferToken(x,y,z) SQLITE_OK |
| | # define sqlite3Fts3CacheDeferredDoclists(x) SQLITE_OK |
| | # define sqlite3Fts3FreeDeferredDoclists(x) |
| | # define sqlite3Fts3DeferredTokenList(x,y,z) SQLITE_OK |
| | #endif |
| |
|
| | void sqlite3Fts3SegmentsClose(Fts3Table *); |
| | int sqlite3Fts3MaxLevel(Fts3Table *, int *); |
| |
|
| | |
| | #define FTS3_SEGCURSOR_PENDING -1 |
| | #define FTS3_SEGCURSOR_ALL -2 |
| |
|
| | int sqlite3Fts3SegReaderStart(Fts3Table*, Fts3MultiSegReader*, Fts3SegFilter*); |
| | int sqlite3Fts3SegReaderStep(Fts3Table *, Fts3MultiSegReader *); |
| | void sqlite3Fts3SegReaderFinish(Fts3MultiSegReader *); |
| |
|
| | int sqlite3Fts3SegReaderCursor(Fts3Table *, |
| | int, int, int, const char *, int, int, int, Fts3MultiSegReader *); |
| |
|
| | |
| | #define FTS3_SEGMENT_REQUIRE_POS 0x00000001 |
| | #define FTS3_SEGMENT_IGNORE_EMPTY 0x00000002 |
| | #define FTS3_SEGMENT_COLUMN_FILTER 0x00000004 |
| | #define FTS3_SEGMENT_PREFIX 0x00000008 |
| | #define FTS3_SEGMENT_SCAN 0x00000010 |
| | #define FTS3_SEGMENT_FIRST 0x00000020 |
| |
|
| | |
| | struct Fts3SegFilter { |
| | const char *zTerm; |
| | int nTerm; |
| | int iCol; |
| | int flags; |
| | }; |
| |
|
| | struct Fts3MultiSegReader { |
| | |
| | Fts3SegReader **apSegment; |
| | int nSegment; |
| | int nAdvance; |
| | Fts3SegFilter *pFilter; |
| | char *aBuffer; |
| | i64 nBuffer; |
| |
|
| | int iColFilter; |
| | int bRestart; |
| |
|
| | |
| | int nCost; |
| | int bLookup; |
| |
|
| | |
| | char *zTerm; |
| | int nTerm; |
| | char *aDoclist; |
| | int nDoclist; |
| | }; |
| |
|
| | int sqlite3Fts3Incrmerge(Fts3Table*,int,int); |
| |
|
| | #define fts3GetVarint32(p, piVal) ( \ |
| | (*(u8*)(p)&0x80) ? sqlite3Fts3GetVarint32(p, piVal) : (*piVal=*(u8*)(p), 1) \ |
| | ) |
| |
|
| | |
| | void sqlite3Fts3ErrMsg(char**,const char*,...); |
| | int sqlite3Fts3PutVarint(char *, sqlite3_int64); |
| | int sqlite3Fts3GetVarint(const char *, sqlite_int64 *); |
| | int sqlite3Fts3GetVarintU(const char *, sqlite_uint64 *); |
| | int sqlite3Fts3GetVarintBounded(const char*,const char*,sqlite3_int64*); |
| | int sqlite3Fts3GetVarint32(const char *, int *); |
| | int sqlite3Fts3VarintLen(sqlite3_uint64); |
| | void sqlite3Fts3Dequote(char *); |
| | void sqlite3Fts3DoclistPrev(int,char*,int,char**,sqlite3_int64*,int*,u8*); |
| | int sqlite3Fts3EvalPhraseStats(Fts3Cursor *, Fts3Expr *, u32 *); |
| | int sqlite3Fts3FirstFilter(sqlite3_int64, char *, int, char *); |
| | void sqlite3Fts3CreateStatTable(int*, Fts3Table*); |
| | int sqlite3Fts3EvalTestDeferred(Fts3Cursor *pCsr, int *pRc); |
| | int sqlite3Fts3ReadInt(const char *z, int *pnOut); |
| |
|
| | |
| | const char *sqlite3Fts3NextToken(const char *, int *); |
| | int sqlite3Fts3InitHashTable(sqlite3 *, Fts3Hash *, const char *); |
| | int sqlite3Fts3InitTokenizer(Fts3Hash *pHash, const char *, |
| | sqlite3_tokenizer **, char ** |
| | ); |
| | int sqlite3Fts3IsIdChar(char); |
| |
|
| | |
| | void sqlite3Fts3Offsets(sqlite3_context*, Fts3Cursor*); |
| | void sqlite3Fts3Snippet(sqlite3_context *, Fts3Cursor *, const char *, |
| | const char *, const char *, int, int |
| | ); |
| | void sqlite3Fts3Matchinfo(sqlite3_context *, Fts3Cursor *, const char *); |
| | void sqlite3Fts3MIBufferFree(MatchinfoBuffer *p); |
| |
|
| | |
| | int sqlite3Fts3ExprParse(sqlite3_tokenizer *, int, |
| | char **, int, int, int, const char *, int, Fts3Expr **, char ** |
| | ); |
| | void sqlite3Fts3ExprFree(Fts3Expr *); |
| | #ifdef SQLITE_TEST |
| | int sqlite3Fts3ExprInitTestInterface(sqlite3 *db, Fts3Hash*); |
| | int sqlite3Fts3InitTerm(sqlite3 *db); |
| | #endif |
| | void *sqlite3Fts3MallocZero(i64 nByte); |
| |
|
| | int sqlite3Fts3OpenTokenizer(sqlite3_tokenizer *, int, const char *, int, |
| | sqlite3_tokenizer_cursor ** |
| | ); |
| |
|
| | |
| | int sqlite3Fts3InitAux(sqlite3 *db); |
| |
|
| | void sqlite3Fts3EvalPhraseCleanup(Fts3Phrase *); |
| |
|
| | int sqlite3Fts3MsrIncrStart( |
| | Fts3Table*, Fts3MultiSegReader*, int, const char*, int); |
| | int sqlite3Fts3MsrIncrNext( |
| | Fts3Table *, Fts3MultiSegReader *, sqlite3_int64 *, char **, int *); |
| | int sqlite3Fts3EvalPhrasePoslist(Fts3Cursor *, Fts3Expr *, int iCol, char **); |
| | int sqlite3Fts3MsrOvfl(Fts3Cursor *, Fts3MultiSegReader *, int *); |
| | int sqlite3Fts3MsrIncrRestart(Fts3MultiSegReader *pCsr); |
| | int sqlite3Fts3MsrCancel(Fts3Cursor*, Fts3Expr*); |
| |
|
| | |
| | int sqlite3Fts3InitTok(sqlite3*, Fts3Hash *, void(*xDestroy)(void*)); |
| |
|
| | |
| | #ifndef SQLITE_DISABLE_FTS3_UNICODE |
| | int sqlite3FtsUnicodeFold(int, int); |
| | int sqlite3FtsUnicodeIsalnum(int); |
| | int sqlite3FtsUnicodeIsdiacritic(int); |
| | #endif |
| |
|
| | int sqlite3Fts3ExprIterate(Fts3Expr*, int (*x)(Fts3Expr*,int,void*), void*); |
| |
|
| | int sqlite3Fts3IntegrityCheck(Fts3Table *p, int *pbOk); |
| |
|
| | #endif |
| | #endif |
| |
|