/ Hex Artifact Content
Login

Artifact 52c3f01523e3e387eb321b4739a89d1fe47cbe6025aa1f2d8d3685e9e365df0f:


0000: 2f 2a 0a 2a 2a 20 32 30 31 37 2d 30 37 2d 31 30  /*.** 2017-07-10
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a  ***************.
0170: 2a 2a 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20  **.** This file 
0180: 69 6d 70 6c 65 6d 65 6e 74 73 20 61 6e 20 65 70  implements an ep
0190: 6f 6e 79 6d 6f 75 73 20 76 69 72 74 75 61 6c 20  onymous virtual 
01a0: 74 61 62 6c 65 20 74 68 61 74 20 72 65 74 75 72  table that retur
01b0: 6e 73 20 73 75 67 67 65 73 74 65 64 0a 2a 2a 20  ns suggested.** 
01c0: 63 6f 6d 70 6c 65 74 69 6f 6e 73 20 66 6f 72 20  completions for 
01d0: 61 20 70 61 72 74 69 61 6c 20 53 51 4c 20 69 6e  a partial SQL in
01e0: 70 75 74 2e 0a 2a 2a 0a 2a 2a 20 53 75 67 67 65  put..**.** Sugge
01f0: 73 74 65 64 20 75 73 61 67 65 3a 0a 2a 2a 0a 2a  sted usage:.**.*
0200: 2a 20 20 20 20 20 53 45 4c 45 43 54 20 44 49 53  *     SELECT DIS
0210: 54 49 4e 43 54 20 63 61 6e 64 69 64 61 74 65 20  TINCT candidate 
0220: 43 4f 4c 4c 41 54 45 20 6e 6f 63 61 73 65 0a 2a  COLLATE nocase.*
0230: 2a 20 20 20 20 20 20 20 46 52 4f 4d 20 63 6f 6d  *       FROM com
0240: 70 6c 65 74 69 6f 6e 28 24 70 72 65 66 69 78 2c  pletion($prefix,
0250: 24 77 68 6f 6c 65 6c 69 6e 65 29 0a 2a 2a 20 20  $wholeline).**  
0260: 20 20 20 20 4f 52 44 45 52 20 42 59 20 31 3b 0a      ORDER BY 1;.
0270: 2a 2a 0a 2a 2a 20 54 68 65 20 74 77 6f 20 71 75  **.** The two qu
0280: 65 72 79 20 70 61 72 61 6d 65 74 65 72 73 20 61  ery parameters a
0290: 72 65 20 6f 70 74 69 6f 6e 61 6c 2e 20 20 24 70  re optional.  $p
02a0: 72 65 66 69 78 20 69 73 20 74 68 65 20 74 65 78  refix is the tex
02b0: 74 20 6f 66 20 74 68 65 0a 2a 2a 20 63 75 72 72  t of the.** curr
02c0: 65 6e 74 20 77 6f 72 64 20 62 65 69 6e 67 20 74  ent word being t
02d0: 79 70 65 64 20 61 6e 64 20 74 68 61 74 20 69 73  yped and that is
02e0: 20 74 6f 20 62 65 20 63 6f 6d 70 6c 65 74 65 64   to be completed
02f0: 2e 20 20 24 77 68 6f 6c 65 6c 69 6e 65 20 69 73  .  $wholeline is
0300: 0a 2a 2a 20 74 68 65 20 63 6f 6d 70 6c 65 74 65  .** the complete
0310: 20 69 6e 70 75 74 20 6c 69 6e 65 2c 20 75 73 65   input line, use
0320: 64 20 66 6f 72 20 63 6f 6e 74 65 78 74 2e 0a 2a  d for context..*
0330: 2a 0a 2a 2a 20 54 68 65 20 72 61 77 20 63 6f 6d  *.** The raw com
0340: 70 6c 65 74 69 6f 6e 28 29 20 74 61 62 6c 65 20  pletion() table 
0350: 6d 69 67 68 74 20 72 65 74 75 72 6e 20 74 68 65  might return the
0360: 20 73 61 6d 65 20 63 61 6e 64 69 64 61 74 65 20   same candidate 
0370: 6d 75 6c 74 69 70 6c 65 0a 2a 2a 20 74 69 6d 65  multiple.** time
0380: 73 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65 20 69  s, for example i
0390: 66 20 74 68 65 20 73 61 6d 65 20 63 6f 6c 75 6d  f the same colum
03a0: 6e 20 6e 61 6d 65 20 69 73 20 75 73 65 64 20 74  n name is used t
03b0: 6f 20 74 77 6f 20 6f 72 20 6d 6f 72 65 0a 2a 2a  o two or more.**
03c0: 20 74 61 62 6c 65 73 2e 20 20 41 6e 64 20 74 68   tables.  And th
03d0: 65 20 63 61 6e 64 69 64 61 74 65 73 20 61 72 65  e candidates are
03e0: 20 72 65 74 75 72 6e 65 64 20 69 6e 20 61 6e 20   returned in an 
03f0: 61 72 62 69 74 72 61 72 79 20 6f 72 64 65 72 2e  arbitrary order.
0400: 20 20 48 65 6e 63 65 2c 0a 2a 2a 20 74 68 65 20    Hence,.** the 
0410: 44 49 53 54 49 4e 43 54 20 61 6e 64 20 4f 52 44  DISTINCT and ORD
0420: 45 52 20 42 59 20 61 72 65 20 72 65 63 6f 6d 6d  ER BY are recomm
0430: 65 6e 64 65 64 2e 0a 2a 2a 0a 2a 2a 20 54 68 69  ended..**.** Thi
0440: 73 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65 20  s virtual table 
0450: 6f 70 65 72 61 74 65 73 20 61 74 20 74 68 65 20  operates at the 
0460: 73 70 65 65 64 20 6f 66 20 68 75 6d 61 6e 20 74  speed of human t
0470: 79 70 69 6e 67 2c 20 61 6e 64 20 73 6f 20 74 68  yping, and so th
0480: 65 72 65 0a 2a 2a 20 69 73 20 6e 6f 20 61 74 74  ere.** is no att
0490: 65 6d 70 74 20 74 6f 20 6d 61 6b 65 20 69 74 20  empt to make it 
04a0: 66 61 73 74 2e 20 20 45 76 65 6e 20 61 20 73 6c  fast.  Even a sl
04b0: 6f 77 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  ow implementatio
04c0: 6e 20 77 69 6c 6c 20 62 65 20 6d 75 63 68 0a 2a  n will be much.*
04d0: 2a 20 66 61 73 74 65 72 20 74 68 61 6e 20 61 6e  * faster than an
04e0: 79 20 68 75 6d 61 6e 20 63 61 6e 20 74 79 70 65  y human can type
04f0: 2e 0a 2a 2a 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65  ..**.*/.#include
0500: 20 22 73 71 6c 69 74 65 33 65 78 74 2e 68 22 0a   "sqlite3ext.h".
0510: 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49 4f 4e  SQLITE_EXTENSION
0520: 5f 49 4e 49 54 31 0a 23 69 6e 63 6c 75 64 65 20  _INIT1.#include 
0530: 3c 61 73 73 65 72 74 2e 68 3e 0a 23 69 6e 63 6c  <assert.h>.#incl
0540: 75 64 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23  ude <string.h>.#
0550: 69 6e 63 6c 75 64 65 20 3c 63 74 79 70 65 2e 68  include <ctype.h
0560: 3e 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  >..#ifndef SQLIT
0570: 45 5f 4f 4d 49 54 5f 56 49 52 54 55 41 4c 54 41  E_OMIT_VIRTUALTA
0580: 42 4c 45 0a 0a 2f 2a 20 63 6f 6d 70 6c 65 74 69  BLE../* completi
0590: 6f 6e 5f 76 74 61 62 20 69 73 20 61 20 73 75 62  on_vtab is a sub
05a0: 63 6c 61 73 73 20 6f 66 20 73 71 6c 69 74 65 33  class of sqlite3
05b0: 5f 76 74 61 62 20 77 68 69 63 68 20 77 69 6c 6c  _vtab which will
05c0: 0a 2a 2a 20 73 65 72 76 65 20 61 73 20 74 68 65  .** serve as the
05d0: 20 75 6e 64 65 72 6c 79 69 6e 67 20 72 65 70 72   underlying repr
05e0: 65 73 65 6e 74 61 74 69 6f 6e 20 6f 66 20 61 20  esentation of a 
05f0: 63 6f 6d 70 6c 65 74 69 6f 6e 20 76 69 72 74 75  completion virtu
0600: 61 6c 20 74 61 62 6c 65 0a 2a 2f 0a 74 79 70 65  al table.*/.type
0610: 64 65 66 20 73 74 72 75 63 74 20 63 6f 6d 70 6c  def struct compl
0620: 65 74 69 6f 6e 5f 76 74 61 62 20 63 6f 6d 70 6c  etion_vtab compl
0630: 65 74 69 6f 6e 5f 76 74 61 62 3b 0a 73 74 72 75  etion_vtab;.stru
0640: 63 74 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f 76 74  ct completion_vt
0650: 61 62 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76  ab {.  sqlite3_v
0660: 74 61 62 20 62 61 73 65 3b 20 20 2f 2a 20 42 61  tab base;  /* Ba
0670: 73 65 20 63 6c 61 73 73 20 2d 20 6d 75 73 74 20  se class - must 
0680: 62 65 20 66 69 72 73 74 20 2a 2f 0a 20 20 73 71  be first */.  sq
0690: 6c 69 74 65 33 20 2a 64 62 3b 20 20 20 20 20 20  lite3 *db;      
06a0: 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 63 6f    /* Database co
06b0: 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20 74 68 69  nnection for thi
06c0: 73 20 63 6f 6d 70 6c 65 74 69 6f 6e 20 76 74 61  s completion vta
06d0: 62 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 20 63 6f 6d 70  b */.};../* comp
06e0: 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 20 69 73  letion_cursor is
06f0: 20 61 20 73 75 62 63 6c 61 73 73 20 6f 66 20 73   a subclass of s
0700: 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73  qlite3_vtab_curs
0710: 6f 72 20 77 68 69 63 68 20 77 69 6c 6c 0a 2a 2a  or which will.**
0720: 20 73 65 72 76 65 20 61 73 20 74 68 65 20 75 6e   serve as the un
0730: 64 65 72 6c 79 69 6e 67 20 72 65 70 72 65 73 65  derlying represe
0740: 6e 74 61 74 69 6f 6e 20 6f 66 20 61 20 63 75 72  ntation of a cur
0750: 73 6f 72 20 74 68 61 74 20 73 63 61 6e 73 0a 2a  sor that scans.*
0760: 2a 20 6f 76 65 72 20 72 6f 77 73 20 6f 66 20 74  * over rows of t
0770: 68 65 20 72 65 73 75 6c 74 0a 2a 2f 0a 74 79 70  he result.*/.typ
0780: 65 64 65 66 20 73 74 72 75 63 74 20 63 6f 6d 70  edef struct comp
0790: 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 20 63 6f  letion_cursor co
07a0: 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 3b  mpletion_cursor;
07b0: 0a 73 74 72 75 63 74 20 63 6f 6d 70 6c 65 74 69  .struct completi
07c0: 6f 6e 5f 63 75 72 73 6f 72 20 7b 0a 20 20 73 71  on_cursor {.  sq
07d0: 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f  lite3_vtab_curso
07e0: 72 20 62 61 73 65 3b 20 20 2f 2a 20 42 61 73 65  r base;  /* Base
07f0: 20 63 6c 61 73 73 20 2d 20 6d 75 73 74 20 62 65   class - must be
0800: 20 66 69 72 73 74 20 2a 2f 0a 20 20 73 71 6c 69   first */.  sqli
0810: 74 65 33 20 2a 64 62 3b 20 20 20 20 20 20 20 20  te3 *db;        
0820: 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61         /* Databa
0830: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f  se connection fo
0840: 72 20 74 68 69 73 20 63 75 72 73 6f 72 20 2a 2f  r this cursor */
0850: 0a 20 20 69 6e 74 20 6e 50 72 65 66 69 78 2c 20  .  int nPrefix, 
0860: 6e 4c 69 6e 65 3b 20 20 20 20 20 20 20 20 2f 2a  nLine;        /*
0870: 20 4e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73   Number of bytes
0880: 20 69 6e 20 7a 50 72 65 66 69 78 20 61 6e 64 20   in zPrefix and 
0890: 7a 4c 69 6e 65 20 2a 2f 0a 20 20 63 68 61 72 20  zLine */.  char 
08a0: 2a 7a 50 72 65 66 69 78 3b 20 20 20 20 20 20 20  *zPrefix;       
08b0: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 72 65        /* The pre
08c0: 66 69 78 20 66 6f 72 20 74 68 65 20 77 6f 72 64  fix for the word
08d0: 20 77 65 20 77 61 6e 74 20 74 6f 20 63 6f 6d 70   we want to comp
08e0: 6c 65 74 65 20 2a 2f 0a 20 20 63 68 61 72 20 2a  lete */.  char *
08f0: 7a 4c 69 6e 65 3b 20 20 20 20 20 20 20 20 20 20  zLine;          
0900: 20 20 20 20 20 2f 2a 20 54 68 65 20 77 68 6f 6c       /* The whol
0910: 65 20 74 68 61 74 20 77 65 20 77 61 6e 74 20 74  e that we want t
0920: 6f 20 63 6f 6d 70 6c 65 74 65 20 2a 2f 0a 20 20  o complete */.  
0930: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 43 75 72  const char *zCur
0940: 72 65 6e 74 52 6f 77 3b 20 20 20 2f 2a 20 43 75  rentRow;   /* Cu
0950: 72 72 65 6e 74 20 6f 75 74 70 75 74 20 72 6f 77  rrent output row
0960: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73 74   */.  sqlite3_st
0970: 6d 74 20 2a 70 53 74 6d 74 3b 20 20 20 20 20 20  mt *pStmt;      
0980: 20 2f 2a 20 43 75 72 72 65 6e 74 20 73 74 61 74   /* Current stat
0990: 65 6d 65 6e 74 20 2a 2f 0a 20 20 73 71 6c 69 74  ement */.  sqlit
09a0: 65 33 5f 69 6e 74 36 34 20 69 52 6f 77 69 64 3b  e3_int64 iRowid;
09b0: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 72 6f 77        /* The row
09c0: 69 64 20 2a 2f 0a 20 20 69 6e 74 20 65 50 68 61  id */.  int ePha
09d0: 73 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  se;             
09e0: 20 20 20 2f 2a 20 43 75 72 72 65 6e 74 20 70 68     /* Current ph
09f0: 61 73 65 20 2a 2f 0a 20 20 69 6e 74 20 6a 3b 20  ase */.  int j; 
0a00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a10: 20 20 20 20 2f 2a 20 69 6e 74 65 72 2d 70 68 61      /* inter-pha
0a20: 73 65 20 63 6f 75 6e 74 65 72 20 2a 2f 0a 7d 3b  se counter */.};
0a30: 0a 0a 2f 2a 20 56 61 6c 75 65 73 20 66 6f 72 20  ../* Values for 
0a40: 65 50 68 61 73 65 3a 0a 2a 2f 0a 23 64 65 66 69  ePhase:.*/.#defi
0a50: 6e 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 46 49  ne COMPLETION_FI
0a60: 52 53 54 5f 50 48 41 53 45 20 20 20 31 0a 23 64  RST_PHASE   1.#d
0a70: 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49 4f 4e  efine COMPLETION
0a80: 5f 4b 45 59 57 4f 52 44 53 20 20 20 20 20 20 31  _KEYWORDS      1
0a90: 0a 23 64 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54  .#define COMPLET
0aa0: 49 4f 4e 5f 50 52 41 47 4d 41 53 20 20 20 20 20  ION_PRAGMAS     
0ab0: 20 20 32 0a 23 64 65 66 69 6e 65 20 43 4f 4d 50    2.#define COMP
0ac0: 4c 45 54 49 4f 4e 5f 46 55 4e 43 54 49 4f 4e 53  LETION_FUNCTIONS
0ad0: 20 20 20 20 20 33 0a 23 64 65 66 69 6e 65 20 43       3.#define C
0ae0: 4f 4d 50 4c 45 54 49 4f 4e 5f 43 4f 4c 4c 41 54  OMPLETION_COLLAT
0af0: 49 4f 4e 53 20 20 20 20 34 0a 23 64 65 66 69 6e  IONS    4.#defin
0b00: 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 49 4e 44  e COMPLETION_IND
0b10: 45 58 45 53 20 20 20 20 20 20 20 35 0a 23 64 65  EXES       5.#de
0b20: 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f  fine COMPLETION_
0b30: 54 52 49 47 47 45 52 53 20 20 20 20 20 20 36 0a  TRIGGERS      6.
0b40: 23 64 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49  #define COMPLETI
0b50: 4f 4e 5f 44 41 54 41 42 41 53 45 53 20 20 20 20  ON_DATABASES    
0b60: 20 37 0a 23 64 65 66 69 6e 65 20 43 4f 4d 50 4c   7.#define COMPL
0b70: 45 54 49 4f 4e 5f 54 41 42 4c 45 53 20 20 20 20  ETION_TABLES    
0b80: 20 20 20 20 38 0a 23 64 65 66 69 6e 65 20 43 4f      8.#define CO
0b90: 4d 50 4c 45 54 49 4f 4e 5f 43 4f 4c 55 4d 4e 53  MPLETION_COLUMNS
0ba0: 20 20 20 20 20 20 20 39 0a 23 64 65 66 69 6e 65         9.#define
0bb0: 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 4d 4f 44 55   COMPLETION_MODU
0bc0: 4c 45 53 20 20 20 20 20 20 20 31 30 0a 23 64 65  LES       10.#de
0bd0: 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f  fine COMPLETION_
0be0: 45 4f 46 20 20 20 20 20 20 20 20 20 20 20 31 31  EOF           11
0bf0: 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 63 6f 6d 70  ../*.** The comp
0c00: 6c 65 74 69 6f 6e 43 6f 6e 6e 65 63 74 28 29 20  letionConnect() 
0c10: 6d 65 74 68 6f 64 20 69 73 20 69 6e 76 6f 6b 65  method is invoke
0c20: 64 20 74 6f 20 63 72 65 61 74 65 20 61 20 6e 65  d to create a ne
0c30: 77 0a 2a 2a 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f  w.** completion_
0c40: 76 74 61 62 20 74 68 61 74 20 64 65 73 63 72 69  vtab that descri
0c50: 62 65 73 20 74 68 65 20 63 6f 6d 70 6c 65 74 69  bes the completi
0c60: 6f 6e 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65  on virtual table
0c70: 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 6e 6b 20 6f 66  ..**.** Think of
0c80: 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 61 73   this routine as
0c90: 20 74 68 65 20 63 6f 6e 73 74 72 75 63 74 6f 72   the constructor
0ca0: 20 66 6f 72 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f   for completion_
0cb0: 76 74 61 62 20 6f 62 6a 65 63 74 73 2e 0a 2a 2a  vtab objects..**
0cc0: 0a 2a 2a 20 41 6c 6c 20 74 68 69 73 20 72 6f 75  .** All this rou
0cd0: 74 69 6e 65 20 6e 65 65 64 73 20 74 6f 20 64 6f  tine needs to do
0ce0: 20 69 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 28 31   is:.**.**    (1
0cf0: 29 20 41 6c 6c 6f 63 61 74 65 20 74 68 65 20 63  ) Allocate the c
0d00: 6f 6d 70 6c 65 74 69 6f 6e 5f 76 74 61 62 20 6f  ompletion_vtab o
0d10: 62 6a 65 63 74 20 61 6e 64 20 69 6e 69 74 69 61  bject and initia
0d20: 6c 69 7a 65 20 61 6c 6c 20 66 69 65 6c 64 73 2e  lize all fields.
0d30: 0a 2a 2a 0a 2a 2a 20 20 20 20 28 32 29 20 54 65  .**.**    (2) Te
0d40: 6c 6c 20 53 51 4c 69 74 65 20 28 76 69 61 20 74  ll SQLite (via t
0d50: 68 65 20 73 71 6c 69 74 65 33 5f 64 65 63 6c 61  he sqlite3_decla
0d60: 72 65 5f 76 74 61 62 28 29 20 69 6e 74 65 72 66  re_vtab() interf
0d70: 61 63 65 29 20 77 68 61 74 20 74 68 65 0a 2a 2a  ace) what the.**
0d80: 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 20 73          result s
0d90: 65 74 20 6f 66 20 71 75 65 72 69 65 73 20 61 67  et of queries ag
0da0: 61 69 6e 73 74 20 63 6f 6d 70 6c 65 74 69 6f 6e  ainst completion
0db0: 20 77 69 6c 6c 20 6c 6f 6f 6b 20 6c 69 6b 65 2e   will look like.
0dc0: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63  .*/.static int c
0dd0: 6f 6d 70 6c 65 74 69 6f 6e 43 6f 6e 6e 65 63 74  ompletionConnect
0de0: 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c  (.  sqlite3 *db,
0df0: 0a 20 20 76 6f 69 64 20 2a 70 41 75 78 2c 0a 20  .  void *pAux,. 
0e00: 20 69 6e 74 20 61 72 67 63 2c 20 63 6f 6e 73 74   int argc, const
0e10: 20 63 68 61 72 20 2a 63 6f 6e 73 74 2a 61 72 67   char *const*arg
0e20: 76 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61  v,.  sqlite3_vta
0e30: 62 20 2a 2a 70 70 56 74 61 62 2c 0a 20 20 63 68  b **ppVtab,.  ch
0e40: 61 72 20 2a 2a 70 7a 45 72 72 0a 29 7b 0a 20 20  ar **pzErr.){.  
0e50: 63 6f 6d 70 6c 65 74 69 6f 6e 5f 76 74 61 62 20  completion_vtab 
0e60: 2a 70 4e 65 77 3b 0a 20 20 69 6e 74 20 72 63 3b  *pNew;.  int rc;
0e70: 0a 0a 20 20 28 76 6f 69 64 29 28 70 41 75 78 29  ..  (void)(pAux)
0e80: 3b 20 20 20 20 2f 2a 20 55 6e 75 73 65 64 20 70  ;    /* Unused p
0e90: 61 72 61 6d 65 74 65 72 20 2a 2f 0a 20 20 28 76  arameter */.  (v
0ea0: 6f 69 64 29 28 61 72 67 63 29 3b 20 20 20 20 2f  oid)(argc);    /
0eb0: 2a 20 55 6e 75 73 65 64 20 70 61 72 61 6d 65 74  * Unused paramet
0ec0: 65 72 20 2a 2f 0a 20 20 28 76 6f 69 64 29 28 61  er */.  (void)(a
0ed0: 72 67 76 29 3b 20 20 20 20 2f 2a 20 55 6e 75 73  rgv);    /* Unus
0ee0: 65 64 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a  ed parameter */.
0ef0: 20 20 28 76 6f 69 64 29 28 70 7a 45 72 72 29 3b    (void)(pzErr);
0f00: 20 20 20 2f 2a 20 55 6e 75 73 65 64 20 70 61 72     /* Unused par
0f10: 61 6d 65 74 65 72 20 2a 2f 0a 0a 2f 2a 20 43 6f  ameter */../* Co
0f20: 6c 75 6d 6e 20 6e 75 6d 62 65 72 73 20 2a 2f 0a  lumn numbers */.
0f30: 23 64 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49  #define COMPLETI
0f40: 4f 4e 5f 43 4f 4c 55 4d 4e 5f 43 41 4e 44 49 44  ON_COLUMN_CANDID
0f50: 41 54 45 20 30 20 20 2f 2a 20 53 75 67 67 65 73  ATE 0  /* Sugges
0f60: 74 65 64 20 63 6f 6d 70 6c 65 74 69 6f 6e 20 6f  ted completion o
0f70: 66 20 74 68 65 20 69 6e 70 75 74 20 2a 2f 0a 23  f the input */.#
0f80: 64 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49 4f  define COMPLETIO
0f90: 4e 5f 43 4f 4c 55 4d 4e 5f 50 52 45 46 49 58 20  N_COLUMN_PREFIX 
0fa0: 20 20 20 31 20 20 2f 2a 20 50 72 65 66 69 78 20     1  /* Prefix 
0fb0: 6f 66 20 74 68 65 20 77 6f 72 64 20 74 6f 20 62  of the word to b
0fc0: 65 20 63 6f 6d 70 6c 65 74 65 64 20 2a 2f 0a 23  e completed */.#
0fd0: 64 65 66 69 6e 65 20 43 4f 4d 50 4c 45 54 49 4f  define COMPLETIO
0fe0: 4e 5f 43 4f 4c 55 4d 4e 5f 57 48 4f 4c 45 4c 49  N_COLUMN_WHOLELI
0ff0: 4e 45 20 32 20 20 2f 2a 20 45 6e 74 69 72 65 20  NE 2  /* Entire 
1000: 6c 69 6e 65 20 73 65 65 6e 20 73 6f 20 66 61 72  line seen so far
1010: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 43 4f 4d 50   */.#define COMP
1020: 4c 45 54 49 4f 4e 5f 43 4f 4c 55 4d 4e 5f 50 48  LETION_COLUMN_PH
1030: 41 53 45 20 20 20 20 20 33 20 20 2f 2a 20 65 50  ASE     3  /* eP
1040: 68 61 73 65 20 2d 20 75 73 65 64 20 66 6f 72 20  hase - used for 
1050: 64 65 62 75 67 67 69 6e 67 20 6f 6e 6c 79 20 2a  debugging only *
1060: 2f 0a 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  /..  rc = sqlite
1070: 33 5f 64 65 63 6c 61 72 65 5f 76 74 61 62 28 64  3_declare_vtab(d
1080: 62 2c 0a 20 20 20 20 20 20 22 43 52 45 41 54 45  b,.      "CREATE
1090: 20 54 41 42 4c 45 20 78 28 22 0a 20 20 20 20 20   TABLE x(".     
10a0: 20 22 20 20 63 61 6e 64 69 64 61 74 65 20 54 45   "  candidate TE
10b0: 58 54 2c 22 0a 20 20 20 20 20 20 22 20 20 70 72  XT,".      "  pr
10c0: 65 66 69 78 20 54 45 58 54 20 48 49 44 44 45 4e  efix TEXT HIDDEN
10d0: 2c 22 0a 20 20 20 20 20 20 22 20 20 77 68 6f 6c  ,".      "  whol
10e0: 65 6c 69 6e 65 20 54 45 58 54 20 48 49 44 44 45  eline TEXT HIDDE
10f0: 4e 2c 22 0a 20 20 20 20 20 20 22 20 20 70 68 61  N,".      "  pha
1100: 73 65 20 49 4e 54 20 48 49 44 44 45 4e 22 20 20  se INT HIDDEN"  
1110: 20 20 20 20 20 20 2f 2a 20 55 73 65 64 20 66 6f        /* Used fo
1120: 72 20 64 65 62 75 67 67 69 6e 67 20 6f 6e 6c 79  r debugging only
1130: 20 2a 2f 0a 20 20 20 20 20 20 22 29 22 29 3b 0a   */.      ")");.
1140: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
1150: 5f 4f 4b 20 29 7b 0a 20 20 20 20 70 4e 65 77 20  _OK ){.    pNew 
1160: 3d 20 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63  = sqlite3_malloc
1170: 28 20 73 69 7a 65 6f 66 28 2a 70 4e 65 77 29 20  ( sizeof(*pNew) 
1180: 29 3b 0a 20 20 20 20 2a 70 70 56 74 61 62 20 3d  );.    *ppVtab =
1190: 20 28 73 71 6c 69 74 65 33 5f 76 74 61 62 2a 29   (sqlite3_vtab*)
11a0: 70 4e 65 77 3b 0a 20 20 20 20 69 66 28 20 70 4e  pNew;.    if( pN
11b0: 65 77 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53  ew==0 ) return S
11c0: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20  QLITE_NOMEM;.   
11d0: 20 6d 65 6d 73 65 74 28 70 4e 65 77 2c 20 30 2c   memset(pNew, 0,
11e0: 20 73 69 7a 65 6f 66 28 2a 70 4e 65 77 29 29 3b   sizeof(*pNew));
11f0: 0a 20 20 20 20 70 4e 65 77 2d 3e 64 62 20 3d 20  .    pNew->db = 
1200: 64 62 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  db;.  }.  return
1210: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68   rc;.}../*.** Th
1220: 69 73 20 6d 65 74 68 6f 64 20 69 73 20 74 68 65  is method is the
1230: 20 64 65 73 74 72 75 63 74 6f 72 20 66 6f 72 20   destructor for 
1240: 63 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f  completion_curso
1250: 72 20 6f 62 6a 65 63 74 73 2e 0a 2a 2f 0a 73 74  r objects..*/.st
1260: 61 74 69 63 20 69 6e 74 20 63 6f 6d 70 6c 65 74  atic int complet
1270: 69 6f 6e 44 69 73 63 6f 6e 6e 65 63 74 28 73 71  ionDisconnect(sq
1280: 6c 69 74 65 33 5f 76 74 61 62 20 2a 70 56 74 61  lite3_vtab *pVta
1290: 62 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 72  b){.  sqlite3_fr
12a0: 65 65 28 70 56 74 61 62 29 3b 0a 20 20 72 65 74  ee(pVtab);.  ret
12b0: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
12c0: 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 73 74 72 75 63  ../*.** Construc
12d0: 74 6f 72 20 66 6f 72 20 61 20 6e 65 77 20 63 6f  tor for a new co
12e0: 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 20  mpletion_cursor 
12f0: 6f 62 6a 65 63 74 2e 0a 2a 2f 0a 73 74 61 74 69  object..*/.stati
1300: 63 20 69 6e 74 20 63 6f 6d 70 6c 65 74 69 6f 6e  c int completion
1310: 4f 70 65 6e 28 73 71 6c 69 74 65 33 5f 76 74 61  Open(sqlite3_vta
1320: 62 20 2a 70 2c 20 73 71 6c 69 74 65 33 5f 76 74  b *p, sqlite3_vt
1330: 61 62 5f 63 75 72 73 6f 72 20 2a 2a 70 70 43 75  ab_cursor **ppCu
1340: 72 73 6f 72 29 7b 0a 20 20 63 6f 6d 70 6c 65 74  rsor){.  complet
1350: 69 6f 6e 5f 63 75 72 73 6f 72 20 2a 70 43 75 72  ion_cursor *pCur
1360: 3b 0a 20 20 70 43 75 72 20 3d 20 73 71 6c 69 74  ;.  pCur = sqlit
1370: 65 33 5f 6d 61 6c 6c 6f 63 28 20 73 69 7a 65 6f  e3_malloc( sizeo
1380: 66 28 2a 70 43 75 72 29 20 29 3b 0a 20 20 69 66  f(*pCur) );.  if
1390: 28 20 70 43 75 72 3d 3d 30 20 29 20 72 65 74 75  ( pCur==0 ) retu
13a0: 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b  rn SQLITE_NOMEM;
13b0: 0a 20 20 6d 65 6d 73 65 74 28 70 43 75 72 2c 20  .  memset(pCur, 
13c0: 30 2c 20 73 69 7a 65 6f 66 28 2a 70 43 75 72 29  0, sizeof(*pCur)
13d0: 29 3b 0a 20 20 70 43 75 72 2d 3e 64 62 20 3d 20  );.  pCur->db = 
13e0: 28 28 63 6f 6d 70 6c 65 74 69 6f 6e 5f 76 74 61  ((completion_vta
13f0: 62 2a 29 70 29 2d 3e 64 62 3b 0a 20 20 2a 70 70  b*)p)->db;.  *pp
1400: 43 75 72 73 6f 72 20 3d 20 26 70 43 75 72 2d 3e  Cursor = &pCur->
1410: 62 61 73 65 3b 0a 20 20 72 65 74 75 72 6e 20 53  base;.  return S
1420: 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a  QLITE_OK;.}../*.
1430: 2a 2a 20 52 65 73 65 74 20 74 68 65 20 63 6f 6d  ** Reset the com
1440: 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 2e 0a  pletion_cursor..
1450: 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 63  */.static void c
1460: 6f 6d 70 6c 65 74 69 6f 6e 43 75 72 73 6f 72 52  ompletionCursorR
1470: 65 73 65 74 28 63 6f 6d 70 6c 65 74 69 6f 6e 5f  eset(completion_
1480: 63 75 72 73 6f 72 20 2a 70 43 75 72 29 7b 0a 20  cursor *pCur){. 
1490: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 43   sqlite3_free(pC
14a0: 75 72 2d 3e 7a 50 72 65 66 69 78 29 3b 20 20 20  ur->zPrefix);   
14b0: 70 43 75 72 2d 3e 7a 50 72 65 66 69 78 20 3d 20  pCur->zPrefix = 
14c0: 30 3b 20 20 70 43 75 72 2d 3e 6e 50 72 65 66 69  0;  pCur->nPrefi
14d0: 78 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65 33  x = 0;.  sqlite3
14e0: 5f 66 72 65 65 28 70 43 75 72 2d 3e 7a 4c 69 6e  _free(pCur->zLin
14f0: 65 29 3b 20 20 20 20 20 70 43 75 72 2d 3e 7a 4c  e);     pCur->zL
1500: 69 6e 65 20 3d 20 30 3b 20 20 20 20 70 43 75 72  ine = 0;    pCur
1510: 2d 3e 6e 4c 69 6e 65 20 3d 20 30 3b 0a 20 20 73  ->nLine = 0;.  s
1520: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
1530: 70 43 75 72 2d 3e 70 53 74 6d 74 29 3b 20 70 43  pCur->pStmt); pC
1540: 75 72 2d 3e 70 53 74 6d 74 20 3d 20 30 3b 0a 20  ur->pStmt = 0;. 
1550: 20 70 43 75 72 2d 3e 6a 20 3d 20 30 3b 0a 7d 0a   pCur->j = 0;.}.
1560: 0a 2f 2a 0a 2a 2a 20 44 65 73 74 72 75 63 74 6f  ./*.** Destructo
1570: 72 20 66 6f 72 20 61 20 63 6f 6d 70 6c 65 74 69  r for a completi
1580: 6f 6e 5f 63 75 72 73 6f 72 2e 0a 2a 2f 0a 73 74  on_cursor..*/.st
1590: 61 74 69 63 20 69 6e 74 20 63 6f 6d 70 6c 65 74  atic int complet
15a0: 69 6f 6e 43 6c 6f 73 65 28 73 71 6c 69 74 65 33  ionClose(sqlite3
15b0: 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 63 75  _vtab_cursor *cu
15c0: 72 29 7b 0a 20 20 63 6f 6d 70 6c 65 74 69 6f 6e  r){.  completion
15d0: 43 75 72 73 6f 72 52 65 73 65 74 28 28 63 6f 6d  CursorReset((com
15e0: 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 2a 29  pletion_cursor*)
15f0: 63 75 72 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f  cur);.  sqlite3_
1600: 66 72 65 65 28 63 75 72 29 3b 0a 20 20 72 65 74  free(cur);.  ret
1610: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
1620: 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c 20 53 51 4c 20  ../*.** All SQL 
1630: 6b 65 79 77 6f 72 64 73 20 75 6e 64 65 72 73 74  keywords underst
1640: 6f 6f 64 20 62 79 20 53 51 4c 69 74 65 0a 2a 2f  ood by SQLite.*/
1650: 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68  .static const ch
1660: 61 72 20 2a 63 6f 6d 70 6c 65 74 69 6f 6e 4b 77  ar *completionKw
1670: 72 64 73 5b 5d 20 3d 20 7b 0a 20 20 22 41 42 4f  rds[] = {.  "ABO
1680: 52 54 22 2c 20 22 41 43 54 49 4f 4e 22 2c 20 22  RT", "ACTION", "
1690: 41 44 44 22 2c 20 22 41 46 54 45 52 22 2c 20 22  ADD", "AFTER", "
16a0: 41 4c 4c 22 2c 20 22 41 4c 54 45 52 22 2c 20 22  ALL", "ALTER", "
16b0: 41 4e 41 4c 59 5a 45 22 2c 20 22 41 4e 44 22 2c  ANALYZE", "AND",
16c0: 20 22 41 53 22 2c 0a 20 20 22 41 53 43 22 2c 20   "AS",.  "ASC", 
16d0: 22 41 54 54 41 43 48 22 2c 20 22 41 55 54 4f 49  "ATTACH", "AUTOI
16e0: 4e 43 52 45 4d 45 4e 54 22 2c 20 22 42 45 46 4f  NCREMENT", "BEFO
16f0: 52 45 22 2c 20 22 42 45 47 49 4e 22 2c 20 22 42  RE", "BEGIN", "B
1700: 45 54 57 45 45 4e 22 2c 20 22 42 59 22 2c 0a 20  ETWEEN", "BY",. 
1710: 20 22 43 41 53 43 41 44 45 22 2c 20 22 43 41 53   "CASCADE", "CAS
1720: 45 22 2c 20 22 43 41 53 54 22 2c 20 22 43 48 45  E", "CAST", "CHE
1730: 43 4b 22 2c 20 22 43 4f 4c 4c 41 54 45 22 2c 20  CK", "COLLATE", 
1740: 22 43 4f 4c 55 4d 4e 22 2c 20 22 43 4f 4d 4d 49  "COLUMN", "COMMI
1750: 54 22 2c 0a 20 20 22 43 4f 4e 46 4c 49 43 54 22  T",.  "CONFLICT"
1760: 2c 20 22 43 4f 4e 53 54 52 41 49 4e 54 22 2c 20  , "CONSTRAINT", 
1770: 22 43 52 45 41 54 45 22 2c 20 22 43 52 4f 53 53  "CREATE", "CROSS
1780: 22 2c 20 22 43 55 52 52 45 4e 54 5f 44 41 54 45  ", "CURRENT_DATE
1790: 22 2c 0a 20 20 22 43 55 52 52 45 4e 54 5f 54 49  ",.  "CURRENT_TI
17a0: 4d 45 22 2c 20 22 43 55 52 52 45 4e 54 5f 54 49  ME", "CURRENT_TI
17b0: 4d 45 53 54 41 4d 50 22 2c 20 22 44 41 54 41 42  MESTAMP", "DATAB
17c0: 41 53 45 22 2c 20 22 44 45 46 41 55 4c 54 22 2c  ASE", "DEFAULT",
17d0: 20 22 44 45 46 45 52 52 41 42 4c 45 22 2c 0a 20   "DEFERRABLE",. 
17e0: 20 22 44 45 46 45 52 52 45 44 22 2c 20 22 44 45   "DEFERRED", "DE
17f0: 4c 45 54 45 22 2c 20 22 44 45 53 43 22 2c 20 22  LETE", "DESC", "
1800: 44 45 54 41 43 48 22 2c 20 22 44 49 53 54 49 4e  DETACH", "DISTIN
1810: 43 54 22 2c 20 22 44 52 4f 50 22 2c 20 22 45 41  CT", "DROP", "EA
1820: 43 48 22 2c 0a 20 20 22 45 4c 53 45 22 2c 20 22  CH",.  "ELSE", "
1830: 45 4e 44 22 2c 20 22 45 53 43 41 50 45 22 2c 20  END", "ESCAPE", 
1840: 22 45 58 43 45 50 54 22 2c 20 22 45 58 43 4c 55  "EXCEPT", "EXCLU
1850: 53 49 56 45 22 2c 20 22 45 58 49 53 54 53 22 2c  SIVE", "EXISTS",
1860: 20 22 45 58 50 4c 41 49 4e 22 2c 0a 20 20 22 46   "EXPLAIN",.  "F
1870: 41 49 4c 22 2c 20 22 46 4f 52 22 2c 20 22 46 4f  AIL", "FOR", "FO
1880: 52 45 49 47 4e 22 2c 20 22 46 52 4f 4d 22 2c 20  REIGN", "FROM", 
1890: 22 46 55 4c 4c 22 2c 20 22 47 4c 4f 42 22 2c 20  "FULL", "GLOB", 
18a0: 22 47 52 4f 55 50 22 2c 20 22 48 41 56 49 4e 47  "GROUP", "HAVING
18b0: 22 2c 20 22 49 46 22 2c 0a 20 20 22 49 47 4e 4f  ", "IF",.  "IGNO
18c0: 52 45 22 2c 20 22 49 4d 4d 45 44 49 41 54 45 22  RE", "IMMEDIATE"
18d0: 2c 20 22 49 4e 22 2c 20 22 49 4e 44 45 58 22 2c  , "IN", "INDEX",
18e0: 20 22 49 4e 44 45 58 45 44 22 2c 20 22 49 4e 49   "INDEXED", "INI
18f0: 54 49 41 4c 4c 59 22 2c 20 22 49 4e 4e 45 52 22  TIALLY", "INNER"
1900: 2c 0a 20 20 22 49 4e 53 45 52 54 22 2c 20 22 49  ,.  "INSERT", "I
1910: 4e 53 54 45 41 44 22 2c 20 22 49 4e 54 45 52 53  NSTEAD", "INTERS
1920: 45 43 54 22 2c 20 22 49 4e 54 4f 22 2c 20 22 49  ECT", "INTO", "I
1930: 53 22 2c 20 22 49 53 4e 55 4c 4c 22 2c 20 22 4a  S", "ISNULL", "J
1940: 4f 49 4e 22 2c 20 22 4b 45 59 22 2c 0a 20 20 22  OIN", "KEY",.  "
1950: 4c 45 46 54 22 2c 20 22 4c 49 4b 45 22 2c 20 22  LEFT", "LIKE", "
1960: 4c 49 4d 49 54 22 2c 20 22 4d 41 54 43 48 22 2c  LIMIT", "MATCH",
1970: 20 22 4e 41 54 55 52 41 4c 22 2c 20 22 4e 4f 22   "NATURAL", "NO"
1980: 2c 20 22 4e 4f 54 22 2c 20 22 4e 4f 54 4e 55 4c  , "NOT", "NOTNUL
1990: 4c 22 2c 0a 20 20 22 4e 55 4c 4c 22 2c 20 22 4f  L",.  "NULL", "O
19a0: 46 22 2c 20 22 4f 46 46 53 45 54 22 2c 20 22 4f  F", "OFFSET", "O
19b0: 4e 22 2c 20 22 4f 52 22 2c 20 22 4f 52 44 45 52  N", "OR", "ORDER
19c0: 22 2c 20 22 4f 55 54 45 52 22 2c 20 22 50 4c 41  ", "OUTER", "PLA
19d0: 4e 22 2c 20 22 50 52 41 47 4d 41 22 2c 0a 20 20  N", "PRAGMA",.  
19e0: 22 50 52 49 4d 41 52 59 22 2c 20 22 51 55 45 52  "PRIMARY", "QUER
19f0: 59 22 2c 20 22 52 41 49 53 45 22 2c 20 22 52 45  Y", "RAISE", "RE
1a00: 43 55 52 53 49 56 45 22 2c 20 22 52 45 46 45 52  CURSIVE", "REFER
1a10: 45 4e 43 45 53 22 2c 20 22 52 45 47 45 58 50 22  ENCES", "REGEXP"
1a20: 2c 0a 20 20 22 52 45 49 4e 44 45 58 22 2c 20 22  ,.  "REINDEX", "
1a30: 52 45 4c 45 41 53 45 22 2c 20 22 52 45 4e 41 4d  RELEASE", "RENAM
1a40: 45 22 2c 20 22 52 45 50 4c 41 43 45 22 2c 20 22  E", "REPLACE", "
1a50: 52 45 53 54 52 49 43 54 22 2c 20 22 52 49 47 48  RESTRICT", "RIGH
1a60: 54 22 2c 0a 20 20 22 52 4f 4c 4c 42 41 43 4b 22  T",.  "ROLLBACK"
1a70: 2c 20 22 52 4f 57 22 2c 20 22 53 41 56 45 50 4f  , "ROW", "SAVEPO
1a80: 49 4e 54 22 2c 20 22 53 45 4c 45 43 54 22 2c 20  INT", "SELECT", 
1a90: 22 53 45 54 22 2c 20 22 54 41 42 4c 45 22 2c 20  "SET", "TABLE", 
1aa0: 22 54 45 4d 50 22 2c 0a 20 20 22 54 45 4d 50 4f  "TEMP",.  "TEMPO
1ab0: 52 41 52 59 22 2c 20 22 54 48 45 4e 22 2c 20 22  RARY", "THEN", "
1ac0: 54 4f 22 2c 20 22 54 52 41 4e 53 41 43 54 49 4f  TO", "TRANSACTIO
1ad0: 4e 22 2c 20 22 54 52 49 47 47 45 52 22 2c 20 22  N", "TRIGGER", "
1ae0: 55 4e 49 4f 4e 22 2c 20 22 55 4e 49 51 55 45 22  UNION", "UNIQUE"
1af0: 2c 0a 20 20 22 55 50 44 41 54 45 22 2c 20 22 55  ,.  "UPDATE", "U
1b00: 53 49 4e 47 22 2c 20 22 56 41 43 55 55 4d 22 2c  SING", "VACUUM",
1b10: 20 22 56 41 4c 55 45 53 22 2c 20 22 56 49 45 57   "VALUES", "VIEW
1b20: 22 2c 20 22 56 49 52 54 55 41 4c 22 2c 20 22 57  ", "VIRTUAL", "W
1b30: 48 45 4e 22 2c 20 22 57 48 45 52 45 22 2c 0a 20  HEN", "WHERE",. 
1b40: 20 22 57 49 54 48 22 2c 20 22 57 49 54 48 4f 55   "WITH", "WITHOU
1b50: 54 22 2c 0a 7d 3b 0a 23 64 65 66 69 6e 65 20 63  T",.};.#define c
1b60: 6f 6d 70 6c 65 74 69 6f 6e 4b 77 43 6f 75 6e 74  ompletionKwCount
1b70: 20 5c 0a 20 20 20 28 69 6e 74 29 28 73 69 7a 65   \.   (int)(size
1b80: 6f 66 28 63 6f 6d 70 6c 65 74 69 6f 6e 4b 77 72  of(completionKwr
1b90: 64 73 29 2f 73 69 7a 65 6f 66 28 63 6f 6d 70 6c  ds)/sizeof(compl
1ba0: 65 74 69 6f 6e 4b 77 72 64 73 5b 30 5d 29 29 0a  etionKwrds[0])).
1bb0: 0a 2f 2a 0a 2a 2a 20 41 64 76 61 6e 63 65 20 61  ./*.** Advance a
1bc0: 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73   completion_curs
1bd0: 6f 72 20 74 6f 20 69 74 73 20 6e 65 78 74 20 72  or to its next r
1be0: 6f 77 20 6f 66 20 6f 75 74 70 75 74 2e 0a 2a 2a  ow of output..**
1bf0: 0a 2a 2a 20 54 68 65 20 2d 3e 65 50 68 61 73 65  .** The ->ePhase
1c00: 2c 20 2d 3e 6a 2c 20 61 6e 64 20 2d 3e 70 53 74  , ->j, and ->pSt
1c10: 6d 74 20 66 69 65 6c 64 73 20 6f 66 20 74 68 65  mt fields of the
1c20: 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73   completion_curs
1c30: 6f 72 20 6f 62 6a 65 63 74 0a 2a 2a 20 72 65 63  or object.** rec
1c40: 6f 72 64 20 74 68 65 20 63 75 72 72 65 6e 74 20  ord the current 
1c50: 73 74 61 74 65 20 6f 66 20 74 68 65 20 73 63 61  state of the sca
1c60: 6e 2e 20 20 54 68 69 73 20 72 6f 75 74 69 6e 65  n.  This routine
1c70: 20 73 65 74 73 20 2d 3e 7a 43 75 72 72 65 6e 74   sets ->zCurrent
1c80: 52 6f 77 0a 2a 2a 20 74 6f 20 74 68 65 20 63 75  Row.** to the cu
1c90: 72 72 65 6e 74 20 72 6f 77 20 6f 66 20 6f 75 74  rrent row of out
1ca0: 70 75 74 20 61 6e 64 20 74 68 65 6e 20 72 65 74  put and then ret
1cb0: 75 72 6e 73 2e 20 20 49 66 20 6e 6f 20 6d 6f 72  urns.  If no mor
1cc0: 65 20 72 6f 77 73 20 72 65 6d 61 69 6e 2c 0a 2a  e rows remain,.*
1cd0: 2a 20 74 68 65 6e 20 2d 3e 65 50 68 61 73 65 20  * then ->ePhase 
1ce0: 69 73 20 73 65 74 20 74 6f 20 43 4f 4d 50 4c 45  is set to COMPLE
1cf0: 54 49 4f 4e 5f 45 4f 46 20 77 68 69 63 68 20 77  TION_EOF which w
1d00: 69 6c 6c 20 73 69 67 6e 61 6c 20 74 68 65 20 76  ill signal the v
1d10: 69 72 74 75 61 6c 0a 2a 2a 20 74 61 62 6c 65 20  irtual.** table 
1d20: 74 68 61 74 20 68 61 73 20 72 65 61 63 68 65 64  that has reached
1d30: 20 74 68 65 20 65 6e 64 20 6f 66 20 69 74 73 20   the end of its 
1d40: 73 63 61 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20  scan..**.** The 
1d50: 63 75 72 72 65 6e 74 20 69 6d 70 6c 65 6d 65 6e  current implemen
1d60: 74 61 74 69 6f 6e 20 6a 75 73 74 20 6c 69 73 74  tation just list
1d70: 73 20 70 6f 74 65 6e 74 69 61 6c 20 69 64 65 6e  s potential iden
1d80: 74 69 66 69 65 72 73 20 61 6e 64 0a 2a 2a 20 6b  tifiers and.** k
1d90: 65 79 77 6f 72 64 73 20 61 6e 64 20 66 69 6c 74  eywords and filt
1da0: 65 72 73 20 74 68 65 6d 20 62 79 20 7a 50 72 65  ers them by zPre
1db0: 66 69 78 2e 20 20 46 75 74 75 72 65 20 65 6e 68  fix.  Future enh
1dc0: 61 6e 63 65 6d 65 6e 74 73 20 73 68 6f 75 6c 64  ancements should
1dd0: 0a 2a 2a 20 74 61 6b 65 20 7a 4c 69 6e 65 20 69  .** take zLine i
1de0: 6e 74 6f 20 61 63 63 6f 75 6e 74 20 74 6f 20 74  nto account to t
1df0: 72 79 20 74 6f 20 72 65 73 74 72 69 63 74 20 74  ry to restrict t
1e00: 68 65 20 73 65 74 20 6f 66 20 69 64 65 6e 74 69  he set of identi
1e10: 66 69 65 72 73 20 61 6e 64 0a 2a 2a 20 6b 65 79  fiers and.** key
1e20: 77 6f 72 64 73 20 62 61 73 65 64 20 6f 6e 20 77  words based on w
1e30: 68 61 74 20 77 6f 75 6c 64 20 62 65 20 6c 65 67  hat would be leg
1e40: 61 6c 20 61 74 20 74 68 65 20 63 75 72 72 65 6e  al at the curren
1e50: 74 20 70 6f 69 6e 74 20 6f 66 20 69 6e 70 75 74  t point of input
1e60: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
1e70: 63 6f 6d 70 6c 65 74 69 6f 6e 4e 65 78 74 28 73  completionNext(s
1e80: 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73  qlite3_vtab_curs
1e90: 6f 72 20 2a 63 75 72 29 7b 0a 20 20 63 6f 6d 70  or *cur){.  comp
1ea0: 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 20 2a 70  letion_cursor *p
1eb0: 43 75 72 20 3d 20 28 63 6f 6d 70 6c 65 74 69 6f  Cur = (completio
1ec0: 6e 5f 63 75 72 73 6f 72 2a 29 63 75 72 3b 0a 20  n_cursor*)cur;. 
1ed0: 20 69 6e 74 20 65 4e 65 78 74 50 68 61 73 65 20   int eNextPhase 
1ee0: 3d 20 30 3b 20 20 2f 2a 20 4e 65 78 74 20 70 68  = 0;  /* Next ph
1ef0: 61 73 65 20 74 6f 20 74 72 79 20 69 66 20 63 75  ase to try if cu
1f00: 72 72 65 6e 74 20 70 68 61 73 65 20 72 65 61 63  rrent phase reac
1f10: 68 65 73 20 65 6e 64 20 2a 2f 0a 20 20 69 6e 74  hes end */.  int
1f20: 20 69 43 6f 6c 20 3d 20 2d 31 3b 20 20 20 20 20   iCol = -1;     
1f30: 20 20 2f 2a 20 49 66 20 3e 3d 30 2c 20 73 74 65    /* If >=0, ste
1f40: 70 20 70 43 75 72 2d 3e 70 53 74 6d 74 20 61 6e  p pCur->pStmt an
1f50: 64 20 75 73 65 20 74 68 65 20 69 2d 74 68 20 63  d use the i-th c
1f60: 6f 6c 75 6d 6e 20 2a 2f 0a 20 20 70 43 75 72 2d  olumn */.  pCur-
1f70: 3e 69 52 6f 77 69 64 2b 2b 3b 0a 20 20 77 68 69  >iRowid++;.  whi
1f80: 6c 65 28 20 70 43 75 72 2d 3e 65 50 68 61 73 65  le( pCur->ePhase
1f90: 21 3d 43 4f 4d 50 4c 45 54 49 4f 4e 5f 45 4f 46  !=COMPLETION_EOF
1fa0: 20 29 7b 0a 20 20 20 20 73 77 69 74 63 68 28 20   ){.    switch( 
1fb0: 70 43 75 72 2d 3e 65 50 68 61 73 65 20 29 7b 0a  pCur->ePhase ){.
1fc0: 20 20 20 20 20 20 63 61 73 65 20 43 4f 4d 50 4c        case COMPL
1fd0: 45 54 49 4f 4e 5f 4b 45 59 57 4f 52 44 53 3a 20  ETION_KEYWORDS: 
1fe0: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 43  {.        if( pC
1ff0: 75 72 2d 3e 6a 20 3e 3d 20 63 6f 6d 70 6c 65 74  ur->j >= complet
2000: 69 6f 6e 4b 77 43 6f 75 6e 74 20 29 7b 0a 20 20  ionKwCount ){.  
2010: 20 20 20 20 20 20 20 20 70 43 75 72 2d 3e 7a 43          pCur->zC
2020: 75 72 72 65 6e 74 52 6f 77 20 3d 20 30 3b 0a 20  urrentRow = 0;. 
2030: 20 20 20 20 20 20 20 20 20 70 43 75 72 2d 3e 65           pCur->e
2040: 50 68 61 73 65 20 3d 20 43 4f 4d 50 4c 45 54 49  Phase = COMPLETI
2050: 4f 4e 5f 44 41 54 41 42 41 53 45 53 3b 0a 20 20  ON_DATABASES;.  
2060: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
2070: 20 20 20 20 20 20 20 70 43 75 72 2d 3e 7a 43 75         pCur->zCu
2080: 72 72 65 6e 74 52 6f 77 20 3d 20 63 6f 6d 70 6c  rrentRow = compl
2090: 65 74 69 6f 6e 4b 77 72 64 73 5b 70 43 75 72 2d  etionKwrds[pCur-
20a0: 3e 6a 2b 2b 5d 3b 0a 20 20 20 20 20 20 20 20 7d  >j++];.        }
20b0: 0a 20 20 20 20 20 20 20 20 69 43 6f 6c 20 3d 20  .        iCol = 
20c0: 2d 31 3b 0a 20 20 20 20 20 20 20 20 62 72 65 61  -1;.        brea
20d0: 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  k;.      }.     
20e0: 20 63 61 73 65 20 43 4f 4d 50 4c 45 54 49 4f 4e   case COMPLETION
20f0: 5f 44 41 54 41 42 41 53 45 53 3a 20 7b 0a 20 20  _DATABASES: {.  
2100: 20 20 20 20 20 20 69 66 28 20 70 43 75 72 2d 3e        if( pCur->
2110: 70 53 74 6d 74 3d 3d 30 20 29 7b 0a 20 20 20 20  pStmt==0 ){.    
2120: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 70 72        sqlite3_pr
2130: 65 70 61 72 65 5f 76 32 28 70 43 75 72 2d 3e 64  epare_v2(pCur->d
2140: 62 2c 20 22 50 52 41 47 4d 41 20 64 61 74 61 62  b, "PRAGMA datab
2150: 61 73 65 5f 6c 69 73 74 22 2c 20 2d 31 2c 0a 20  ase_list", -1,. 
2160: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2170: 20 20 20 20 20 20 20 20 20 20 20 20 26 70 43 75              &pCu
2180: 72 2d 3e 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20  r->pStmt, 0);.  
2190: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
21a0: 69 43 6f 6c 20 3d 20 31 3b 0a 20 20 20 20 20 20  iCol = 1;.      
21b0: 20 20 65 4e 65 78 74 50 68 61 73 65 20 3d 20 43    eNextPhase = C
21c0: 4f 4d 50 4c 45 54 49 4f 4e 5f 54 41 42 4c 45 53  OMPLETION_TABLES
21d0: 3b 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b  ;.        break;
21e0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 63  .      }.      c
21f0: 61 73 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 54  ase COMPLETION_T
2200: 41 42 4c 45 53 3a 20 7b 0a 20 20 20 20 20 20 20  ABLES: {.       
2210: 20 69 66 28 20 70 43 75 72 2d 3e 70 53 74 6d 74   if( pCur->pStmt
2220: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ==0 ){.         
2230: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
2240: 53 32 3b 0a 20 20 20 20 20 20 20 20 20 20 63 68  S2;.          ch
2250: 61 72 20 2a 7a 53 71 6c 20 3d 20 30 3b 0a 20 20  ar *zSql = 0;.  
2260: 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68          const ch
2270: 61 72 20 2a 7a 53 65 70 20 3d 20 22 22 3b 0a 20  ar *zSep = "";. 
2280: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
2290: 5f 70 72 65 70 61 72 65 5f 76 32 28 70 43 75 72  _prepare_v2(pCur
22a0: 2d 3e 64 62 2c 20 22 50 52 41 47 4d 41 20 64 61  ->db, "PRAGMA da
22b0: 74 61 62 61 73 65 5f 6c 69 73 74 22 2c 20 2d 31  tabase_list", -1
22c0: 2c 20 26 70 53 32 2c 20 30 29 3b 0a 20 20 20 20  , &pS2, 0);.    
22d0: 20 20 20 20 20 20 77 68 69 6c 65 28 20 73 71 6c        while( sql
22e0: 69 74 65 33 5f 73 74 65 70 28 70 53 32 29 3d 3d  ite3_step(pS2)==
22f0: 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20  SQLITE_ROW ){.  
2300: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20            const 
2310: 63 68 61 72 20 2a 7a 44 62 20 3d 20 28 63 6f 6e  char *zDb = (con
2320: 73 74 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33  st char*)sqlite3
2330: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 53 32  _column_text(pS2
2340: 2c 20 31 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 1);.          
2350: 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33    zSql = sqlite3
2360: 5f 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20 20  _mprintf(.      
2370: 20 20 20 20 20 20 20 20 20 22 25 7a 25 73 22 0a           "%z%s".
2380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
2390: 53 45 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d  SELECT name FROM
23a0: 20 5c 22 25 77 5c 22 2e 73 71 6c 69 74 65 5f 6d   \"%w\".sqlite_m
23b0: 61 73 74 65 72 22 0a 20 20 20 20 20 20 20 20 20  aster".         
23c0: 20 20 20 20 20 20 22 20 57 48 45 52 45 20 74 79        " WHERE ty
23d0: 70 65 3d 27 74 61 62 6c 65 27 22 2c 0a 20 20 20  pe='table'",.   
23e0: 20 20 20 20 20 20 20 20 20 20 20 20 7a 53 71 6c              zSql
23f0: 2c 20 7a 53 65 70 2c 20 7a 44 62 0a 20 20 20 20  , zSep, zDb.    
2400: 20 20 20 20 20 20 20 20 29 3b 0a 20 20 20 20 20          );.     
2410: 20 20 20 20 20 20 20 69 66 28 20 7a 53 71 6c 3d         if( zSql=
2420: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  =0 ) return SQLI
2430: 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20 20  TE_NOMEM;.      
2440: 20 20 20 20 20 20 7a 53 65 70 20 3d 20 22 20 55        zSep = " U
2450: 4e 49 4f 4e 20 22 3b 0a 20 20 20 20 20 20 20 20  NION ";.        
2460: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 73 71    }.          sq
2470: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
2480: 53 32 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73  S2);.          s
2490: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
24a0: 32 28 70 43 75 72 2d 3e 64 62 2c 20 7a 53 71 6c  2(pCur->db, zSql
24b0: 2c 20 2d 31 2c 20 26 70 43 75 72 2d 3e 70 53 74  , -1, &pCur->pSt
24c0: 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  mt, 0);.        
24d0: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
24e0: 53 71 6c 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  Sql);.        }.
24f0: 20 20 20 20 20 20 20 20 69 43 6f 6c 20 3d 20 30          iCol = 0
2500: 3b 0a 20 20 20 20 20 20 20 20 65 4e 65 78 74 50  ;.        eNextP
2510: 68 61 73 65 20 3d 20 43 4f 4d 50 4c 45 54 49 4f  hase = COMPLETIO
2520: 4e 5f 43 4f 4c 55 4d 4e 53 3b 0a 20 20 20 20 20  N_COLUMNS;.     
2530: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
2540: 7d 0a 20 20 20 20 20 20 63 61 73 65 20 43 4f 4d  }.      case COM
2550: 50 4c 45 54 49 4f 4e 5f 43 4f 4c 55 4d 4e 53 3a  PLETION_COLUMNS:
2560: 20 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70   {.        if( p
2570: 43 75 72 2d 3e 70 53 74 6d 74 3d 3d 30 20 29 7b  Cur->pStmt==0 ){
2580: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
2590: 65 33 5f 73 74 6d 74 20 2a 70 53 32 3b 0a 20 20  e3_stmt *pS2;.  
25a0: 20 20 20 20 20 20 20 20 63 68 61 72 20 2a 7a 53          char *zS
25b0: 71 6c 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  ql = 0;.        
25c0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53    const char *zS
25d0: 65 70 20 3d 20 22 22 3b 0a 20 20 20 20 20 20 20  ep = "";.       
25e0: 20 20 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61     sqlite3_prepa
25f0: 72 65 5f 76 32 28 70 43 75 72 2d 3e 64 62 2c 20  re_v2(pCur->db, 
2600: 22 50 52 41 47 4d 41 20 64 61 74 61 62 61 73 65  "PRAGMA database
2610: 5f 6c 69 73 74 22 2c 20 2d 31 2c 20 26 70 53 32  _list", -1, &pS2
2620: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 0);.          
2630: 77 68 69 6c 65 28 20 73 71 6c 69 74 65 33 5f 73  while( sqlite3_s
2640: 74 65 70 28 70 53 32 29 3d 3d 53 51 4c 49 54 45  tep(pS2)==SQLITE
2650: 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 20 20  _ROW ){.        
2660: 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a      const char *
2670: 7a 44 62 20 3d 20 28 63 6f 6e 73 74 20 63 68 61  zDb = (const cha
2680: 72 2a 29 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  r*)sqlite3_colum
2690: 6e 5f 74 65 78 74 28 70 53 32 2c 20 31 29 3b 0a  n_text(pS2, 1);.
26a0: 20 20 20 20 20 20 20 20 20 20 20 20 7a 53 71 6c              zSql
26b0: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e   = sqlite3_mprin
26c0: 74 66 28 0a 20 20 20 20 20 20 20 20 20 20 20 20  tf(.            
26d0: 20 20 20 22 25 7a 25 73 22 0a 20 20 20 20 20 20     "%z%s".      
26e0: 20 20 20 20 20 20 20 20 20 22 53 45 4c 45 43 54           "SELECT
26f0: 20 70 74 69 2e 6e 61 6d 65 20 46 52 4f 4d 20 5c   pti.name FROM \
2700: 22 25 77 5c 22 2e 73 71 6c 69 74 65 5f 6d 61 73  "%w\".sqlite_mas
2710: 74 65 72 20 41 53 20 73 6d 22 0a 20 20 20 20 20  ter AS sm".     
2720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2730: 20 20 22 20 4a 4f 49 4e 20 70 72 61 67 6d 61 5f    " JOIN pragma_
2740: 74 61 62 6c 65 5f 69 6e 66 6f 28 73 6d 2e 6e 61  table_info(sm.na
2750: 6d 65 2c 25 51 29 20 41 53 20 70 74 69 22 0a 20  me,%Q) AS pti". 
2760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 20                " 
2770: 57 48 45 52 45 20 73 6d 2e 74 79 70 65 3d 27 74  WHERE sm.type='t
2780: 61 62 6c 65 27 22 2c 0a 20 20 20 20 20 20 20 20  able'",.        
2790: 20 20 20 20 20 20 20 7a 53 71 6c 2c 20 7a 53 65         zSql, zSe
27a0: 70 2c 20 7a 44 62 2c 20 7a 44 62 0a 20 20 20 20  p, zDb, zDb.    
27b0: 20 20 20 20 20 20 20 20 29 3b 0a 20 20 20 20 20          );.     
27c0: 20 20 20 20 20 20 20 69 66 28 20 7a 53 71 6c 3d         if( zSql=
27d0: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  =0 ) return SQLI
27e0: 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20 20  TE_NOMEM;.      
27f0: 20 20 20 20 20 20 7a 53 65 70 20 3d 20 22 20 55        zSep = " U
2800: 4e 49 4f 4e 20 22 3b 0a 20 20 20 20 20 20 20 20  NION ";.        
2810: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 73 71    }.          sq
2820: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
2830: 53 32 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73  S2);.          s
2840: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
2850: 32 28 70 43 75 72 2d 3e 64 62 2c 20 7a 53 71 6c  2(pCur->db, zSql
2860: 2c 20 2d 31 2c 20 26 70 43 75 72 2d 3e 70 53 74  , -1, &pCur->pSt
2870: 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  mt, 0);.        
2880: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
2890: 53 71 6c 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  Sql);.        }.
28a0: 20 20 20 20 20 20 20 20 69 43 6f 6c 20 3d 20 30          iCol = 0
28b0: 3b 0a 20 20 20 20 20 20 20 20 65 4e 65 78 74 50  ;.        eNextP
28c0: 68 61 73 65 20 3d 20 43 4f 4d 50 4c 45 54 49 4f  hase = COMPLETIO
28d0: 4e 5f 45 4f 46 3b 0a 20 20 20 20 20 20 20 20 62  N_EOF;.        b
28e0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20  reak;.      }.  
28f0: 20 20 7d 0a 20 20 20 20 69 66 28 20 69 43 6f 6c    }.    if( iCol
2900: 3c 30 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 54  <0 ){.      /* T
2910: 68 69 73 20 63 61 73 65 20 69 73 20 77 68 65 6e  his case is when
2920: 20 74 68 65 20 70 68 61 73 65 20 70 72 65 73 65   the phase prese
2930: 74 73 20 7a 43 75 72 72 65 6e 74 52 6f 77 20 2a  ts zCurrentRow *
2940: 2f 0a 20 20 20 20 20 20 69 66 28 20 70 43 75 72  /.      if( pCur
2950: 2d 3e 7a 43 75 72 72 65 6e 74 52 6f 77 3d 3d 30  ->zCurrentRow==0
2960: 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20   ) continue;.   
2970: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 66   }else{.      if
2980: 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70  ( sqlite3_step(p
2990: 43 75 72 2d 3e 70 53 74 6d 74 29 3d 3d 53 51 4c  Cur->pStmt)==SQL
29a0: 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20  ITE_ROW ){.     
29b0: 20 20 20 2f 2a 20 45 78 74 72 61 63 74 20 74 68     /* Extract th
29c0: 65 20 6e 65 78 74 20 72 6f 77 20 6f 66 20 63 6f  e next row of co
29d0: 6e 74 65 6e 74 20 2a 2f 0a 20 20 20 20 20 20 20  ntent */.       
29e0: 20 70 43 75 72 2d 3e 7a 43 75 72 72 65 6e 74 52   pCur->zCurrentR
29f0: 6f 77 20 3d 20 28 63 6f 6e 73 74 20 63 68 61 72  ow = (const char
2a00: 2a 29 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  *)sqlite3_column
2a10: 5f 74 65 78 74 28 70 43 75 72 2d 3e 70 53 74 6d  _text(pCur->pStm
2a20: 74 2c 20 69 43 6f 6c 29 3b 0a 20 20 20 20 20 20  t, iCol);.      
2a30: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 2f  }else{.        /
2a40: 2a 20 57 68 65 6e 20 61 6c 6c 20 72 6f 77 73 20  * When all rows 
2a50: 61 72 65 20 66 69 6e 69 73 68 65 64 2c 20 61 64  are finished, ad
2a60: 76 61 6e 63 65 20 74 6f 20 74 68 65 20 6e 65 78  vance to the nex
2a70: 74 20 70 68 61 73 65 20 2a 2f 0a 20 20 20 20 20  t phase */.     
2a80: 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c     sqlite3_final
2a90: 69 7a 65 28 70 43 75 72 2d 3e 70 53 74 6d 74 29  ize(pCur->pStmt)
2aa0: 3b 0a 20 20 20 20 20 20 20 20 70 43 75 72 2d 3e  ;.        pCur->
2ab0: 70 53 74 6d 74 20 3d 20 30 3b 0a 20 20 20 20 20  pStmt = 0;.     
2ac0: 20 20 20 70 43 75 72 2d 3e 65 50 68 61 73 65 20     pCur->ePhase 
2ad0: 3d 20 65 4e 65 78 74 50 68 61 73 65 3b 0a 20 20  = eNextPhase;.  
2ae0: 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a        continue;.
2af0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
2b00: 20 20 69 66 28 20 70 43 75 72 2d 3e 6e 50 72 65    if( pCur->nPre
2b10: 66 69 78 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a  fix==0 ) break;.
2b20: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f      if( sqlite3_
2b30: 73 74 72 6e 69 63 6d 70 28 70 43 75 72 2d 3e 7a  strnicmp(pCur->z
2b40: 50 72 65 66 69 78 2c 20 70 43 75 72 2d 3e 7a 43  Prefix, pCur->zC
2b50: 75 72 72 65 6e 74 52 6f 77 2c 20 70 43 75 72 2d  urrentRow, pCur-
2b60: 3e 6e 50 72 65 66 69 78 29 3d 3d 30 20 29 7b 0a  >nPrefix)==0 ){.
2b70: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2b80: 20 7d 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e   }.  }..  return
2b90: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f   SQLITE_OK;.}../
2ba0: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 76 61 6c 75  *.** Return valu
2bb0: 65 73 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 66 6f  es of columns fo
2bc0: 72 20 74 68 65 20 72 6f 77 20 61 74 20 77 68 69  r the row at whi
2bd0: 63 68 20 74 68 65 20 63 6f 6d 70 6c 65 74 69 6f  ch the completio
2be0: 6e 5f 63 75 72 73 6f 72 0a 2a 2a 20 69 73 20 63  n_cursor.** is c
2bf0: 75 72 72 65 6e 74 6c 79 20 70 6f 69 6e 74 69 6e  urrently pointin
2c00: 67 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  g..*/.static int
2c10: 20 63 6f 6d 70 6c 65 74 69 6f 6e 43 6f 6c 75 6d   completionColum
2c20: 6e 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61  n(.  sqlite3_vta
2c30: 62 5f 63 75 72 73 6f 72 20 2a 63 75 72 2c 20 20  b_cursor *cur,  
2c40: 20 2f 2a 20 54 68 65 20 63 75 72 73 6f 72 20 2a   /* The cursor *
2c50: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  /.  sqlite3_cont
2c60: 65 78 74 20 2a 63 74 78 2c 20 20 20 20 20 20 20  ext *ctx,       
2c70: 2f 2a 20 46 69 72 73 74 20 61 72 67 75 6d 65 6e  /* First argumen
2c80: 74 20 74 6f 20 73 71 6c 69 74 65 33 5f 72 65 73  t to sqlite3_res
2c90: 75 6c 74 5f 2e 2e 2e 28 29 20 2a 2f 0a 20 20 69  ult_...() */.  i
2ca0: 6e 74 20 69 20 20 20 20 20 20 20 20 20 20 20 20  nt i            
2cb0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 57 68             /* Wh
2cc0: 69 63 68 20 63 6f 6c 75 6d 6e 20 74 6f 20 72 65  ich column to re
2cd0: 74 75 72 6e 20 2a 2f 0a 29 7b 0a 20 20 63 6f 6d  turn */.){.  com
2ce0: 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 20 2a  pletion_cursor *
2cf0: 70 43 75 72 20 3d 20 28 63 6f 6d 70 6c 65 74 69  pCur = (completi
2d00: 6f 6e 5f 63 75 72 73 6f 72 2a 29 63 75 72 3b 0a  on_cursor*)cur;.
2d10: 20 20 73 77 69 74 63 68 28 20 69 20 29 7b 0a 20    switch( i ){. 
2d20: 20 20 20 63 61 73 65 20 43 4f 4d 50 4c 45 54 49     case COMPLETI
2d30: 4f 4e 5f 43 4f 4c 55 4d 4e 5f 43 41 4e 44 49 44  ON_COLUMN_CANDID
2d40: 41 54 45 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c  ATE: {.      sql
2d50: 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74  ite3_result_text
2d60: 28 63 74 78 2c 20 70 43 75 72 2d 3e 7a 43 75 72  (ctx, pCur->zCur
2d70: 72 65 6e 74 52 6f 77 2c 20 2d 31 2c 20 53 51 4c  rentRow, -1, SQL
2d80: 49 54 45 5f 54 52 41 4e 53 49 45 4e 54 29 3b 0a  ITE_TRANSIENT);.
2d90: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2da0: 20 7d 0a 20 20 20 20 63 61 73 65 20 43 4f 4d 50   }.    case COMP
2db0: 4c 45 54 49 4f 4e 5f 43 4f 4c 55 4d 4e 5f 50 52  LETION_COLUMN_PR
2dc0: 45 46 49 58 3a 20 7b 0a 20 20 20 20 20 20 73 71  EFIX: {.      sq
2dd0: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78  lite3_result_tex
2de0: 74 28 63 74 78 2c 20 70 43 75 72 2d 3e 7a 50 72  t(ctx, pCur->zPr
2df0: 65 66 69 78 2c 20 2d 31 2c 20 53 51 4c 49 54 45  efix, -1, SQLITE
2e00: 5f 54 52 41 4e 53 49 45 4e 54 29 3b 0a 20 20 20  _TRANSIENT);.   
2e10: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
2e20: 20 20 20 20 63 61 73 65 20 43 4f 4d 50 4c 45 54      case COMPLET
2e30: 49 4f 4e 5f 43 4f 4c 55 4d 4e 5f 57 48 4f 4c 45  ION_COLUMN_WHOLE
2e40: 4c 49 4e 45 3a 20 7b 0a 20 20 20 20 20 20 73 71  LINE: {.      sq
2e50: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78  lite3_result_tex
2e60: 74 28 63 74 78 2c 20 70 43 75 72 2d 3e 7a 4c 69  t(ctx, pCur->zLi
2e70: 6e 65 2c 20 2d 31 2c 20 53 51 4c 49 54 45 5f 54  ne, -1, SQLITE_T
2e80: 52 41 4e 53 49 45 4e 54 29 3b 0a 20 20 20 20 20  RANSIENT);.     
2e90: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
2ea0: 20 20 63 61 73 65 20 43 4f 4d 50 4c 45 54 49 4f    case COMPLETIO
2eb0: 4e 5f 43 4f 4c 55 4d 4e 5f 50 48 41 53 45 3a 20  N_COLUMN_PHASE: 
2ec0: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  {.      sqlite3_
2ed0: 72 65 73 75 6c 74 5f 69 6e 74 28 63 74 78 2c 20  result_int(ctx, 
2ee0: 70 43 75 72 2d 3e 65 50 68 61 73 65 29 3b 0a 20  pCur->ePhase);. 
2ef0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
2f00: 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 53  }.  }.  return S
2f10: 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a  QLITE_OK;.}../*.
2f20: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 72 6f  ** Return the ro
2f30: 77 69 64 20 66 6f 72 20 74 68 65 20 63 75 72 72  wid for the curr
2f40: 65 6e 74 20 72 6f 77 2e 20 20 49 6e 20 74 68 69  ent row.  In thi
2f50: 73 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e  s implementation
2f60: 2c 20 74 68 65 0a 2a 2a 20 72 6f 77 69 64 20 69  , the.** rowid i
2f70: 73 20 74 68 65 20 73 61 6d 65 20 61 73 20 74 68  s the same as th
2f80: 65 20 6f 75 74 70 75 74 20 76 61 6c 75 65 2e 0a  e output value..
2f90: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63 6f  */.static int co
2fa0: 6d 70 6c 65 74 69 6f 6e 52 6f 77 69 64 28 73 71  mpletionRowid(sq
2fb0: 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f  lite3_vtab_curso
2fc0: 72 20 2a 63 75 72 2c 20 73 71 6c 69 74 65 5f 69  r *cur, sqlite_i
2fd0: 6e 74 36 34 20 2a 70 52 6f 77 69 64 29 7b 0a 20  nt64 *pRowid){. 
2fe0: 20 63 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73   completion_curs
2ff0: 6f 72 20 2a 70 43 75 72 20 3d 20 28 63 6f 6d 70  or *pCur = (comp
3000: 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72 2a 29 63  letion_cursor*)c
3010: 75 72 3b 0a 20 20 2a 70 52 6f 77 69 64 20 3d 20  ur;.  *pRowid = 
3020: 70 43 75 72 2d 3e 69 52 6f 77 69 64 3b 0a 20 20  pCur->iRowid;.  
3030: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
3040: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72  ;.}../*.** Retur
3050: 6e 20 54 52 55 45 20 69 66 20 74 68 65 20 63 75  n TRUE if the cu
3060: 72 73 6f 72 20 68 61 73 20 62 65 65 6e 20 6d 6f  rsor has been mo
3070: 76 65 64 20 6f 66 66 20 6f 66 20 74 68 65 20 6c  ved off of the l
3080: 61 73 74 0a 2a 2a 20 72 6f 77 20 6f 66 20 6f 75  ast.** row of ou
3090: 74 70 75 74 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  tput..*/.static 
30a0: 69 6e 74 20 63 6f 6d 70 6c 65 74 69 6f 6e 45 6f  int completionEo
30b0: 66 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63  f(sqlite3_vtab_c
30c0: 75 72 73 6f 72 20 2a 63 75 72 29 7b 0a 20 20 63  ursor *cur){.  c
30d0: 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75 72 73 6f 72  ompletion_cursor
30e0: 20 2a 70 43 75 72 20 3d 20 28 63 6f 6d 70 6c 65   *pCur = (comple
30f0: 74 69 6f 6e 5f 63 75 72 73 6f 72 2a 29 63 75 72  tion_cursor*)cur
3100: 3b 0a 20 20 72 65 74 75 72 6e 20 70 43 75 72 2d  ;.  return pCur-
3110: 3e 65 50 68 61 73 65 20 3e 3d 20 43 4f 4d 50 4c  >ePhase >= COMPL
3120: 45 54 49 4f 4e 5f 45 4f 46 3b 0a 7d 0a 0a 2f 2a  ETION_EOF;.}../*
3130: 0a 2a 2a 20 54 68 69 73 20 6d 65 74 68 6f 64 20  .** This method 
3140: 69 73 20 63 61 6c 6c 65 64 20 74 6f 20 22 72 65  is called to "re
3150: 77 69 6e 64 22 20 74 68 65 20 63 6f 6d 70 6c 65  wind" the comple
3160: 74 69 6f 6e 5f 63 75 72 73 6f 72 20 6f 62 6a 65  tion_cursor obje
3170: 63 74 20 62 61 63 6b 0a 2a 2a 20 74 6f 20 74 68  ct back.** to th
3180: 65 20 66 69 72 73 74 20 72 6f 77 20 6f 66 20 6f  e first row of o
3190: 75 74 70 75 74 2e 20 20 54 68 69 73 20 6d 65 74  utput.  This met
31a0: 68 6f 64 20 69 73 20 61 6c 77 61 79 73 20 63 61  hod is always ca
31b0: 6c 6c 65 64 20 61 74 20 6c 65 61 73 74 0a 2a 2a  lled at least.**
31c0: 20 6f 6e 63 65 20 70 72 69 6f 72 20 74 6f 20 61   once prior to a
31d0: 6e 79 20 63 61 6c 6c 20 74 6f 20 63 6f 6d 70 6c  ny call to compl
31e0: 65 74 69 6f 6e 43 6f 6c 75 6d 6e 28 29 20 6f 72  etionColumn() or
31f0: 20 63 6f 6d 70 6c 65 74 69 6f 6e 52 6f 77 69 64   completionRowid
3200: 28 29 20 6f 72 20 0a 2a 2a 20 63 6f 6d 70 6c 65  () or .** comple
3210: 74 69 6f 6e 45 6f 66 28 29 2e 0a 2a 2f 0a 73 74  tionEof()..*/.st
3220: 61 74 69 63 20 69 6e 74 20 63 6f 6d 70 6c 65 74  atic int complet
3230: 69 6f 6e 46 69 6c 74 65 72 28 0a 20 20 73 71 6c  ionFilter(.  sql
3240: 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72  ite3_vtab_cursor
3250: 20 2a 70 56 74 61 62 43 75 72 73 6f 72 2c 20 0a   *pVtabCursor, .
3260: 20 20 69 6e 74 20 69 64 78 4e 75 6d 2c 20 63 6f    int idxNum, co
3270: 6e 73 74 20 63 68 61 72 20 2a 69 64 78 53 74 72  nst char *idxStr
3280: 2c 0a 20 20 69 6e 74 20 61 72 67 63 2c 20 73 71  ,.  int argc, sq
3290: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72  lite3_value **ar
32a0: 67 76 0a 29 7b 0a 20 20 63 6f 6d 70 6c 65 74 69  gv.){.  completi
32b0: 6f 6e 5f 63 75 72 73 6f 72 20 2a 70 43 75 72 20  on_cursor *pCur 
32c0: 3d 20 28 63 6f 6d 70 6c 65 74 69 6f 6e 5f 63 75  = (completion_cu
32d0: 72 73 6f 72 20 2a 29 70 56 74 61 62 43 75 72 73  rsor *)pVtabCurs
32e0: 6f 72 3b 0a 20 20 69 6e 74 20 69 41 72 67 20 3d  or;.  int iArg =
32f0: 20 30 3b 0a 20 20 28 76 6f 69 64 29 28 69 64 78   0;.  (void)(idx
3300: 53 74 72 29 3b 20 20 20 2f 2a 20 55 6e 75 73 65  Str);   /* Unuse
3310: 64 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a 20  d parameter */. 
3320: 20 28 76 6f 69 64 29 28 61 72 67 63 29 3b 20 20   (void)(argc);  
3330: 20 20 20 2f 2a 20 55 6e 75 73 65 64 20 70 61 72     /* Unused par
3340: 61 6d 65 74 65 72 20 2a 2f 0a 20 20 63 6f 6d 70  ameter */.  comp
3350: 6c 65 74 69 6f 6e 43 75 72 73 6f 72 52 65 73 65  letionCursorRese
3360: 74 28 70 43 75 72 29 3b 0a 20 20 69 66 28 20 69  t(pCur);.  if( i
3370: 64 78 4e 75 6d 20 26 20 31 20 29 7b 0a 20 20 20  dxNum & 1 ){.   
3380: 20 70 43 75 72 2d 3e 6e 50 72 65 66 69 78 20 3d   pCur->nPrefix =
3390: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62   sqlite3_value_b
33a0: 79 74 65 73 28 61 72 67 76 5b 69 41 72 67 5d 29  ytes(argv[iArg])
33b0: 3b 0a 20 20 20 20 69 66 28 20 70 43 75 72 2d 3e  ;.    if( pCur->
33c0: 6e 50 72 65 66 69 78 3e 30 20 29 7b 0a 20 20 20  nPrefix>0 ){.   
33d0: 20 20 20 70 43 75 72 2d 3e 7a 50 72 65 66 69 78     pCur->zPrefix
33e0: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e   = sqlite3_mprin
33f0: 74 66 28 22 25 73 22 2c 20 73 71 6c 69 74 65 33  tf("%s", sqlite3
3400: 5f 76 61 6c 75 65 5f 74 65 78 74 28 61 72 67 76  _value_text(argv
3410: 5b 69 41 72 67 5d 29 29 3b 0a 20 20 20 20 20 20  [iArg]));.      
3420: 69 66 28 20 70 43 75 72 2d 3e 7a 50 72 65 66 69  if( pCur->zPrefi
3430: 78 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51  x==0 ) return SQ
3440: 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20  LITE_NOMEM;.    
3450: 7d 0a 20 20 20 20 69 41 72 67 2b 2b 3b 0a 20 20  }.    iArg++;.  
3460: 7d 0a 20 20 69 66 28 20 69 64 78 4e 75 6d 20 26  }.  if( idxNum &
3470: 20 32 20 29 7b 0a 20 20 20 20 70 43 75 72 2d 3e   2 ){.    pCur->
3480: 6e 4c 69 6e 65 20 3d 20 73 71 6c 69 74 65 33 5f  nLine = sqlite3_
3490: 76 61 6c 75 65 5f 62 79 74 65 73 28 61 72 67 76  value_bytes(argv
34a0: 5b 69 41 72 67 5d 29 3b 0a 20 20 20 20 69 66 28  [iArg]);.    if(
34b0: 20 70 43 75 72 2d 3e 6e 4c 69 6e 65 3e 30 20 29   pCur->nLine>0 )
34c0: 7b 0a 20 20 20 20 20 20 70 43 75 72 2d 3e 7a 4c  {.      pCur->zL
34d0: 69 6e 65 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70  ine = sqlite3_mp
34e0: 72 69 6e 74 66 28 22 25 73 22 2c 20 73 71 6c 69  rintf("%s", sqli
34f0: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 61  te3_value_text(a
3500: 72 67 76 5b 69 41 72 67 5d 29 29 3b 0a 20 20 20  rgv[iArg]));.   
3510: 20 20 20 69 66 28 20 70 43 75 72 2d 3e 7a 4c 69     if( pCur->zLi
3520: 6e 65 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53  ne==0 ) return S
3530: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20  QLITE_NOMEM;.   
3540: 20 7d 0a 20 20 20 20 69 41 72 67 2b 2b 3b 0a 20   }.    iArg++;. 
3550: 20 7d 0a 20 20 69 66 28 20 70 43 75 72 2d 3e 7a   }.  if( pCur->z
3560: 4c 69 6e 65 21 3d 30 20 26 26 20 70 43 75 72 2d  Line!=0 && pCur-
3570: 3e 7a 50 72 65 66 69 78 3d 3d 30 20 29 7b 0a 20  >zPrefix==0 ){. 
3580: 20 20 20 69 6e 74 20 69 20 3d 20 70 43 75 72 2d     int i = pCur-
3590: 3e 6e 4c 69 6e 65 3b 0a 20 20 20 20 77 68 69 6c  >nLine;.    whil
35a0: 65 28 20 69 3e 30 20 26 26 20 28 69 73 61 6c 6e  e( i>0 && (isaln
35b0: 75 6d 28 70 43 75 72 2d 3e 7a 4c 69 6e 65 5b 69  um(pCur->zLine[i
35c0: 2d 31 5d 29 20 7c 7c 20 70 43 75 72 2d 3e 7a 4c  -1]) || pCur->zL
35d0: 69 6e 65 5b 69 2d 31 5d 3d 3d 27 5f 27 29 20 29  ine[i-1]=='_') )
35e0: 7b 0a 20 20 20 20 20 20 69 2d 2d 3b 0a 20 20 20  {.      i--;.   
35f0: 20 7d 0a 20 20 20 20 70 43 75 72 2d 3e 6e 50 72   }.    pCur->nPr
3600: 65 66 69 78 20 3d 20 70 43 75 72 2d 3e 6e 4c 69  efix = pCur->nLi
3610: 6e 65 20 2d 20 69 3b 0a 20 20 20 20 69 66 28 20  ne - i;.    if( 
3620: 70 43 75 72 2d 3e 6e 50 72 65 66 69 78 3e 30 20  pCur->nPrefix>0 
3630: 29 7b 0a 20 20 20 20 20 20 70 43 75 72 2d 3e 7a  ){.      pCur->z
3640: 50 72 65 66 69 78 20 3d 20 73 71 6c 69 74 65 33  Prefix = sqlite3
3650: 5f 6d 70 72 69 6e 74 66 28 22 25 2e 2a 73 22 2c  _mprintf("%.*s",
3660: 20 70 43 75 72 2d 3e 6e 50 72 65 66 69 78 2c 20   pCur->nPrefix, 
3670: 70 43 75 72 2d 3e 7a 4c 69 6e 65 20 2b 20 69 29  pCur->zLine + i)
3680: 3b 0a 20 20 20 20 20 20 69 66 28 20 70 43 75 72  ;.      if( pCur
3690: 2d 3e 7a 50 72 65 66 69 78 3d 3d 30 20 29 20 72  ->zPrefix==0 ) r
36a0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d  eturn SQLITE_NOM
36b0: 45 4d 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  EM;.    }.  }.  
36c0: 70 43 75 72 2d 3e 69 52 6f 77 69 64 20 3d 20 30  pCur->iRowid = 0
36d0: 3b 0a 20 20 70 43 75 72 2d 3e 65 50 68 61 73 65  ;.  pCur->ePhase
36e0: 20 3d 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 46 49   = COMPLETION_FI
36f0: 52 53 54 5f 50 48 41 53 45 3b 0a 20 20 72 65 74  RST_PHASE;.  ret
3700: 75 72 6e 20 63 6f 6d 70 6c 65 74 69 6f 6e 4e 65  urn completionNe
3710: 78 74 28 70 56 74 61 62 43 75 72 73 6f 72 29 3b  xt(pVtabCursor);
3720: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 51 4c 69 74 65  .}../*.** SQLite
3730: 20 77 69 6c 6c 20 69 6e 76 6f 6b 65 20 74 68 69   will invoke thi
3740: 73 20 6d 65 74 68 6f 64 20 6f 6e 65 20 6f 72 20  s method one or 
3750: 6d 6f 72 65 20 74 69 6d 65 73 20 77 68 69 6c 65  more times while
3760: 20 70 6c 61 6e 6e 69 6e 67 20 61 20 71 75 65 72   planning a quer
3770: 79 0a 2a 2a 20 74 68 61 74 20 75 73 65 73 20 74  y.** that uses t
3780: 68 65 20 63 6f 6d 70 6c 65 74 69 6f 6e 20 76 69  he completion vi
3790: 72 74 75 61 6c 20 74 61 62 6c 65 2e 20 20 54 68  rtual table.  Th
37a0: 69 73 20 72 6f 75 74 69 6e 65 20 6e 65 65 64 73  is routine needs
37b0: 20 74 6f 20 63 72 65 61 74 65 0a 2a 2a 20 61 20   to create.** a 
37c0: 71 75 65 72 79 20 70 6c 61 6e 20 66 6f 72 20 65  query plan for e
37d0: 61 63 68 20 69 6e 76 6f 63 61 74 69 6f 6e 20 61  ach invocation a
37e0: 6e 64 20 63 6f 6d 70 75 74 65 20 61 6e 20 65 73  nd compute an es
37f0: 74 69 6d 61 74 65 64 20 63 6f 73 74 20 66 6f 72  timated cost for
3800: 20 74 68 61 74 0a 2a 2a 20 70 6c 61 6e 2e 0a 2a   that.** plan..*
3810: 2a 0a 2a 2a 20 54 68 65 72 65 20 61 72 65 20 74  *.** There are t
3820: 77 6f 20 68 69 64 64 65 6e 20 70 61 72 61 6d 65  wo hidden parame
3830: 74 65 72 73 20 74 68 61 74 20 61 63 74 20 61 73  ters that act as
3840: 20 61 72 67 75 6d 65 6e 74 73 20 74 6f 20 74 68   arguments to th
3850: 65 20 74 61 62 6c 65 2d 76 61 6c 75 65 64 0a 2a  e table-valued.*
3860: 2a 20 66 75 6e 63 74 69 6f 6e 3a 20 20 22 70 72  * function:  "pr
3870: 65 66 69 78 22 20 61 6e 64 20 22 77 68 6f 6c 65  efix" and "whole
3880: 6c 69 6e 65 22 2e 20 20 42 69 74 20 30 20 6f 66  line".  Bit 0 of
3890: 20 69 64 78 4e 75 6d 20 69 73 20 73 65 74 20 69   idxNum is set i
38a0: 66 20 22 70 72 65 66 69 78 22 0a 2a 2a 20 69 73  f "prefix".** is
38b0: 20 61 76 61 69 6c 61 62 6c 65 20 61 6e 64 20 62   available and b
38c0: 69 74 20 31 20 69 73 20 73 65 74 20 69 66 20 22  it 1 is set if "
38d0: 77 68 6f 6c 65 6c 69 6e 65 22 20 69 73 20 61 76  wholeline" is av
38e0: 61 69 6c 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74  ailable..*/.stat
38f0: 69 63 20 69 6e 74 20 63 6f 6d 70 6c 65 74 69 6f  ic int completio
3900: 6e 42 65 73 74 49 6e 64 65 78 28 0a 20 20 73 71  nBestIndex(.  sq
3910: 6c 69 74 65 33 5f 76 74 61 62 20 2a 74 61 62 2c  lite3_vtab *tab,
3920: 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 64 65 78  .  sqlite3_index
3930: 5f 69 6e 66 6f 20 2a 70 49 64 78 49 6e 66 6f 0a  _info *pIdxInfo.
3940: 29 7b 0a 20 20 69 6e 74 20 69 3b 20 20 20 20 20  ){.  int i;     
3950: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c              /* L
3960: 6f 6f 70 20 6f 76 65 72 20 63 6f 6e 73 74 72 61  oop over constra
3970: 69 6e 74 73 20 2a 2f 0a 20 20 69 6e 74 20 69 64  ints */.  int id
3980: 78 4e 75 6d 20 3d 20 30 3b 20 20 20 20 20 20 20  xNum = 0;       
3990: 20 2f 2a 20 54 68 65 20 71 75 65 72 79 20 70 6c   /* The query pl
39a0: 61 6e 20 62 69 74 6d 61 73 6b 20 2a 2f 0a 20 20  an bitmask */.  
39b0: 69 6e 74 20 70 72 65 66 69 78 49 64 78 20 3d 20  int prefixIdx = 
39c0: 2d 31 3b 20 20 20 20 2f 2a 20 49 6e 64 65 78 20  -1;    /* Index 
39d0: 6f 66 20 74 68 65 20 73 74 61 72 74 3d 20 63 6f  of the start= co
39e0: 6e 73 74 72 61 69 6e 74 2c 20 6f 72 20 2d 31 20  nstraint, or -1 
39f0: 69 66 20 6e 6f 6e 65 20 2a 2f 0a 20 20 69 6e 74  if none */.  int
3a00: 20 77 68 6f 6c 65 6c 69 6e 65 49 64 78 20 3d 20   wholelineIdx = 
3a10: 2d 31 3b 20 2f 2a 20 49 6e 64 65 78 20 6f 66 20  -1; /* Index of 
3a20: 74 68 65 20 73 74 6f 70 3d 20 63 6f 6e 73 74 72  the stop= constr
3a30: 61 69 6e 74 2c 20 6f 72 20 2d 31 20 69 66 20 6e  aint, or -1 if n
3a40: 6f 6e 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 41 72  one */.  int nAr
3a50: 67 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  g = 0;          
3a60: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67  /* Number of arg
3a70: 75 6d 65 6e 74 73 20 74 68 61 74 20 63 6f 6d 70  uments that comp
3a80: 6c 65 74 65 46 69 6c 74 65 72 28 29 20 65 78 70  leteFilter() exp
3a90: 65 63 74 73 20 2a 2f 0a 20 20 63 6f 6e 73 74 20  ects */.  const 
3aa0: 73 74 72 75 63 74 20 73 71 6c 69 74 65 33 5f 69  struct sqlite3_i
3ab0: 6e 64 65 78 5f 63 6f 6e 73 74 72 61 69 6e 74 20  ndex_constraint 
3ac0: 2a 70 43 6f 6e 73 74 72 61 69 6e 74 3b 0a 0a 20  *pConstraint;.. 
3ad0: 20 28 76 6f 69 64 29 28 74 61 62 29 3b 20 20 20   (void)(tab);   
3ae0: 20 2f 2a 20 55 6e 75 73 65 64 20 70 61 72 61 6d   /* Unused param
3af0: 65 74 65 72 20 2a 2f 0a 20 20 70 43 6f 6e 73 74  eter */.  pConst
3b00: 72 61 69 6e 74 20 3d 20 70 49 64 78 49 6e 66 6f  raint = pIdxInfo
3b10: 2d 3e 61 43 6f 6e 73 74 72 61 69 6e 74 3b 0a 20  ->aConstraint;. 
3b20: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 49 64 78   for(i=0; i<pIdx
3b30: 49 6e 66 6f 2d 3e 6e 43 6f 6e 73 74 72 61 69 6e  Info->nConstrain
3b40: 74 3b 20 69 2b 2b 2c 20 70 43 6f 6e 73 74 72 61  t; i++, pConstra
3b50: 69 6e 74 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  int++){.    if( 
3b60: 70 43 6f 6e 73 74 72 61 69 6e 74 2d 3e 75 73 61  pConstraint->usa
3b70: 62 6c 65 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75  ble==0 ) continu
3b80: 65 3b 0a 20 20 20 20 69 66 28 20 70 43 6f 6e 73  e;.    if( pCons
3b90: 74 72 61 69 6e 74 2d 3e 6f 70 21 3d 53 51 4c 49  traint->op!=SQLI
3ba0: 54 45 5f 49 4e 44 45 58 5f 43 4f 4e 53 54 52 41  TE_INDEX_CONSTRA
3bb0: 49 4e 54 5f 45 51 20 29 20 63 6f 6e 74 69 6e 75  INT_EQ ) continu
3bc0: 65 3b 0a 20 20 20 20 73 77 69 74 63 68 28 20 70  e;.    switch( p
3bd0: 43 6f 6e 73 74 72 61 69 6e 74 2d 3e 69 43 6f 6c  Constraint->iCol
3be0: 75 6d 6e 20 29 7b 0a 20 20 20 20 20 20 63 61 73  umn ){.      cas
3bf0: 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 43 4f 4c  e COMPLETION_COL
3c00: 55 4d 4e 5f 50 52 45 46 49 58 3a 0a 20 20 20 20  UMN_PREFIX:.    
3c10: 20 20 20 20 70 72 65 66 69 78 49 64 78 20 3d 20      prefixIdx = 
3c20: 69 3b 0a 20 20 20 20 20 20 20 20 69 64 78 4e 75  i;.        idxNu
3c30: 6d 20 7c 3d 20 31 3b 0a 20 20 20 20 20 20 20 20  m |= 1;.        
3c40: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 63 61 73  break;.      cas
3c50: 65 20 43 4f 4d 50 4c 45 54 49 4f 4e 5f 43 4f 4c  e COMPLETION_COL
3c60: 55 4d 4e 5f 57 48 4f 4c 45 4c 49 4e 45 3a 0a 20  UMN_WHOLELINE:. 
3c70: 20 20 20 20 20 20 20 77 68 6f 6c 65 6c 69 6e 65         wholeline
3c80: 49 64 78 20 3d 20 69 3b 0a 20 20 20 20 20 20 20  Idx = i;.       
3c90: 20 69 64 78 4e 75 6d 20 7c 3d 20 32 3b 0a 20 20   idxNum |= 2;.  
3ca0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
3cb0: 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 70 72 65   }.  }.  if( pre
3cc0: 66 69 78 49 64 78 3e 3d 30 20 29 7b 0a 20 20 20  fixIdx>=0 ){.   
3cd0: 20 70 49 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73   pIdxInfo->aCons
3ce0: 74 72 61 69 6e 74 55 73 61 67 65 5b 70 72 65 66  traintUsage[pref
3cf0: 69 78 49 64 78 5d 2e 61 72 67 76 49 6e 64 65 78  ixIdx].argvIndex
3d00: 20 3d 20 2b 2b 6e 41 72 67 3b 0a 20 20 20 20 70   = ++nArg;.    p
3d10: 49 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73 74 72  IdxInfo->aConstr
3d20: 61 69 6e 74 55 73 61 67 65 5b 70 72 65 66 69 78  aintUsage[prefix
3d30: 49 64 78 5d 2e 6f 6d 69 74 20 3d 20 31 3b 0a 20  Idx].omit = 1;. 
3d40: 20 7d 0a 20 20 69 66 28 20 77 68 6f 6c 65 6c 69   }.  if( wholeli
3d50: 6e 65 49 64 78 3e 3d 30 20 29 7b 0a 20 20 20 20  neIdx>=0 ){.    
3d60: 70 49 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73 74  pIdxInfo->aConst
3d70: 72 61 69 6e 74 55 73 61 67 65 5b 77 68 6f 6c 65  raintUsage[whole
3d80: 6c 69 6e 65 49 64 78 5d 2e 61 72 67 76 49 6e 64  lineIdx].argvInd
3d90: 65 78 20 3d 20 2b 2b 6e 41 72 67 3b 0a 20 20 20  ex = ++nArg;.   
3da0: 20 70 49 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73   pIdxInfo->aCons
3db0: 74 72 61 69 6e 74 55 73 61 67 65 5b 77 68 6f 6c  traintUsage[whol
3dc0: 65 6c 69 6e 65 49 64 78 5d 2e 6f 6d 69 74 20 3d  elineIdx].omit =
3dd0: 20 31 3b 0a 20 20 7d 0a 20 20 70 49 64 78 49 6e   1;.  }.  pIdxIn
3de0: 66 6f 2d 3e 69 64 78 4e 75 6d 20 3d 20 69 64 78  fo->idxNum = idx
3df0: 4e 75 6d 3b 0a 20 20 70 49 64 78 49 6e 66 6f 2d  Num;.  pIdxInfo-
3e00: 3e 65 73 74 69 6d 61 74 65 64 43 6f 73 74 20 3d  >estimatedCost =
3e10: 20 28 64 6f 75 62 6c 65 29 35 30 30 30 20 2d 20   (double)5000 - 
3e20: 31 30 30 30 2a 6e 41 72 67 3b 0a 20 20 70 49 64  1000*nArg;.  pId
3e30: 78 49 6e 66 6f 2d 3e 65 73 74 69 6d 61 74 65 64  xInfo->estimated
3e40: 52 6f 77 73 20 3d 20 35 30 30 20 2d 20 31 30 30  Rows = 500 - 100
3e50: 2a 6e 41 72 67 3b 0a 20 20 72 65 74 75 72 6e 20  *nArg;.  return 
3e60: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a  SQLITE_OK;.}../*
3e70: 0a 2a 2a 20 54 68 69 73 20 66 6f 6c 6c 6f 77 69  .** This followi
3e80: 6e 67 20 73 74 72 75 63 74 75 72 65 20 64 65 66  ng structure def
3e90: 69 6e 65 73 20 61 6c 6c 20 74 68 65 20 6d 65 74  ines all the met
3ea0: 68 6f 64 73 20 66 6f 72 20 74 68 65 20 0a 2a 2a  hods for the .**
3eb0: 20 63 6f 6d 70 6c 65 74 69 6f 6e 20 76 69 72 74   completion virt
3ec0: 75 61 6c 20 74 61 62 6c 65 2e 0a 2a 2f 0a 73 74  ual table..*/.st
3ed0: 61 74 69 63 20 73 71 6c 69 74 65 33 5f 6d 6f 64  atic sqlite3_mod
3ee0: 75 6c 65 20 63 6f 6d 70 6c 65 74 69 6f 6e 4d 6f  ule completionMo
3ef0: 64 75 6c 65 20 3d 20 7b 0a 20 20 30 2c 20 20 20  dule = {.  0,   
3f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3f10: 20 20 20 20 20 20 2f 2a 20 69 56 65 72 73 69 6f        /* iVersio
3f20: 6e 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  n */.  0,       
3f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3f40: 20 20 2f 2a 20 78 43 72 65 61 74 65 20 2a 2f 0a    /* xCreate */.
3f50: 20 20 63 6f 6d 70 6c 65 74 69 6f 6e 43 6f 6e 6e    completionConn
3f60: 65 63 74 2c 20 20 20 20 20 20 20 20 20 2f 2a 20  ect,         /* 
3f70: 78 43 6f 6e 6e 65 63 74 20 2a 2f 0a 20 20 63 6f  xConnect */.  co
3f80: 6d 70 6c 65 74 69 6f 6e 42 65 73 74 49 6e 64 65  mpletionBestInde
3f90: 78 2c 20 20 20 20 20 20 20 2f 2a 20 78 42 65 73  x,       /* xBes
3fa0: 74 49 6e 64 65 78 20 2a 2f 0a 20 20 63 6f 6d 70  tIndex */.  comp
3fb0: 6c 65 74 69 6f 6e 44 69 73 63 6f 6e 6e 65 63 74  letionDisconnect
3fc0: 2c 20 20 20 20 20 20 2f 2a 20 78 44 69 73 63 6f  ,      /* xDisco
3fd0: 6e 6e 65 63 74 20 2a 2f 0a 20 20 30 2c 20 20 20  nnect */.  0,   
3fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3ff0: 20 20 20 20 20 20 2f 2a 20 78 44 65 73 74 72 6f        /* xDestro
4000: 79 20 2a 2f 0a 20 20 63 6f 6d 70 6c 65 74 69 6f  y */.  completio
4010: 6e 4f 70 65 6e 2c 20 20 20 20 20 20 20 20 20 20  nOpen,          
4020: 20 20 2f 2a 20 78 4f 70 65 6e 20 2d 20 6f 70 65    /* xOpen - ope
4030: 6e 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20  n a cursor */.  
4040: 63 6f 6d 70 6c 65 74 69 6f 6e 43 6c 6f 73 65 2c  completionClose,
4050: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43             /* xC
4060: 6c 6f 73 65 20 2d 20 63 6c 6f 73 65 20 61 20 63  lose - close a c
4070: 75 72 73 6f 72 20 2a 2f 0a 20 20 63 6f 6d 70 6c  ursor */.  compl
4080: 65 74 69 6f 6e 46 69 6c 74 65 72 2c 20 20 20 20  etionFilter,    
4090: 20 20 20 20 20 20 2f 2a 20 78 46 69 6c 74 65 72        /* xFilter
40a0: 20 2d 20 63 6f 6e 66 69 67 75 72 65 20 73 63 61   - configure sca
40b0: 6e 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 2a 2f  n constraints */
40c0: 0a 20 20 63 6f 6d 70 6c 65 74 69 6f 6e 4e 65 78  .  completionNex
40d0: 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t,            /*
40e0: 20 78 4e 65 78 74 20 2d 20 61 64 76 61 6e 63 65   xNext - advance
40f0: 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20 63   a cursor */.  c
4100: 6f 6d 70 6c 65 74 69 6f 6e 45 6f 66 2c 20 20 20  ompletionEof,   
4110: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 45 6f            /* xEo
4120: 66 20 2d 20 63 68 65 63 6b 20 66 6f 72 20 65 6e  f - check for en
4130: 64 20 6f 66 20 73 63 61 6e 20 2a 2f 0a 20 20 63  d of scan */.  c
4140: 6f 6d 70 6c 65 74 69 6f 6e 43 6f 6c 75 6d 6e 2c  ompletionColumn,
4150: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43 6f            /* xCo
4160: 6c 75 6d 6e 20 2d 20 72 65 61 64 20 64 61 74 61  lumn - read data
4170: 20 2a 2f 0a 20 20 63 6f 6d 70 6c 65 74 69 6f 6e   */.  completion
4180: 52 6f 77 69 64 2c 20 20 20 20 20 20 20 20 20 20  Rowid,          
4190: 20 2f 2a 20 78 52 6f 77 69 64 20 2d 20 72 65 61   /* xRowid - rea
41a0: 64 20 64 61 74 61 20 2a 2f 0a 20 20 30 2c 20 20  d data */.  0,  
41b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
41c0: 20 20 20 20 20 20 20 2f 2a 20 78 55 70 64 61 74         /* xUpdat
41d0: 65 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  e */.  0,       
41e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
41f0: 20 20 2f 2a 20 78 42 65 67 69 6e 20 2a 2f 0a 20    /* xBegin */. 
4200: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
4210: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
4220: 53 79 6e 63 20 2a 2f 0a 20 20 30 2c 20 20 20 20  Sync */.  0,    
4230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4240: 20 20 20 20 20 2f 2a 20 78 43 6f 6d 6d 69 74 20       /* xCommit 
4250: 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20  */.  0,         
4260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4270: 2f 2a 20 78 52 6f 6c 6c 62 61 63 6b 20 2a 2f 0a  /* xRollback */.
4280: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
4290: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
42a0: 78 46 69 6e 64 4d 65 74 68 6f 64 20 2a 2f 0a 20  xFindMethod */. 
42b0: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
42c0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
42d0: 52 65 6e 61 6d 65 20 2a 2f 0a 20 20 30 2c 20 20  Rename */.  0,  
42e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
42f0: 20 20 20 20 20 20 20 2f 2a 20 78 53 61 76 65 70         /* xSavep
4300: 6f 69 6e 74 20 2a 2f 0a 20 20 30 2c 20 20 20 20  oint */.  0,    
4310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4320: 20 20 20 20 20 2f 2a 20 78 52 65 6c 65 61 73 65       /* xRelease
4330: 20 2a 2f 0a 20 20 30 20 20 20 20 20 20 20 20 20   */.  0         
4340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4350: 20 2f 2a 20 78 52 6f 6c 6c 62 61 63 6b 54 6f 20   /* xRollbackTo 
4360: 2a 2f 0a 7d 3b 0a 0a 23 65 6e 64 69 66 20 2f 2a  */.};..#endif /*
4370: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 49 52   SQLITE_OMIT_VIR
4380: 54 55 41 4c 54 41 42 4c 45 20 2a 2f 0a 0a 69 6e  TUALTABLE */..in
4390: 74 20 73 71 6c 69 74 65 33 43 6f 6d 70 6c 65 74  t sqlite3Complet
43a0: 69 6f 6e 56 74 61 62 49 6e 69 74 28 73 71 6c 69  ionVtabInit(sqli
43b0: 74 65 33 20 2a 64 62 29 7b 0a 20 20 69 6e 74 20  te3 *db){.  int 
43c0: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  rc = SQLITE_OK;.
43d0: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
43e0: 4d 49 54 5f 56 49 52 54 55 41 4c 54 41 42 4c 45  MIT_VIRTUALTABLE
43f0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  .  rc = sqlite3_
4400: 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 28 64 62  create_module(db
4410: 2c 20 22 63 6f 6d 70 6c 65 74 69 6f 6e 22 2c 20  , "completion", 
4420: 26 63 6f 6d 70 6c 65 74 69 6f 6e 4d 6f 64 75 6c  &completionModul
4430: 65 2c 20 30 29 3b 0a 23 65 6e 64 69 66 0a 20 20  e, 0);.#endif.  
4440: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 23 69  return rc;.}..#i
4450: 66 64 65 66 20 5f 57 49 4e 33 32 0a 5f 5f 64 65  fdef _WIN32.__de
4460: 63 6c 73 70 65 63 28 64 6c 6c 65 78 70 6f 72 74  clspec(dllexport
4470: 29 0a 23 65 6e 64 69 66 0a 69 6e 74 20 73 71 6c  ).#endif.int sql
4480: 69 74 65 33 5f 63 6f 6d 70 6c 65 74 69 6f 6e 5f  ite3_completion_
4490: 69 6e 69 74 28 0a 20 20 73 71 6c 69 74 65 33 20  init(.  sqlite3 
44a0: 2a 64 62 2c 20 0a 20 20 63 68 61 72 20 2a 2a 70  *db, .  char **p
44b0: 7a 45 72 72 4d 73 67 2c 20 0a 20 20 63 6f 6e 73  zErrMsg, .  cons
44c0: 74 20 73 71 6c 69 74 65 33 5f 61 70 69 5f 72 6f  t sqlite3_api_ro
44d0: 75 74 69 6e 65 73 20 2a 70 41 70 69 0a 29 7b 0a  utines *pApi.){.
44e0: 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54    int rc = SQLIT
44f0: 45 5f 4f 4b 3b 0a 20 20 53 51 4c 49 54 45 5f 45  E_OK;.  SQLITE_E
4500: 58 54 45 4e 53 49 4f 4e 5f 49 4e 49 54 32 28 70  XTENSION_INIT2(p
4510: 41 70 69 29 3b 0a 20 20 28 76 6f 69 64 29 28 70  Api);.  (void)(p
4520: 7a 45 72 72 4d 73 67 29 3b 20 20 2f 2a 20 55 6e  zErrMsg);  /* Un
4530: 75 73 65 64 20 70 61 72 61 6d 65 74 65 72 20 2a  used parameter *
4540: 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  /.#ifndef SQLITE
4550: 5f 4f 4d 49 54 5f 56 49 52 54 55 41 4c 54 41 42  _OMIT_VIRTUALTAB
4560: 4c 45 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  LE.  rc = sqlite
4570: 33 43 6f 6d 70 6c 65 74 69 6f 6e 56 74 61 62 49  3CompletionVtabI
4580: 6e 69 74 28 64 62 29 3b 0a 23 65 6e 64 69 66 0a  nit(db);.#endif.
4590: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a       return rc;.}.