4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 *************************************************************************
13 ** This file implements an eponymous virtual table that returns suggested
14 ** completions for a partial SQL input.
18 ** SELECT DISTINCT candidate COLLATE nocase
19 ** FROM completion($prefix,$wholeline)
22 ** The two query parameters are optional. $prefix is the text of the
23 ** current word being typed and that is to be completed. $wholeline is
24 ** the complete input line, used for context.
26 ** The raw completion() table might return the same candidate multiple
27 ** times, for example if the same column name is used to two or more
28 ** tables. And the candidates are returned in an arbitrary order. Hence,
29 ** the DISTINCT and ORDER BY are recommended.
31 ** This virtual table operates at the speed of human typing, and so there
32 ** is no attempt to make it fast. Even a slow implementation will be much
33 ** faster than any human can type.
36 #include "sqlite3ext.h"
37 SQLITE_EXTENSION_INIT1
42 #ifndef SQLITE_OMIT_VIRTUALTABLE
44 /* completion_vtab is a subclass of sqlite3_vtab which will
45 ** serve as the underlying representation of a completion virtual table
47 typedef struct completion_vtab completion_vtab
;
48 struct completion_vtab
{
49 sqlite3_vtab base
; /* Base class - must be first */
50 sqlite3
*db
; /* Database connection for this completion vtab */
53 /* completion_cursor is a subclass of sqlite3_vtab_cursor which will
54 ** serve as the underlying representation of a cursor that scans
55 ** over rows of the result
57 typedef struct completion_cursor completion_cursor
;
58 struct completion_cursor
{
59 sqlite3_vtab_cursor base
; /* Base class - must be first */
60 sqlite3
*db
; /* Database connection for this cursor */
61 int nPrefix
, nLine
; /* Number of bytes in zPrefix and zLine */
62 char *zPrefix
; /* The prefix for the word we want to complete */
63 char *zLine
; /* The whole that we want to complete */
64 const char *zCurrentRow
; /* Current output row */
65 int szRow
; /* Length of the zCurrentRow string */
66 sqlite3_stmt
*pStmt
; /* Current statement */
67 sqlite3_int64 iRowid
; /* The rowid */
68 int ePhase
; /* Current phase */
69 int j
; /* inter-phase counter */
74 #define COMPLETION_FIRST_PHASE 1
75 #define COMPLETION_KEYWORDS 1
76 #define COMPLETION_PRAGMAS 2
77 #define COMPLETION_FUNCTIONS 3
78 #define COMPLETION_COLLATIONS 4
79 #define COMPLETION_INDEXES 5
80 #define COMPLETION_TRIGGERS 6
81 #define COMPLETION_DATABASES 7
82 #define COMPLETION_TABLES 8 /* Also VIEWs and TRIGGERs */
83 #define COMPLETION_COLUMNS 9
84 #define COMPLETION_MODULES 10
85 #define COMPLETION_EOF 11
88 ** The completionConnect() method is invoked to create a new
89 ** completion_vtab that describes the completion virtual table.
91 ** Think of this routine as the constructor for completion_vtab objects.
93 ** All this routine needs to do is:
95 ** (1) Allocate the completion_vtab object and initialize all fields.
97 ** (2) Tell SQLite (via the sqlite3_declare_vtab() interface) what the
98 ** result set of queries against completion will look like.
100 static int completionConnect(
103 int argc
, const char *const*argv
,
104 sqlite3_vtab
**ppVtab
,
107 completion_vtab
*pNew
;
110 (void)(pAux
); /* Unused parameter */
111 (void)(argc
); /* Unused parameter */
112 (void)(argv
); /* Unused parameter */
113 (void)(pzErr
); /* Unused parameter */
116 #define COMPLETION_COLUMN_CANDIDATE 0 /* Suggested completion of the input */
117 #define COMPLETION_COLUMN_PREFIX 1 /* Prefix of the word to be completed */
118 #define COMPLETION_COLUMN_WHOLELINE 2 /* Entire line seen so far */
119 #define COMPLETION_COLUMN_PHASE 3 /* ePhase - used for debugging only */
121 sqlite3_vtab_config(db
, SQLITE_VTAB_INNOCUOUS
);
122 rc
= sqlite3_declare_vtab(db
,
125 " prefix TEXT HIDDEN,"
126 " wholeline TEXT HIDDEN,"
127 " phase INT HIDDEN" /* Used for debugging only */
130 pNew
= sqlite3_malloc( sizeof(*pNew
) );
131 *ppVtab
= (sqlite3_vtab
*)pNew
;
132 if( pNew
==0 ) return SQLITE_NOMEM
;
133 memset(pNew
, 0, sizeof(*pNew
));
140 ** This method is the destructor for completion_cursor objects.
142 static int completionDisconnect(sqlite3_vtab
*pVtab
){
148 ** Constructor for a new completion_cursor object.
150 static int completionOpen(sqlite3_vtab
*p
, sqlite3_vtab_cursor
**ppCursor
){
151 completion_cursor
*pCur
;
152 pCur
= sqlite3_malloc( sizeof(*pCur
) );
153 if( pCur
==0 ) return SQLITE_NOMEM
;
154 memset(pCur
, 0, sizeof(*pCur
));
155 pCur
->db
= ((completion_vtab
*)p
)->db
;
156 *ppCursor
= &pCur
->base
;
161 ** Reset the completion_cursor.
163 static void completionCursorReset(completion_cursor
*pCur
){
164 sqlite3_free(pCur
->zPrefix
); pCur
->zPrefix
= 0; pCur
->nPrefix
= 0;
165 sqlite3_free(pCur
->zLine
); pCur
->zLine
= 0; pCur
->nLine
= 0;
166 sqlite3_finalize(pCur
->pStmt
); pCur
->pStmt
= 0;
171 ** Destructor for a completion_cursor.
173 static int completionClose(sqlite3_vtab_cursor
*cur
){
174 completionCursorReset((completion_cursor
*)cur
);
180 ** Advance a completion_cursor to its next row of output.
182 ** The ->ePhase, ->j, and ->pStmt fields of the completion_cursor object
183 ** record the current state of the scan. This routine sets ->zCurrentRow
184 ** to the current row of output and then returns. If no more rows remain,
185 ** then ->ePhase is set to COMPLETION_EOF which will signal the virtual
186 ** table that has reached the end of its scan.
188 ** The current implementation just lists potential identifiers and
189 ** keywords and filters them by zPrefix. Future enhancements should
190 ** take zLine into account to try to restrict the set of identifiers and
191 ** keywords based on what would be legal at the current point of input.
193 static int completionNext(sqlite3_vtab_cursor
*cur
){
194 completion_cursor
*pCur
= (completion_cursor
*)cur
;
195 int eNextPhase
= 0; /* Next phase to try if current phase reaches end */
196 int iCol
= -1; /* If >=0, step pCur->pStmt and use the i-th column */
198 while( pCur
->ePhase
!=COMPLETION_EOF
){
199 switch( pCur
->ePhase
){
200 case COMPLETION_KEYWORDS
: {
201 if( pCur
->j
>= sqlite3_keyword_count() ){
202 pCur
->zCurrentRow
= 0;
203 pCur
->ePhase
= COMPLETION_DATABASES
;
205 sqlite3_keyword_name(pCur
->j
++, &pCur
->zCurrentRow
, &pCur
->szRow
);
210 case COMPLETION_DATABASES
: {
211 if( pCur
->pStmt
==0 ){
212 sqlite3_prepare_v2(pCur
->db
, "PRAGMA database_list", -1,
216 eNextPhase
= COMPLETION_TABLES
;
219 case COMPLETION_TABLES
: {
220 if( pCur
->pStmt
==0 ){
223 const char *zSep
= "";
224 sqlite3_prepare_v2(pCur
->db
, "PRAGMA database_list", -1, &pS2
, 0);
225 while( sqlite3_step(pS2
)==SQLITE_ROW
){
226 const char *zDb
= (const char*)sqlite3_column_text(pS2
, 1);
227 zSql
= sqlite3_mprintf(
229 "SELECT name FROM \"%w\".sqlite_schema",
232 if( zSql
==0 ) return SQLITE_NOMEM
;
235 sqlite3_finalize(pS2
);
236 sqlite3_prepare_v2(pCur
->db
, zSql
, -1, &pCur
->pStmt
, 0);
240 eNextPhase
= COMPLETION_COLUMNS
;
243 case COMPLETION_COLUMNS
: {
244 if( pCur
->pStmt
==0 ){
247 const char *zSep
= "";
248 sqlite3_prepare_v2(pCur
->db
, "PRAGMA database_list", -1, &pS2
, 0);
249 while( sqlite3_step(pS2
)==SQLITE_ROW
){
250 const char *zDb
= (const char*)sqlite3_column_text(pS2
, 1);
251 zSql
= sqlite3_mprintf(
253 "SELECT pti.name FROM \"%w\".sqlite_schema AS sm"
254 " JOIN pragma_table_info(sm.name,%Q) AS pti"
255 " WHERE sm.type='table'",
258 if( zSql
==0 ) return SQLITE_NOMEM
;
261 sqlite3_finalize(pS2
);
262 sqlite3_prepare_v2(pCur
->db
, zSql
, -1, &pCur
->pStmt
, 0);
266 eNextPhase
= COMPLETION_EOF
;
271 /* This case is when the phase presets zCurrentRow */
272 if( pCur
->zCurrentRow
==0 ) continue;
274 if( sqlite3_step(pCur
->pStmt
)==SQLITE_ROW
){
275 /* Extract the next row of content */
276 pCur
->zCurrentRow
= (const char*)sqlite3_column_text(pCur
->pStmt
, iCol
);
277 pCur
->szRow
= sqlite3_column_bytes(pCur
->pStmt
, iCol
);
279 /* When all rows are finished, advance to the next phase */
280 sqlite3_finalize(pCur
->pStmt
);
282 pCur
->ePhase
= eNextPhase
;
286 if( pCur
->nPrefix
==0 ) break;
287 if( pCur
->nPrefix
<=pCur
->szRow
288 && sqlite3_strnicmp(pCur
->zPrefix
, pCur
->zCurrentRow
, pCur
->nPrefix
)==0
298 ** Return values of columns for the row at which the completion_cursor
299 ** is currently pointing.
301 static int completionColumn(
302 sqlite3_vtab_cursor
*cur
, /* The cursor */
303 sqlite3_context
*ctx
, /* First argument to sqlite3_result_...() */
304 int i
/* Which column to return */
306 completion_cursor
*pCur
= (completion_cursor
*)cur
;
308 case COMPLETION_COLUMN_CANDIDATE
: {
309 sqlite3_result_text(ctx
, pCur
->zCurrentRow
, pCur
->szRow
,SQLITE_TRANSIENT
);
312 case COMPLETION_COLUMN_PREFIX
: {
313 sqlite3_result_text(ctx
, pCur
->zPrefix
, -1, SQLITE_TRANSIENT
);
316 case COMPLETION_COLUMN_WHOLELINE
: {
317 sqlite3_result_text(ctx
, pCur
->zLine
, -1, SQLITE_TRANSIENT
);
320 case COMPLETION_COLUMN_PHASE
: {
321 sqlite3_result_int(ctx
, pCur
->ePhase
);
329 ** Return the rowid for the current row. In this implementation, the
330 ** rowid is the same as the output value.
332 static int completionRowid(sqlite3_vtab_cursor
*cur
, sqlite_int64
*pRowid
){
333 completion_cursor
*pCur
= (completion_cursor
*)cur
;
334 *pRowid
= pCur
->iRowid
;
339 ** Return TRUE if the cursor has been moved off of the last
342 static int completionEof(sqlite3_vtab_cursor
*cur
){
343 completion_cursor
*pCur
= (completion_cursor
*)cur
;
344 return pCur
->ePhase
>= COMPLETION_EOF
;
348 ** This method is called to "rewind" the completion_cursor object back
349 ** to the first row of output. This method is always called at least
350 ** once prior to any call to completionColumn() or completionRowid() or
353 static int completionFilter(
354 sqlite3_vtab_cursor
*pVtabCursor
,
355 int idxNum
, const char *idxStr
,
356 int argc
, sqlite3_value
**argv
358 completion_cursor
*pCur
= (completion_cursor
*)pVtabCursor
;
360 (void)(idxStr
); /* Unused parameter */
361 (void)(argc
); /* Unused parameter */
362 completionCursorReset(pCur
);
364 pCur
->nPrefix
= sqlite3_value_bytes(argv
[iArg
]);
365 if( pCur
->nPrefix
>0 ){
366 pCur
->zPrefix
= sqlite3_mprintf("%s", sqlite3_value_text(argv
[iArg
]));
367 if( pCur
->zPrefix
==0 ) return SQLITE_NOMEM
;
372 pCur
->nLine
= sqlite3_value_bytes(argv
[iArg
]);
374 pCur
->zLine
= sqlite3_mprintf("%s", sqlite3_value_text(argv
[iArg
]));
375 if( pCur
->zLine
==0 ) return SQLITE_NOMEM
;
378 if( pCur
->zLine
!=0 && pCur
->zPrefix
==0 ){
380 while( i
>0 && (isalnum(pCur
->zLine
[i
-1]) || pCur
->zLine
[i
-1]=='_') ){
383 pCur
->nPrefix
= pCur
->nLine
- i
;
384 if( pCur
->nPrefix
>0 ){
385 pCur
->zPrefix
= sqlite3_mprintf("%.*s", pCur
->nPrefix
, pCur
->zLine
+ i
);
386 if( pCur
->zPrefix
==0 ) return SQLITE_NOMEM
;
390 pCur
->ePhase
= COMPLETION_FIRST_PHASE
;
391 return completionNext(pVtabCursor
);
395 ** SQLite will invoke this method one or more times while planning a query
396 ** that uses the completion virtual table. This routine needs to create
397 ** a query plan for each invocation and compute an estimated cost for that
400 ** There are two hidden parameters that act as arguments to the table-valued
401 ** function: "prefix" and "wholeline". Bit 0 of idxNum is set if "prefix"
402 ** is available and bit 1 is set if "wholeline" is available.
404 static int completionBestIndex(
406 sqlite3_index_info
*pIdxInfo
408 int i
; /* Loop over constraints */
409 int idxNum
= 0; /* The query plan bitmask */
410 int prefixIdx
= -1; /* Index of the start= constraint, or -1 if none */
411 int wholelineIdx
= -1; /* Index of the stop= constraint, or -1 if none */
412 int nArg
= 0; /* Number of arguments that completeFilter() expects */
413 const struct sqlite3_index_constraint
*pConstraint
;
415 (void)(tab
); /* Unused parameter */
416 pConstraint
= pIdxInfo
->aConstraint
;
417 for(i
=0; i
<pIdxInfo
->nConstraint
; i
++, pConstraint
++){
418 if( pConstraint
->usable
==0 ) continue;
419 if( pConstraint
->op
!=SQLITE_INDEX_CONSTRAINT_EQ
) continue;
420 switch( pConstraint
->iColumn
){
421 case COMPLETION_COLUMN_PREFIX
:
425 case COMPLETION_COLUMN_WHOLELINE
:
432 pIdxInfo
->aConstraintUsage
[prefixIdx
].argvIndex
= ++nArg
;
433 pIdxInfo
->aConstraintUsage
[prefixIdx
].omit
= 1;
435 if( wholelineIdx
>=0 ){
436 pIdxInfo
->aConstraintUsage
[wholelineIdx
].argvIndex
= ++nArg
;
437 pIdxInfo
->aConstraintUsage
[wholelineIdx
].omit
= 1;
439 pIdxInfo
->idxNum
= idxNum
;
440 pIdxInfo
->estimatedCost
= (double)5000 - 1000*nArg
;
441 pIdxInfo
->estimatedRows
= 500 - 100*nArg
;
446 ** This following structure defines all the methods for the
447 ** completion virtual table.
449 static sqlite3_module completionModule
= {
452 completionConnect
, /* xConnect */
453 completionBestIndex
, /* xBestIndex */
454 completionDisconnect
, /* xDisconnect */
456 completionOpen
, /* xOpen - open a cursor */
457 completionClose
, /* xClose - close a cursor */
458 completionFilter
, /* xFilter - configure scan constraints */
459 completionNext
, /* xNext - advance a cursor */
460 completionEof
, /* xEof - check for end of scan */
461 completionColumn
, /* xColumn - read data */
462 completionRowid
, /* xRowid - read data */
477 #endif /* SQLITE_OMIT_VIRTUALTABLE */
479 int sqlite3CompletionVtabInit(sqlite3
*db
){
481 #ifndef SQLITE_OMIT_VIRTUALTABLE
482 rc
= sqlite3_create_module(db
, "completion", &completionModule
, 0);
488 __declspec(dllexport
)
490 int sqlite3_completion_init(
493 const sqlite3_api_routines
*pApi
496 SQLITE_EXTENSION_INIT2(pApi
);
497 (void)(pzErrMsg
); /* Unused parameter */
498 #ifndef SQLITE_OMIT_VIRTUALTABLE
499 rc
= sqlite3CompletionVtabInit(db
);