sqlite3.inc 90 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464
  1. {$mode objfpc}{$h+}
  2. {$ifdef BSD}
  3. {$linklib c}
  4. {$linklib pthread}
  5. {$endif}
  6. {$packrecords C}
  7. {.$DEFINE SQLITE_OBSOLETE}
  8. interface
  9. uses
  10. ctypes,
  11. {$ifdef LOAD_DYNAMICALLY}
  12. SysUtils, DynLibs;
  13. {$else}
  14. DynLibs;
  15. {$ifdef darwin}
  16. {$linklib sqlite3}
  17. {$endif}
  18. {$endif}
  19. const
  20. {$IFDEF WINDOWS}
  21. Sqlite3Lib = 'sqlite3.dll';
  22. {$else}
  23. Sqlite3Lib = 'libsqlite3.'+sharedsuffix;
  24. {$endif}
  25. {$IFDEF LOAD_DYNAMICALLY}
  26. {$DEFINE D}
  27. {$ELSE}
  28. {$DEFINE S}
  29. {$ENDIF}
  30. {
  31. Header converted from Sqlite version 3.14.2
  32. }
  33. //SQLITE_EXTERN const char sqlite3_version[];
  34. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_libversion{$IFDEF D}: function{$ENDIF}(): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  35. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_libversion_number{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  36. function sqlite3_version(): pansichar;
  37. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_threadsafe{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  38. type
  39. ppsqlite3 = ^psqlite3;
  40. psqlite3 = ^_sqlite3;
  41. _sqlite3 = record end;
  42. type
  43. sqlite3_destructor_type = procedure(user: pointer); cdecl;
  44. const
  45. SQLITE_STATIC = sqlite3_destructor_type(nil);
  46. SQLITE_TRANSIENT = pointer(-1); //sqlite3_destructor_type(-1);
  47. type
  48. psqlite_int64 = ^sqlite_int64;
  49. sqlite_int64 = Int64;
  50. psqlite_uint64 = ^sqlite_uint64;
  51. sqlite_uint64 = QWord;
  52. psqlite3_int64 = ^sqlite3_int64;
  53. sqlite3_int64 = sqlite_int64;
  54. psqlite3_uint64 = ^sqlite3_uint64;
  55. sqlite3_uint64 = sqlite_uint64;
  56. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_close{$IFDEF D}: function{$ENDIF}(ref: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  57. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_close_v2{$IFDEF D}: function{$ENDIF}(ref: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  58. type
  59. sqlite3_callback = function(user: pointer; cols: cint; values, name: ppansichar): cint; cdecl;
  60. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_exec{$IFDEF D}: function{$ENDIF}(
  61. db: psqlite3; (* An open database *)
  62. sql: pansichar; (* SQL to be evaluted *)
  63. cb: sqlite3_callback; (* Callback function *)
  64. user: pointer; (* 1st argument to callback *)
  65. errmsg: ppansichar (* Error msg written here *)
  66. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  67. const
  68. SQLITE_OK = 0; (* Successful result *)
  69. (* beginning-of-error-codes *)
  70. SQLITE_ERROR = 1; (* SQL error or missing database *)
  71. SQLITE_INTERNAL = 2; (* Internal logic error in SQLite *)
  72. SQLITE_PERM = 3; (* Access permission denied *)
  73. SQLITE_ABORT = 4; (* Callback routine requested an abort *)
  74. SQLITE_BUSY = 5; (* The database file is locked *)
  75. SQLITE_LOCKED = 6; (* A table in the database is locked *)
  76. SQLITE_NOMEM = 7; (* A malloc() failed *)
  77. SQLITE_READONLY = 8; (* Attempt to write a readonly database *)
  78. SQLITE_INTERRUPT = 9; (* Operation terminated by sqlite3_interrupt()*)
  79. SQLITE_IOERR = 10; (* Some kind of disk I/O error occurred *)
  80. SQLITE_CORRUPT = 11; (* The database disk image is malformed *)
  81. SQLITE_NOTFOUND = 12; (* NOT USED. Table or record not found *)
  82. SQLITE_FULL = 13; (* Insertion failed because database is full *)
  83. SQLITE_CANTOPEN = 14; (* Unable to open the database file *)
  84. SQLITE_PROTOCOL = 15; (* NOT USED. Database lock protocol error *)
  85. SQLITE_EMPTY = 16; (* Database is empty *)
  86. SQLITE_SCHEMA = 17; (* The database schema changed *)
  87. SQLITE_TOOBIG = 18; (* String or BLOB exceeds size limit *)
  88. SQLITE_CONSTRAINT = 19; (* Abort due to constraint violation *)
  89. SQLITE_MISMATCH = 20; (* Data type mismatch *)
  90. SQLITE_MISUSE = 21; (* Library used incorrectly *)
  91. SQLITE_NOLFS = 22; (* Uses OS features not supported on host *)
  92. SQLITE_AUTH = 23; (* Authorization denied *)
  93. SQLITE_FORMAT = 24; (* Auxiliary database format error *)
  94. SQLITE_RANGE = 25; (* 2nd parameter to sqlite3_bind out of range *)
  95. SQLITE_NOTADB = 26; (* File opened that is not a database file *)
  96. SQLITE_NOTICE = 27; (* Notifications from sqlite3_log() *)
  97. SQLITE_WARNING = 28; (* Warnings from sqlite3_log() *)
  98. SQLITE_ROW = 100; (* sqlite3_step() has another row ready *)
  99. SQLITE_DONE = 101; (* sqlite3_step() has finished executing *)
  100. SQLITE_IOERR_READ = (SQLITE_IOERR or (1 shl 8));
  101. SQLITE_IOERR_SHORT_READ = (SQLITE_IOERR or (2 shl 8));
  102. SQLITE_IOERR_WRITE = (SQLITE_IOERR or (3 shl 8));
  103. SQLITE_IOERR_FSYNC = (SQLITE_IOERR or (4 shl 8));
  104. SQLITE_IOERR_DIR_FSYNC = (SQLITE_IOERR or (5 shl 8));
  105. SQLITE_IOERR_TRUNCATE = (SQLITE_IOERR or (6 shl 8));
  106. SQLITE_IOERR_FSTAT = (SQLITE_IOERR or (7 shl 8));
  107. SQLITE_IOERR_UNLOCK = (SQLITE_IOERR or (8 shl 8));
  108. SQLITE_IOERR_RDLOCK = (SQLITE_IOERR or (9 shl 8));
  109. SQLITE_IOERR_DELETE = (SQLITE_IOERR or (10 shl 8));
  110. SQLITE_IOERR_BLOCKED = (SQLITE_IOERR or (11 shl 8));
  111. SQLITE_IOERR_NOMEM = (SQLITE_IOERR or (12 shl 8));
  112. SQLITE_IOERR_ACCESS = (SQLITE_IOERR or (13 shl 8));
  113. SQLITE_IOERR_CHECKRESERVEDLOCK = (SQLITE_IOERR or (14 shl 8));
  114. SQLITE_IOERR_LOCK = (SQLITE_IOERR or (15 shl 8));
  115. SQLITE_IOERR_CLOSE = (SQLITE_IOERR or (16 shl 8));
  116. SQLITE_IOERR_DIR_CLOSE = (SQLITE_IOERR or (17 shl 8));
  117. SQLITE_IOERR_SHMOPEN = (SQLITE_IOERR or (18 shl 8));
  118. SQLITE_IOERR_SHMSIZE = (SQLITE_IOERR or (19 shl 8));
  119. SQLITE_IOERR_SHMLOCK = (SQLITE_IOERR or (20 shl 8));
  120. SQLITE_IOERR_SHMMAP = (SQLITE_IOERR or (21 shl 8));
  121. SQLITE_IOERR_SEEK = (SQLITE_IOERR or (22 shl 8));
  122. SQLITE_IOERR_DELETE_NOENT = (SQLITE_IOERR or (23 shl 8));
  123. SQLITE_IOERR_MMAP = (SQLITE_IOERR or (24 shl 8));
  124. SQLITE_IOERR_GETTEMPPATH = (SQLITE_IOERR or (25 shl 8));
  125. SQLITE_IOERR_CONVPATH = (SQLITE_IOERR or (26 shl 8));
  126. SQLITE_IOERR_VNODE = (SQLITE_IOERR or (27 shl 8));
  127. SQLITE_IOERR_AUTH = (SQLITE_IOERR or (28 shl 8));
  128. SQLITE_LOCKED_SHAREDCACHE = (SQLITE_LOCKED or (1 shl 8));
  129. SQLITE_BUSY_RECOVERY = (SQLITE_BUSY or (1 shl 8));
  130. SQLITE_BUSY_SNAPSHOT = (SQLITE_BUSY or (2 shl 8));
  131. SQLITE_CANTOPEN_NOTEMPDIR = (SQLITE_CANTOPEN or (1 shl 8));
  132. SQLITE_CANTOPEN_ISDIR = (SQLITE_CANTOPEN or (2 shl 8));
  133. SQLITE_CANTOPEN_FULLPATH = (SQLITE_CANTOPEN or (3 shl 8));
  134. SQLITE_CANTOPEN_CONVPATH = (SQLITE_CANTOPEN or (4 shl 8));
  135. SQLITE_CORRUPT_VTAB = (SQLITE_CORRUPT or (1 shl 8));
  136. SQLITE_READONLY_RECOVERY = (SQLITE_READONLY or (1 shl 8));
  137. SQLITE_READONLY_CANTLOCK = (SQLITE_READONLY or (2 shl 8));
  138. SQLITE_READONLY_ROLLBACK = (SQLITE_READONLY or (3 shl 8));
  139. SQLITE_READONLY_DBMOVED = (SQLITE_READONLY or (4 shl 8));
  140. SQLITE_ABORT_ROLLBACK = (SQLITE_ABORT or (2 shl 8));
  141. SQLITE_CONSTRAINT_CHECK = (SQLITE_CONSTRAINT or (1 shl 8));
  142. SQLITE_CONSTRAINT_COMMITHOOK = (SQLITE_CONSTRAINT or (2 shl 8));
  143. SQLITE_CONSTRAINT_FOREIGNKEY = (SQLITE_CONSTRAINT or (3 shl 8));
  144. SQLITE_CONSTRAINT_FUNCTION = (SQLITE_CONSTRAINT or (4 shl 8));
  145. SQLITE_CONSTRAINT_NOTNULL = (SQLITE_CONSTRAINT or (5 shl 8));
  146. SQLITE_CONSTRAINT_PRIMARYKEY = (SQLITE_CONSTRAINT or (6 shl 8));
  147. SQLITE_CONSTRAINT_TRIGGER = (SQLITE_CONSTRAINT or (7 shl 8));
  148. SQLITE_CONSTRAINT_UNIQUE = (SQLITE_CONSTRAINT or (8 shl 8));
  149. SQLITE_CONSTRAINT_VTAB = (SQLITE_CONSTRAINT or (9 shl 8));
  150. SQLITE_CONSTRAINT_ROWID = (SQLITE_CONSTRAINT or (10 shl 8));
  151. SQLITE_NOTICE_RECOVER_WAL = (SQLITE_NOTICE or (1 shl 8));
  152. SQLITE_NOTICE_RECOVER_ROLLBACK = (SQLITE_NOTICE or (2 shl 8));
  153. SQLITE_WARNING_AUTOINDEX = (SQLITE_WARNING or (1 shl 8));
  154. SQLITE_AUTH_USER = (SQLITE_AUTH or (1 shl 8));
  155. SQLITE_OK_LOAD_PERMANENTLY = (SQLITE_OK or (1 shl 8));
  156. SQLITE_OPEN_READONLY = $00000001;
  157. SQLITE_OPEN_READWRITE = $00000002;
  158. SQLITE_OPEN_CREATE = $00000004;
  159. SQLITE_OPEN_DELETEONCLOSE = $00000008;
  160. SQLITE_OPEN_EXCLUSIVE = $00000010;
  161. SQLITE_OPEN_AUTOPROXY = $00000020; (* VFS only *)
  162. SQLITE_OPEN_URI = $00000040; (* Ok for sqlite3_open_v2() *)
  163. SQLITE_OPEN_MEMORY = $00000080; (* Ok for sqlite3_open_v2() *)
  164. SQLITE_OPEN_MAIN_DB = $00000100;
  165. SQLITE_OPEN_TEMP_DB = $00000200;
  166. SQLITE_OPEN_TRANSIENT_DB = $00000400;
  167. SQLITE_OPEN_MAIN_JOURNAL = $00000800;
  168. SQLITE_OPEN_TEMP_JOURNAL = $00001000;
  169. SQLITE_OPEN_SUBJOURNAL = $00002000;
  170. SQLITE_OPEN_MASTER_JOURNAL = $00004000;
  171. SQLITE_OPEN_NOMUTEX = $00008000;
  172. SQLITE_OPEN_FULLMUTEX = $00010000;
  173. SQLITE_OPEN_SHAREDCACHE = $00020000;
  174. SQLITE_OPEN_PRIVATECACHE = $00040000;
  175. SQLITE_OPEN_WAL = $00080000;
  176. SQLITE_IOCAP_ATOMIC = $00000001;
  177. SQLITE_IOCAP_ATOMIC512 = $00000002;
  178. SQLITE_IOCAP_ATOMIC1K = $00000004;
  179. SQLITE_IOCAP_ATOMIC2K = $00000008;
  180. SQLITE_IOCAP_ATOMIC4K = $00000010;
  181. SQLITE_IOCAP_ATOMIC8K = $00000020;
  182. SQLITE_IOCAP_ATOMIC16K = $00000040;
  183. SQLITE_IOCAP_ATOMIC32K = $00000080;
  184. SQLITE_IOCAP_ATOMIC64K = $00000100;
  185. SQLITE_IOCAP_SAFE_APPEND = $00000200;
  186. SQLITE_IOCAP_SEQUENTIAL = $00000400;
  187. SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN = $00000800;
  188. SQLITE_IOCAP_POWERSAFE_OVERWRITE = $00001000;
  189. SQLITE_IOCAP_IMMUTABLE = $00002000;
  190. SQLITE_LOCK_NONE = 0;
  191. SQLITE_LOCK_SHARED = 1;
  192. SQLITE_LOCK_RESERVED = 2;
  193. SQLITE_LOCK_PENDING = 3;
  194. SQLITE_LOCK_EXCLUSIVE = 4;
  195. SQLITE_SYNC_NORMAL = $00002;
  196. SQLITE_SYNC_FULL = $00003;
  197. SQLITE_SYNC_DATAONLY = $00010;
  198. type
  199. psqlite3_io_methods = ^sqlite3_io_methods;
  200. psqlite3_file = ^sqlite3_file;
  201. sqlite3_file = record
  202. pMethods: psqlite3_io_methods; (* Methods for an open file *)
  203. end;
  204. sqlite3_io_methods = record
  205. iVersion : cint;
  206. Close : function(f: psqlite3_file): cint; stdcall;
  207. Read : function(f: psqlite3_file; addr: pointer; iAmt: cint; iOfst: sqlite3_int64): cint; stdcall;
  208. Write : function(f: psqlite3_file; size: sqlite3_int64): cint; stdcall;
  209. Truncate : function(f: psqlite3_file; size: sqlite3_int64): cint; stdcall;
  210. Sync : function(f: psqlite3_file; flags: cint): cint; stdcall;
  211. FileSize : function(f: psqlite3_file; pSize: psqlite3_int64): cint; stdcall;
  212. Lock : function(f: psqlite3_file; flags: cint): cint; stdcall;
  213. Unlock : function(f: psqlite3_file; flags: cint): cint; stdcall;
  214. CheckReservedLock : function(f: psqlite3_file): cint; stdcall;
  215. FileControl : function(f: psqlite3_file; op: cint; pArg: pointer): cint; stdcall;
  216. SectorSize : function(f: psqlite3_file): cint; stdcall;
  217. DeviceCharacteristics: function(f: psqlite3_file): cint; stdcall;
  218. xShmMap : function(f : psqlite3_file; iPg: cint; pgsz: cint; volatile : pointer) : cint;stdcall;
  219. xShmLock : function(f : psqlite3_file; offset: cint; n : cint; flags : cint) : cint; stdcall;
  220. xShmBarrier : procedure (f : psqlite3_file); stdcall;
  221. xShmUnmap : function(f : psqlite3_file; deleteFlag : cint) : cint; stdcall;
  222. (* Methods above are valid for version 2 *)
  223. xFetch : function(f: psqlite3_file; iOfst: sqlite3_int64; iAmt: cint; pp: PPointer) : cint; stdcall;
  224. xUnfetch : function(f: psqlite3_file; iOfst: sqlite3_int64; p: Pointer) : cint; stdcall;
  225. (* Methods above are valid for version 3 *)
  226. (* Additional methods may be added in future releases *)
  227. end;
  228. const
  229. SQLITE_FCNTL_LOCKSTATE = 1;
  230. SQLITE_FCNTL_GET_LOCKPROXYFILE = 2;
  231. SQLITE_FCNTL_SET_LOCKPROXYFILE = 3;
  232. SQLITE_FCNTL_LAST_ERRNO = 4;
  233. SQLITE_FCNTL_SIZE_HINT = 5;
  234. SQLITE_FCNTL_CHUNK_SIZE = 6;
  235. SQLITE_FCNTL_FILE_POINTER = 7;
  236. SQLITE_FCNTL_SYNC_OMITTED = 8;
  237. SQLITE_FCNTL_WIN32_AV_RETRY = 9;
  238. SQLITE_FCNTL_PERSIST_WAL = 10;
  239. SQLITE_FCNTL_OVERWRITE = 11;
  240. SQLITE_FCNTL_VFSNAME = 12;
  241. SQLITE_FCNTL_POWERSAFE_OVERWRITE = 13;
  242. SQLITE_FCNTL_PRAGMA = 14;
  243. SQLITE_FCNTL_BUSYHANDLER = 15;
  244. SQLITE_FCNTL_TEMPFILENAME = 16;
  245. SQLITE_FCNTL_MMAP_SIZE = 18;
  246. SQLITE_FCNTL_TRACE = 19;
  247. SQLITE_FCNTL_HAS_MOVED = 20;
  248. SQLITE_FCNTL_SYNC = 21;
  249. SQLITE_FCNTL_COMMIT_PHASETWO = 22;
  250. SQLITE_FCNTL_WIN32_SET_HANDLE = 23;
  251. SQLITE_FCNTL_WAL_BLOCK = 24;
  252. SQLITE_FCNTL_ZIPVFS = 25;
  253. SQLITE_FCNTL_RBU = 26;
  254. SQLITE_FCNTL_VFS_POINTER = 27;
  255. SQLITE_FCNTL_JOURNAL_POINTER = 28;
  256. (* deprecated names *)
  257. SQLITE_GET_LOCKPROXYFILE = SQLITE_FCNTL_GET_LOCKPROXYFILE;
  258. SQLITE_SET_LOCKPROXYFILE = SQLITE_FCNTL_SET_LOCKPROXYFILE;
  259. SQLITE_LAST_ERRNO = SQLITE_FCNTL_LAST_ERRNO;
  260. type
  261. psqlite3_mutex = ^sqlite3_mutex;
  262. sqlite3_mutex = record end;
  263. type
  264. psqlite3_vfs = ^sqlite3_vfs;
  265. sqlite3_vfs = record
  266. iVersion : cint; (* Structure version number *)
  267. szOsFile : cint; (* Size of subclassed sqlite3_file *)
  268. mxPathname : cint; (* Maximum file pathname length *)
  269. pNext : psqlite3_vfs; (* Next registered VFS *)
  270. zName : pansichar; (* Name of this virtual file system *)
  271. pAppData : ppointer; (* Pointer to application-specific *)
  272. Open : function(vfs: psqlite3_vfs; zName: pansichar; f: psqlite3_file; flags: cint; pOutFlags: pcint): cint; cdecl;
  273. Delete : function(vfs: psqlite3_vfs; zName: pansichar; syncDir: cint): cint; cdecl;
  274. Access : function(vfs: psqlite3_vfs; zName: pansichar; flags: cint): cint; cdecl;
  275. FullPathname : function(vfs: psqlite3_vfs; zName: pansichar; nOut: cint; zOut: pansichar): cint; cdecl;
  276. DlOpen : function(vfs: psqlite3_vfs; zFilename: pansichar): pointer; cdecl;
  277. DlError : procedure(vfs: psqlite3_vfs; nByte: cint; zErrMsg: pansichar); cdecl;
  278. DlSym : function(vfs: psqlite3_vfs; addr: pointer; zSymbol: pansichar): pointer; cdecl;
  279. DlClose : procedure(vfs: psqlite3_vfs; addr: pointer); cdecl;
  280. Randomness : function(vfs: psqlite3_vfs; nByte: cint; zOut: pansichar): cint; cdecl;
  281. Sleep : function(vfs: psqlite3_vfs; microseconds: cint): cint; cdecl;
  282. CurrentTime : function(vfs: psqlite3_vfs; time: pcdouble): cint; cdecl;
  283. GetLastError : function(vfs: psqlite3_vfs; code: cint; msg: pansichar): cint; cdecl;
  284. CurrentTimeInt64 : function(vfs: psqlite3_vfs; time: psqlite3_int64): cint; cdecl;
  285. xSetSystemCall : function(vfs: psqlite3_vfs; zName: pansichar; sqlite3_syscall_ptr : pointer) : cint; cdecl;
  286. xGetSystemCall : function(vfs: psqlite3_vfs; zName: pansichar) : pointer; cdecl;
  287. xNextSystemCall : function(vfs: psqlite3_vfs; zName: pansichar) : pansichar; cdecl;
  288. end;
  289. const
  290. SQLITE_ACCESS_EXISTS = 0;
  291. SQLITE_ACCESS_READWRITE = 1;
  292. SQLITE_ACCESS_READ = 2;
  293. SQLITE_SHM_UNLOCK = 1;
  294. SQLITE_SHM_LOCK = 2;
  295. SQLITE_SHM_SHARED = 4;
  296. SQLITE_SHM_EXCLUSIVE = 8;
  297. SQLITE_SHM_NLOCK = 8;
  298. {$IFDEF S}
  299. function sqlite3_initialize : cint;cdecl; external Sqlite3Lib;
  300. function sqlite3_shutdown : cint;cdecl; external Sqlite3Lib;
  301. function sqlite3_os_init : cint;cdecl; external Sqlite3Lib;
  302. function sqlite3_os_end : cint;cdecl; external Sqlite3Lib;
  303. {$endif}
  304. {$ifdef D}
  305. Var
  306. sqlite3_initialize,
  307. sqlite3_shutdown,
  308. sqlite3_os_init,
  309. sqlite3_os_end : Function : cint; cdecl;
  310. {$endif}
  311. {$IFDEF S}
  312. function sqlite3_config (a : cint): cint;cdecl;varargs; external Sqlite3Lib;
  313. {$ENDIF}
  314. {$IFDEF D}
  315. var
  316. sqlite3_config : function (a : cint): cint;cdecl;varargs;
  317. {$ENDIF}
  318. {$IFDEF S}
  319. function sqlite3_db_config (f : psqlite3; op : cint):cint;cdecl;varargs;external Sqlite3Lib;
  320. {$ENDIF}
  321. {$IFDEF D}
  322. var
  323. sqlite3_db_config : function (f : psqlite3; op : cint): cint;cdecl;varargs;
  324. {$ENDIF}
  325. Type
  326. sqlite3_mem_methods = record
  327. xMalloc : function(size : cint) : pointer;cdecl;
  328. xFree : procedure(p : pointer); cdecl;
  329. xRealloc : function(p : pointer;size : cint) : pointer;cdecl;
  330. xSize : function(p : pointer) : cint; cdecl;
  331. xRoundup : function(size : cint) : cint; cdecl;
  332. xInit : function(): cint; cdecl;
  333. xShutdown : procedure(p : pointer); cdecl;
  334. pAppData: pointer;
  335. end;
  336. Tsqlite3_mem_methods = sqlite3_mem_methods;
  337. Const
  338. SQLITE_CONFIG_SINGLETHREAD = 1;
  339. SQLITE_CONFIG_MULTITHREAD = 2;
  340. SQLITE_CONFIG_SERIALIZED = 3;
  341. SQLITE_CONFIG_MALLOC = 4;
  342. SQLITE_CONFIG_GETMALLOC = 5;
  343. SQLITE_CONFIG_SCRATCH = 6;
  344. SQLITE_CONFIG_PAGECACHE = 7;
  345. SQLITE_CONFIG_HEAP = 8;
  346. SQLITE_CONFIG_MEMSTATUS = 9;
  347. SQLITE_CONFIG_MUTEX = 10;
  348. SQLITE_CONFIG_GETMUTEX = 11;
  349. SQLITE_CONFIG_LOOKASIDE = 13;
  350. SQLITE_CONFIG_PCACHE = 14;
  351. SQLITE_CONFIG_GETPCACHE = 15;
  352. SQLITE_CONFIG_LOG = 16;
  353. SQLITE_CONFIG_URI = 17;
  354. SQLITE_CONFIG_PCACHE2 = 18; (* sqlite3_pcache_methods2* *)
  355. SQLITE_CONFIG_GETPCACHE2 = 19; (* sqlite3_pcache_methods2* *)
  356. SQLITE_CONFIG_COVERING_INDEX_SCAN = 20; (* int *)
  357. SQLITE_CONFIG_SQLLOG = 21; (* xSqllog, void* *)
  358. SQLITE_CONFIG_MMAP_SIZE = 22; (* sqlite3_int64, sqlite3_int64 *)
  359. SQLITE_CONFIG_WIN32_HEAPSIZE = 23; (* int nByte *)
  360. SQLITE_CONFIG_PCACHE_HDRSZ = 24; (* int *psz *)
  361. SQLITE_CONFIG_PMASZ = 25; (* unsigned int szPma *)
  362. SQLITE_CONFIG_STMTJRNL_SPILL = 26; (* int nByte *)
  363. SQLITE_DBCONFIG_LOOKASIDE = 1001;
  364. SQLITE_DBCONFIG_ENABLE_FKEY = 1002;
  365. SQLITE_DBCONFIG_ENABLE_TRIGGER = 1003;
  366. SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER = 1004;
  367. SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION = 1005;
  368. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_extended_result_codes{$IFDEF D}: function{$ENDIF}(db: psqlite3; onoff: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  369. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_last_insert_rowid{$IFDEF D}: function{$ENDIF}(db: psqlite3): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  370. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_changes{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  371. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_total_changes{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  372. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_interrupt{$IFDEF D}: procedure{$ENDIF}(db: psqlite3); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  373. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_complete{$IFDEF D}: function{$ENDIF}(sql: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  374. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_complete16{$IFDEF D}: function{$ENDIF}(sql: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  375. type
  376. busyhandler_callback = function(user: pointer; cnt: cint): cint; cdecl;
  377. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_busy_handler{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: busyhandler_callback; user: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  378. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_busy_timeout{$IFDEF D}: function{$ENDIF}(db: psqlite3; ms: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  379. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_get_table{$IFDEF D}: function{$ENDIF}(
  380. db: psqlite3; (* An open database *)
  381. sql: pansichar; (* SQL to be evaluated *)
  382. pResult: pppansichar; (* Results of the query *)
  383. nrow: pcint; (* Number of result rows written here *)
  384. ncolumn: pcint; (* Number of result columns written here *)
  385. errmsg: ppansichar (* Error msg written here *)
  386. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  387. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_free_table{$IFDEF D}: procedure{$ENDIF}(result: ppansichar); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  388. //char *sqlite3_mprintf(const char*,...);
  389. //char *sqlite3_vmprintf(const char*, va_list);
  390. //char *sqlite3_snprintf(int,char*,const char*, ...);
  391. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_malloc{$IFDEF D}: function{$ENDIF}(size: cint): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  392. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_malloc64{$IFDEF D}: function{$ENDIF}(size: sqlite3_uint64): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  393. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_realloc{$IFDEF D}: function{$ENDIF}(ptr: pointer; size: cint): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  394. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_realloc64{$IFDEF D}: function{$ENDIF}(ptr: pointer; size: sqlite3_uint64): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  395. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_free{$IFDEF D}: procedure{$ENDIF}(ptr: pointer);cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  396. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_msize{$IFDEF D}: function{$ENDIF}(ptr: pointer): sqlite3_uint64;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  397. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_memory_used{$IFDEF D}: function{$ENDIF}(): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  398. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_memory_highwater{$IFDEF D}: function{$ENDIF}(resetFlag: cint): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  399. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_randomness{$IFDEF D}: procedure{$ENDIF}(N: cint; P: pointer); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  400. type
  401. xAuth = function(pUserData: pointer; code: cint; s1, s2, s3, s4: pansichar): cint; cdecl;
  402. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_set_authorizer{$IFDEF D}: function{$ENDIF}(
  403. db: psqlite3;
  404. cb: xAuth;
  405. pUserData: pointer
  406. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  407. const
  408. SQLITE_DENY = 1; (* Abort the SQL statement with an error *)
  409. SQLITE_IGNORE = 2; (* Don't allow access, but don't generate an error *)
  410. const
  411. SQLITE_CREATE_INDEX = 1; (* Index Name Table Name *)
  412. SQLITE_CREATE_TABLE = 2; (* Table Name NULL *)
  413. SQLITE_CREATE_TEMP_INDEX = 3; (* Index Name Table Name *)
  414. SQLITE_CREATE_TEMP_TABLE = 4; (* Table Name NULL *)
  415. SQLITE_CREATE_TEMP_TRIGGER = 5; (* Trigger Name Table Name *)
  416. SQLITE_CREATE_TEMP_VIEW = 6; (* View Name NULL *)
  417. SQLITE_CREATE_TRIGGER = 7; (* Trigger Name Table Name *)
  418. SQLITE_CREATE_VIEW = 8; (* View Name NULL *)
  419. SQLITE_DELETE = 9; (* Table Name NULL *)
  420. SQLITE_DROP_INDEX = 10; (* Index Name Table Name *)
  421. SQLITE_DROP_TABLE = 11; (* Table Name NULL *)
  422. SQLITE_DROP_TEMP_INDEX = 12; (* Index Name Table Name *)
  423. SQLITE_DROP_TEMP_TABLE = 13; (* Table Name NULL *)
  424. SQLITE_DROP_TEMP_TRIGGER = 14; (* Trigger Name Table Name *)
  425. SQLITE_DROP_TEMP_VIEW = 15; (* View Name NULL *)
  426. SQLITE_DROP_TRIGGER = 16; (* Trigger Name Table Name *)
  427. SQLITE_DROP_VIEW = 17; (* View Name NULL *)
  428. SQLITE_INSERT = 18; (* Table Name NULL *)
  429. SQLITE_PRAGMA = 19; (* Pragma Name 1st arg or NULL *)
  430. SQLITE_READ = 20; (* Table Name Column Name *)
  431. SQLITE_SELECT = 21; (* NULL NULL *)
  432. SQLITE_TRANSACTION = 22; (* NULL NULL *)
  433. SQLITE_UPDATE = 23; (* Table Name Column Name *)
  434. SQLITE_ATTACH = 24; (* Filename NULL *)
  435. SQLITE_DETACH = 25; (* Database Name NULL *)
  436. SQLITE_ALTER_TABLE = 26; (* Database Name Table Name *)
  437. SQLITE_REINDEX = 27; (* Index Name NULL *)
  438. SQLITE_ANALYZE = 28; (* Table Name NULL *)
  439. SQLITE_CREATE_VTABLE = 29; (* Table Name Module Name *)
  440. SQLITE_DROP_VTABLE = 30; (* Table Name Module Name *)
  441. SQLITE_FUNCTION = 31; (* Function Name NULL *)
  442. SQLITE_SAVEPOINT = 32; (* Operation Savepoint Name *)
  443. SQLITE_COPY = 0; (* No longer used *)
  444. SQLITE_RECURSIVE = 33; (* NULL NULL *)
  445. type
  446. xTrace = procedure(user: pointer; s: pansichar); cdecl; deprecated;
  447. xProfile = procedure(user: pointer; s: pansichar; i: sqlite3_uint64); cdecl; deprecated;
  448. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_trace{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: xTrace; user: pointer): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  449. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_profile{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: xProfile; user: pointer): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  450. type
  451. progress_callback = function(user: pointer): cint; cdecl;
  452. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_progress_handler{$IFDEF D}: procedure{$ENDIF}(db: psqlite3; i: cint; cb: progress_callback; user: pointer); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  453. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open{$IFDEF D}: function{$ENDIF}(
  454. filename: pansichar; (* Database filename (UTF-8) *)
  455. ppDb: ppsqlite3 (* OUT: SQLite db handle *)
  456. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  457. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open16{$IFDEF D}: function{$ENDIF}(
  458. filename: pwidechar; (* Database filename (UTF-16) *)
  459. ppDb: ppsqlite3 (* OUT: SQLite db handle *)
  460. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  461. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open_v2{$IFDEF D}: function{$ENDIF}(
  462. filename: pansichar; (* Database filename (UTF-8) *)
  463. ppDb: ppsqlite3; (* OUT: SQLite db handle *)
  464. flags: cint; (* Flags *)
  465. zVfs: pansichar (* Name of VFS module to use *)
  466. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  467. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_uri_parameter{$IFDEF D}: function{$ENDIF}(zFilename : pansichar; zParam: pansichar) : pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  468. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_uri_boolean{$IFDEF D}: function{$ENDIF}(zFile : pansichar; zParam :pansichar; bDefault: cint) : cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  469. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_uri_int64{$IFDEF D}: function{$ENDIF}(zFile : pansichar; zParam :pansichar; iDefault: sqlite3_int64) : sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  470. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errcode{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  471. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_extended_errcode{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  472. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errmsg{$IFDEF D}: function{$ENDIF}(db: psqlite3): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  473. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errmsg16{$IFDEF D}: function{$ENDIF}(db: psqlite3): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  474. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errstr{$IFDEF D}: function{$ENDIF}(errCode: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  475. type
  476. ppsqlite3_stmt = ^psqlite3_stmt;
  477. psqlite3_stmt = ^sqlite3_stmt;
  478. sqlite3_stmt = record end;
  479. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_limit{$IFDEF D}: function{$ENDIF}(db: psqlite3; id: cint; newVal: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  480. const
  481. SQLITE_LIMIT_LENGTH = 0;
  482. SQLITE_LIMIT_SQL_LENGTH = 1;
  483. SQLITE_LIMIT_COLUMN = 2;
  484. SQLITE_LIMIT_EXPR_DEPTH = 3;
  485. SQLITE_LIMIT_COMPOUND_SELECT = 4;
  486. SQLITE_LIMIT_VDBE_OP = 5;
  487. SQLITE_LIMIT_FUNCTION_ARG = 6;
  488. SQLITE_LIMIT_ATTACHED = 7;
  489. SQLITE_LIMIT_LIKE_PATTERN_LENGTH = 8;
  490. SQLITE_LIMIT_VARIABLE_NUMBER = 9;
  491. SQLITE_LIMIT_TRIGGER_DEPTH = 10;
  492. SQLITE_LIMIT_WORKER_THREADS = 11;
  493. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare{$IFDEF D}: function{$ENDIF}(
  494. db: psqlite3; (* Database handle *)
  495. zSql: pansichar; (* SQL statement, UTF-8 encoded *)
  496. nByte: cint; (* Maximum length of zSql in bytes. *)
  497. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  498. pzTail: ppansichar (* OUT: Pointer to unused portion of zSql *)
  499. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  500. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare_v2{$IFDEF D}: function{$ENDIF}(
  501. db: psqlite3; (* Database handle *)
  502. zSql: pansichar; (* SQL statement, UTF-8 encoded *)
  503. nByte: cint; (* Maximum length of zSql in bytes. *)
  504. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  505. pzTail: ppansichar (* OUT: Pointer to unused portion of zSql *)
  506. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  507. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare16{$IFDEF D}: function{$ENDIF}(
  508. db: psqlite3; (* Database handle *)
  509. zSql: pwidechar; (* SQL statement, UTF-16 encoded *)
  510. nByte: cint; (* Maximum length of zSql in bytes. *)
  511. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  512. pzTail: ppwidechar (* OUT: Pointer to unused portion of zSql *)
  513. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  514. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare16_v2{$IFDEF D}: function{$ENDIF}(
  515. db: psqlite3; (* Database handle *)
  516. zSql: pwidechar; (* SQL statement, UTF-16 encoded *)
  517. nByte: cint; (* Maximum length of zSql in bytes. *)
  518. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  519. pzTail: ppwidechar (* OUT: Pointer to unused portion of zSql *)
  520. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  521. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_sql{$IFDEF D}: function{$ENDIF}(pStmt: psqlite3_stmt): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  522. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_expanded_sql{$IFDEF D}: function{$ENDIF}(pStmt: psqlite3_stmt): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  523. type
  524. ppsqlite3_value = ^psqlite3_value;
  525. psqlite3_value = ^sqlite3_value;
  526. sqlite3_value = record end;
  527. psqlite3_context = ^sqlite3_context;
  528. sqlite3_context = record end;
  529. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_blob{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pointer; L: cint; D: sqlite3_destructor_type): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  530. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_blob64{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pointer; L: sqlite3_uint64; D: sqlite3_destructor_type): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  531. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_double{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: cdouble): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  532. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_int{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  533. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_int64{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: sqlite3_int64): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  534. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_null{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  535. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_text{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pansichar; L: cint; D: sqlite3_destructor_type): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  536. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_text16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pwidechar; L: cint; D: sqlite3_destructor_type): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  537. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_text64{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pansichar; L: sqlite3_uint64; D: sqlite3_destructor_type; encoding: cuchar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  538. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_value{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  539. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_zeroblob{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  540. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_zeroblob64{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: sqlite3_uint64): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  541. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  542. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  543. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_index{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; zName: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  544. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_clear_bindings{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  545. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  546. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  547. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_name16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  548. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_database_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  549. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_database_name16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  550. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_table_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  551. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_table_name16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  552. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_origin_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  553. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_origin_name16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  554. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_decltype{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  555. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_decltype16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  556. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_step{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  557. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_data_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  558. const
  559. SQLITE_INTEGER = 1;
  560. SQLITE_FLOAT = 2;
  561. SQLITE_BLOB = 4;
  562. SQLITE_NULL = 5;
  563. SQLITE_TEXT = 3;
  564. SQLITE3_TEXT = 3;
  565. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_blob{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  566. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_bytes{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  567. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_bytes16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  568. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_double{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): cdouble; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  569. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_int{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  570. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_int64{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  571. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_text{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  572. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_text16{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  573. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_type{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  574. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_value{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): psqlite3_value; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  575. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_finalize{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  576. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_reset{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  577. type
  578. xFunc = procedure(ctx: psqlite3_context; N: cint; V: ppsqlite3_value); cdecl;
  579. xStep = procedure(ctx: psqlite3_context; N: cint; V: ppsqlite3_value); cdecl;
  580. xFinal = procedure(ctx: psqlite3_context); cdecl;
  581. xDestroy = sqlite3_destructor_type;
  582. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function{$IFDEF D}: function{$ENDIF}(
  583. db: psqlite3;
  584. zFunctionName: pansichar;
  585. nArg: cint;
  586. eTextRep: cint;
  587. pApp: pointer;
  588. funccb: xFunc;
  589. stepcb: xStep;
  590. finalcb: xFinal
  591. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  592. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function16{$IFDEF D}: function{$ENDIF}(
  593. db: psqlite3;
  594. zFunctionName: pwidechar;
  595. nArg: cint;
  596. eTextRep: cint;
  597. pApp: pointer;
  598. funccb: xFunc;
  599. stepcb: xStep;
  600. finalcb: xFinal
  601. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  602. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function_v2{$IFDEF D}: function{$ENDIF}(
  603. db: psqlite3;
  604. zFunctionName: pansichar;
  605. nArg: cint;
  606. eTextRep: cint;
  607. pApp: pointer;
  608. funccb: xFunc;
  609. stepcb: xStep;
  610. finalcb: xFinal;
  611. destroycb : xDestroy
  612. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  613. const
  614. SQLITE_UTF8 = 1;
  615. SQLITE_UTF16LE = 2;
  616. SQLITE_UTF16BE = 3;
  617. SQLITE_UTF16 = 4; (* Use native byte order *)
  618. SQLITE_ANY = 5; (* Deprecated *)
  619. SQLITE_UTF16_ALIGNED = 8; (* sqlite3_create_collation only *)
  620. SQLITE_DETERMINISTIC = $800;
  621. {$IFDEF SQLITE_OBSOLETE}
  622. type
  623. memory_alarm_cb = function(user: pointer; i64: sqlite3_int64; i: cint): pointer; cdecl;
  624. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_aggregate_count{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  625. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_expired{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  626. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_transfer_bindings{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; stmt2: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  627. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_global_recover{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  628. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_thread_cleanup{$IFDEF D}: procedure{$ENDIF}(); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  629. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_memory_alarm{$IFDEF D}: function{$ENDIF}(cb: memory_alarm_cb; user: pointer; i64: sqlite3_int64): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  630. {$ENDIF}
  631. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_blob{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  632. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_bytes{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  633. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_bytes16{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  634. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_double{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cdouble; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  635. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_int{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  636. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_int64{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  637. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  638. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  639. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16le{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  640. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16be{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  641. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_type{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  642. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_numeric_type{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  643. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_subtype{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cuint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  644. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_dup{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): psqlite3_value; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  645. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_value_free{$IFDEF D}: procedure{$ENDIF}(val: psqlite3_value); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  646. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_aggregate_context{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context; nBytes: cint): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  647. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_user_data{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  648. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_context_db_handle{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): psqlite3; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  649. type
  650. set_auxdata_cb = function(p: pointer): pointer; cdecl;
  651. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_get_auxdata{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context; N: cint): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  652. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_set_auxdata{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; N: cint; P: pointer; cb: set_auxdata_cb); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  653. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_blob{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pointer; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  654. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_blob64{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pointer; N: sqlite3_uint64; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  655. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_double{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cdouble); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  656. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pansichar; N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  657. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error16{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pwidechar; N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  658. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error_toobig{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  659. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error_nomem{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  660. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error_code{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  661. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_int{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  662. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_int64{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: sqlite3_int64); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  663. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_null{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  664. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pansichar; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  665. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text64{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pansichar; N: sqlite3_uint64; D: sqlite3_destructor_type; encoding: cuchar); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  666. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text16{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pwidechar; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  667. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text16le{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pwidechar; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  668. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text16be{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pwidechar; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  669. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_value{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: psqlite3_value); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  670. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_zeroblob{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  671. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_result_zeroblob64{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context; N: sqlite3_uint64): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  672. type
  673. xCompare = function(user: pointer; A: cint; B: pointer; C: cint; D: pointer): cint; cdecl;
  674. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation{$IFDEF D}: function{$ENDIF}(
  675. db: psqlite3;
  676. zName: pansichar;
  677. eTextRep: cint;
  678. user: pointer;
  679. xcomparecb: xCompare
  680. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  681. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation_v2{$IFDEF D}: function{$ENDIF}(
  682. db: psqlite3;
  683. zName: pansichar;
  684. eTextRep: cint;
  685. user: pointer;
  686. xcomparecb: xCompare;
  687. xdestroycb: xDestroy
  688. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  689. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation16{$IFDEF D}: function{$ENDIF}(
  690. db: psqlite3;
  691. zName: pwidechar;
  692. eTextRep: cint;
  693. user: pointer;
  694. xcomparecb: xCompare
  695. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  696. type
  697. collation_needed_cb = function(user: pointer; db: psqlite3; eTextRep: cint; s: pansichar): pointer; cdecl;
  698. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_collation_needed{$IFDEF D}: function{$ENDIF}(
  699. db: psqlite3;
  700. user: pointer;
  701. cb: collation_needed_cb
  702. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  703. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_collation_needed16{$IFDEF D}: function{$ENDIF}(
  704. db: psqlite3;
  705. user: pointer;
  706. cb: collation_needed_cb
  707. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  708. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_key{$IFDEF D}: function{$ENDIF}(
  709. db: psqlite3; (* Database to be rekeyed *)
  710. pKey: pointer; nKey: cint (* The key *)
  711. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  712. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_key_v2{$IFDEF D}: function{$ENDIF}(
  713. db: psqlite3; (* Database to be rekeyed *)
  714. zDbName: pansichar; (* Name of the database *)
  715. pKey: pointer; nKey: cint (* The key *)
  716. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  717. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_rekey{$IFDEF D}: function{$ENDIF}(
  718. db: psqlite3; (* Database to be rekeyed *)
  719. pKey: pointer; nKey: cint (* The new key *)
  720. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  721. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_rekey_v2{$IFDEF D}: function{$ENDIF}(
  722. db: psqlite3; (* Database to be rekeyed *)
  723. zDbName: pansichar; (* Name of the database *)
  724. pKey: pointer; nKey: cint (* The new key *)
  725. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  726. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_sleep{$IFDEF D}: function{$ENDIF}(M: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  727. {$ifndef win32}
  728. var
  729. sqlite3_temp_directory: pansichar; cvar; external {Sqlite3Lib};
  730. sqlite3_data_directory: pansichar; cvar; external {Sqlite3Lib};
  731. {$endif}
  732. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_get_autocommit{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  733. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_handle{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): psqlite3; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  734. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_filename{$IFDEF D}: function{$ENDIF}(db: psqlite3; zDbName: pansichar): pansichar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  735. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_readonly{$IFDEF D}: function{$ENDIF}(db: psqlite3; zDbName: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  736. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_next_stmt{$IFDEF D}: function{$ENDIF}(db: psqlite3;stmt: psqlite3_stmt):psqlite3_stmt;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  737. type
  738. commit_callback = function(user: pointer): cint; cdecl;
  739. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_commit_hook{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: commit_callback; user: pointer): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  740. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_rollback_hook{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: sqlite3_destructor_type; user: pointer): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  741. type
  742. update_callback = procedure(user: pointer; event: cint; database, table: pansichar; rowid: sqlite3_int64); cdecl;
  743. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_update_hook{$IFDEF D}: function{$ENDIF}(db: psqlite3; cb: update_callback; user: pointer): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  744. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_enable_shared_cache{$IFDEF D}: function{$ENDIF}(B: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  745. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_release_memory{$IFDEF D}: function{$ENDIF}(N: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  746. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_release_memory{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  747. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_soft_heap_limit{$IFDEF D}: procedure{$ENDIF}(N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  748. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_soft_heap_limit64{$IFDEF D}: function{$ENDIF}(N: int64):int64;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  749. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_table_column_metadata{$IFDEF D}: function{$ENDIF}(
  750. db: psqlite3; (* Connection handle *)
  751. zDbName: pansichar; (* Database name or NULL *)
  752. zTableName: pansichar; (* Table name *)
  753. zColumnName: pansichar; (* Column name *)
  754. pzDataType: ppansichar; (* OUTPUT: Declared data type *)
  755. pzCollSeq: ppansichar; (* OUTPUT: Collation sequence name *)
  756. pNotNull: pcint; (* OUTPUT: True if NOT NULL constracint exists *)
  757. pPrimaryKey: pcint; (* OUTPUT: True if column part of PK *)
  758. pAutoinc: pcint (* OUTPUT: True if column is auto-increment *)
  759. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  760. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_load_extension{$IFDEF D}: function{$ENDIF}(
  761. db: psqlite3; (* Load the extension cinto this database connection *)
  762. zFile: pansichar; (* Name of the shared library containing extension *)
  763. zProc: pansichar; (* Entry point. Derived from zFile if 0 *)
  764. pzErrMsg: ppansichar (* Put error message here if not 0 *)
  765. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  766. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_enable_load_extension{$IFDEF D}: function{$ENDIF}(db: psqlite3; onoff: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  767. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_auto_extension{$IFDEF D}: function{$ENDIF}(xEntrypoint: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  768. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_cancel_auto_extension{$IFDEF D}: function{$ENDIF}(xEntrypoint: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  769. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_reset_auto_extension{$IFDEF D}: procedure{$ENDIF}(); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  770. type
  771. psqlite3_module = ^sqlite3_module;
  772. sqlite3_module = record{
  773. iVersion : cint;
  774. // xCreate : function(db: psqlite3; pAux: pointer; argc: cint; ): cint; cdecl;
  775. cint (*xCreate)(db: psqlite3; void *pAux;
  776. cint argc; const char *const*argv;
  777. sqlite3_vtab **ppVTab; char**);
  778. cint (*xConnect)(db: psqlite3; void *pAux;
  779. cint argc; const char *const*argv;
  780. sqlite3_vtab **ppVTab; char**);
  781. cint (*xBestIndex)(sqlite3_vtab *pVTab; sqlite3_index_info*);
  782. cint (*xDisconnect)(sqlite3_vtab *pVTab);
  783. cint (*xDestroy)(sqlite3_vtab *pVTab);
  784. cint (*xOpen)(sqlite3_vtab *pVTab; sqlite3_vtab_cursor **ppCursor);
  785. cint (*xClose)(sqlite3_vtab_cursor*);
  786. cint (*xFilter)(sqlite3_vtab_cursor*; cint idxNum; const char *idxStr;
  787. cint argc; sqlite3_value **argv);
  788. xNext : function(pVCurs: sqlite3_vtab_cursor): cint; cdecl;
  789. xEof : function(pVCurs: sqlite3_vtab_cursor): cint; cdecl;
  790. xColumn : function(pVCurs: sqlite3_vtab_cursor; ctx: psqlite3_context; i: cint): cint; cdecl;
  791. xRowid : function(pVCurs: sqlite3_vtab_cursor; var pRowid: sqlite3_int64): cint; cdecl;
  792. xUpdate : function(pVtab: psqlite3_vtab; var v: psqlite3_value; var p: sqlite3_int64): cint; cdecl;
  793. xBegin : function(pVtab: psqlite3_vtab): cint; cdecl;
  794. xSync : function(pVtab: psqlite3_vtab): cint; cdecl;
  795. xCommit : function(pVtab: psqlite3_vtab): cint; cdecl;
  796. xRollback : function(pVtab: psqlite3_vtab): cint; cdecl;
  797. xFindFunction : function(pVtab: psqlite3_vtab; nArg: cint; zName: pansichar; var pxFunc: xFunc; var ppArg: pointer): cint; cdecl;
  798. xRename : function(pVtab: psqlite3_vtab; zNew: pansichar): cint; cdecl;
  799. }end;
  800. {.$WARNING TODO}
  801. type
  802. psqlite3_index_constracint = ^sqlite3_index_constracint;
  803. sqlite3_index_constracint = record
  804. iColumn: cint; (* Column constrained. -1 for ROWID *)
  805. op: char; (* Constracint operator *)
  806. usable: char; (* True if this constracint is usable *)
  807. iTermOffset: cint; (* Used cinternally - xBestIndex should ignore *)
  808. end;
  809. psqlite3_index_orderby = ^sqlite3_index_orderby;
  810. sqlite3_index_orderby = record
  811. iColumn: cint; (* Column number *)
  812. desc: char; (* True for DESC. False for ASC. *)
  813. end;
  814. psqlite3_index_constracint_usage = ^sqlite3_index_constracint_usage;
  815. sqlite3_index_constracint_usage = record
  816. argvIndex: cint; (* if >0; constracint is part of argv to xFilter *)
  817. omit: char; (* Do not code a test for this constracint *)
  818. end;
  819. psqlite3_index_info = ^sqlite3_index_info;
  820. sqlite3_index_info = record
  821. (* Inputs *)
  822. nConstracint: cint; (* Number of entries in aConstracint *)
  823. aConstracint: psqlite3_index_constracint;
  824. nOrderBy: cint; (* Number of terms in the ORDER BY clause *)
  825. aOrderBy: psqlite3_index_orderby;
  826. (* Outputs *)
  827. aConstracintUsage: psqlite3_index_constracint_usage;
  828. idxNum: cint; (* Number used to identify the index *)
  829. idxStr: pansichar; (* String; possibly obtained from sqlite3_malloc *)
  830. needToFreeIdxStr: cint; (* Free idxStr using sqlite3_free() if true *)
  831. orderByConsumed: cint; (* True if output is already ordered *)
  832. estimatedCost: cdouble; (* Estimated cost of using this index *)
  833. (* Fields below are only available in SQLite 3.8.2 and later *)
  834. estimatedRows: sqlite3_int64; (* Estimated number of rows returned *)
  835. (* Fields below are only available in SQLite 3.9.0 and later *)
  836. idxFlags: cint ; (* Mask of SQLITE_INDEX_SCAN_* flags *)
  837. (* Fields below are only available in SQLite 3.10.0 and later *)
  838. colUsed: sqlite3_uint64; (* Input: Mask of columns used by statement *)
  839. end;
  840. const
  841. SQLITE_INDEX_SCAN_UNIQUE = 1;
  842. SQLITE_INDEX_CONSTRAINT_EQ = 2;
  843. SQLITE_INDEX_CONSTRAINT_GT = 4;
  844. SQLITE_INDEX_CONSTRAINT_LE = 8;
  845. SQLITE_INDEX_CONSTRAINT_LT = 16;
  846. SQLITE_INDEX_CONSTRAINT_GE = 32;
  847. SQLITE_INDEX_CONSTRAINT_MATCH = 64;
  848. SQLITE_INDEX_CONSTRAINT_LIKE = 65;
  849. SQLITE_INDEX_CONSTRAINT_GLOB = 66;
  850. SQLITE_INDEX_CONSTRAINT_REGEXP= 67;
  851. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_module{$IFDEF D}: function{$ENDIF}(
  852. db: psqlite3; (* SQLite connection to register module with *)
  853. zName: pansichar; (* Name of the module *)
  854. module: psqlite3_module; (* Methods for the module *)
  855. user: pointer (* Client data for xCreate/xConnect *)
  856. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  857. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_module_v2{$IFDEF D}: function{$ENDIF}(
  858. db: psqlite3; (* SQLite connection to register module with *)
  859. zName: pansichar; (* Name of the module *)
  860. module: psqlite3_module; (* Methods for the module *)
  861. user: pointer; (* Client data for xCreate/xConnect *)
  862. xdestroycb: xDestroy (* Module destructor function *)
  863. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  864. type
  865. psqlite3_vtab = ^sqlite3_vtab;
  866. sqlite3_vtab = record
  867. pModule: psqlite3_module; (* The module for this virtual table *)
  868. nRef: cint; (* Used cinternally *)
  869. zErrMsg: pansichar; (* Error message from sqlite3_mprcintf() *)
  870. (* Virtual table implementations will typically add additional fields *)
  871. end;
  872. type
  873. psqlite3_vtab_cursor = ^sqlite3_vtab_cursor;
  874. sqlite3_vtab_cursor = record
  875. pVtab: psqlite3_vtab; (* Virtual table of this cursor *)
  876. (* Virtual table implementations will typically add additional fields *)
  877. end;
  878. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_declare_vtab{$IFDEF D}: function{$ENDIF}(db: psqlite3; zCreateTable: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  879. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_overload_function{$IFDEF D}: function{$ENDIF}(db: psqlite3; zFuncName: pansichar; nArg: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  880. type
  881. ppsqlite3_blob = ^psqlite3_blob;
  882. psqlite3_blob = ^sqlite3_blob;
  883. sqlite3_blob = record end;
  884. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_open{$IFDEF D}: function{$ENDIF}(
  885. db: psqlite3;
  886. zDb: pansichar;
  887. zTable: pansichar;
  888. zColumn: pansichar;
  889. iRow: sqlite3_int64;
  890. flags: cint;
  891. ppBlob: ppsqlite3_blob
  892. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  893. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_reopen{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob;p:sqlite3_int64): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  894. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_close{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  895. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_bytes{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  896. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_read{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob; Z: pointer; N: cint; iOffset: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  897. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_write{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob; Z: pointer; N: cint; iOffset: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  898. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_vfs_find{$IFDEF D}: function{$ENDIF}(zVfsName: pansichar): psqlite3_vfs; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  899. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_vfs_register{$IFDEF D}: function{$ENDIF}(vfs: psqlite3_vfs; makeDflt: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  900. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_vfs_unregister{$IFDEF D}: function{$ENDIF}(vfs: psqlite3_vfs): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  901. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_alloc{$IFDEF D}: function{$ENDIF}(n: cint): psqlite3_mutex; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  902. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_free{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  903. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_enter{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  904. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_try{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  905. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_leave{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  906. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_held{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  907. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_notheld{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  908. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_mutex{$IFDEF D}: function{$ENDIF}(db: psqlite3): psqlite3_mutex; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  909. const
  910. SQLITE_MUTEX_FAST = 0;
  911. SQLITE_MUTEX_RECURSIVE = 1;
  912. SQLITE_MUTEX_STATIC_MASTER = 2;
  913. SQLITE_MUTEX_STATIC_MEM = 3; (* sqlite3_malloc() *)
  914. SQLITE_MUTEX_STATIC_MEM2 = 4; (* sqlite3_release_memory() *)
  915. SQLITE_MUTEX_STATIC_PRNG = 5; (* sqlite3_random() *)
  916. SQLITE_MUTEX_STATIC_LRU = 6; (* lru page list *)
  917. SQLITE_MUTEX_STATIC_LRU2 = 7; (* lru page list *)
  918. SQLITE_MUTEX_STATIC_APP1 = 8; (* For use by application *)
  919. SQLITE_MUTEX_STATIC_APP2 = 9; (* For use by application *)
  920. SQLITE_MUTEX_STATIC_APP3 = 10; (* For use by application *)
  921. SQLITE_MUTEX_STATIC_VFS1 = 11; (* For use by built-in VFS *)
  922. SQLITE_MUTEX_STATIC_VFS2 = 12; (* For use by extension VFS *)
  923. SQLITE_MUTEX_STATIC_VFS3 = 13; (* For use by application VFS *)
  924. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_file_control{$IFDEF D}: function{$ENDIF}(db: psqlite3; zDbName: pansichar; op: cint; p: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  925. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_test_control{$IFDEF D}: function{$ENDIF}(op: cint; args: array of const): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  926. const
  927. SQLITE_TESTCTRL_FAULT_CONFIG = 1;
  928. SQLITE_TESTCTRL_FAULT_FAILURES = 2;
  929. SQLITE_TESTCTRL_FAULT_BENIGN_FAILURES = 3;
  930. SQLITE_TESTCTRL_FAULT_PENDING = 4;
  931. SQLITE_TESTCTRL_PRNG_SAVE = 5;
  932. SQLITE_TESTCTRL_PRNG_RESTORE = 6;
  933. SQLITE_TESTCTRL_PRNG_RESET = 7;
  934. SQLITE_TESTCTRL_BITVEC_TEST = 8;
  935. SQLITE_TESTCTRL_FAULT_INSTALL = 9;
  936. SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS = 10;
  937. SQLITE_TESTCTRL_PENDING_BYTE = 11;
  938. SQLITE_TESTCTRL_ASSERT = 12;
  939. SQLITE_TESTCTRL_ALWAYS = 13;
  940. SQLITE_TESTCTRL_RESERVE = 14;
  941. SQLITE_TESTCTRL_OPTIMIZATIONS = 15;
  942. SQLITE_TESTCTRL_ISKEYWORD = 16;
  943. SQLITE_TESTCTRL_SCRATCHMALLOC = 17;
  944. SQLITE_TESTCTRL_LOCALTIME_FAULT = 18;
  945. SQLITE_TESTCTRL_EXPLAIN_STMT = 19; (* NOT USED *)
  946. SQLITE_TESTCTRL_NEVER_CORRUPT = 20;
  947. SQLITE_TESTCTRL_VDBE_COVERAGE = 21;
  948. SQLITE_TESTCTRL_BYTEORDER = 22;
  949. SQLITE_TESTCTRL_ISINIT = 23;
  950. SQLITE_TESTCTRL_SORTER_MMAP = 24;
  951. SQLITE_TESTCTRL_IMPOSTER = 25;
  952. SQLITE_TESTCTRL_LAST = 25;
  953. SQLITE_STATUS_MEMORY_USED = 0;
  954. SQLITE_STATUS_PAGECACHE_USED = 1;
  955. SQLITE_STATUS_PAGECACHE_OVERFLOW = 2;
  956. SQLITE_STATUS_SCRATCH_USED = 3;
  957. SQLITE_STATUS_SCRATCH_OVERFLOW = 4;
  958. SQLITE_STATUS_MALLOC_SIZE = 5;
  959. SQLITE_STATUS_PARSER_STACK = 6;
  960. SQLITE_STATUS_PAGECACHE_SIZE = 7;
  961. SQLITE_STATUS_SCRATCH_SIZE = 8;
  962. SQLITE_STATUS_MALLOC_COUNT = 9;
  963. SQLITE_DBSTATUS_LOOKASIDE_USED = 0;
  964. SQLITE_DBSTATUS_CACHE_USED = 1;
  965. SQLITE_DBSTATUS_SCHEMA_USED = 2;
  966. SQLITE_DBSTATUS_STMT_USED = 3;
  967. SQLITE_DBSTATUS_LOOKASIDE_HIT = 4;
  968. SQLITE_DBSTATUS_LOOKASIDE_MISS_SIZE = 5;
  969. SQLITE_DBSTATUS_LOOKASIDE_MISS_FULL = 6;
  970. SQLITE_DBSTATUS_CACHE_HIT = 7;
  971. SQLITE_DBSTATUS_CACHE_MISS = 8;
  972. SQLITE_DBSTATUS_CACHE_WRITE = 9;
  973. SQLITE_DBSTATUS_DEFERRED_FKS = 10;
  974. SQLITE_DBSTATUS_CACHE_USED_SHARED = 11;
  975. SQLITE_DBSTATUS_MAX = 11; (* Largest defined DBSTATUS *)
  976. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_status{$IFDEF D}: function{$ENDIF}(op: cint; pCurrent: pcint; pHighwater: pcint; resetFlag: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  977. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_status64{$IFDEF D}: function{$ENDIF}(op: cint; pCurrent: psqlite3_int64; pHighwater: psqlite3_int64; resetFlag: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  978. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_status{$IFDEF D}: function{$ENDIF}(db : psqlite3;op: cint; pCurrent:pcint; pHighwater: pcint; resetFlag: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  979. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_stmt_status{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt;op: cint; pcurrent:pcint; pHighwater: pcint; resetFlag: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  980. {Backup api}
  981. type
  982. psqlite3backup = Pointer;
  983. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_init{$IFDEF D}: function{$ENDIF}(pDest: psqlite3; const zDestName: pansichar; pSource: psqlite3; const zSourceName: pansichar): psqlite3backup; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  984. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_step{$IFDEF D}: function{$ENDIF}(p: psqlite3backup; nPage: Integer): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  985. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_finish{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  986. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_remaining{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  987. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_pagecount{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  988. Type
  989. xNotifycb = procedure (Argp: pointer; narg : cint);cdecl;
  990. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_unlock_notify{$IFDEF D}: function{$ENDIF}(pBlocked:psqlite3;xNotify: xNotifycb;arg:pointer):cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  991. {$IFDEF S}procedure{$ELSE}var{$ENDIF} sqlite3_log{$IFDEF D}: procedure{$ENDIF}(iErrCode:cint;fmt : pansichar); cdecl;varargs;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  992. Type
  993. wal_hook_cb = function (p : pointer; db :psqlite3; c : pansichar; d: cint): cint;cdecl;
  994. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_hook{$IFDEF D}: function{$ENDIF}(db:psqlite3;cb : wal_hook_cb; p: pointer): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  995. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_autocheckpoint{$IFDEF D}: function{$ENDIF}(db:psqlite3;n : cint): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  996. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_checkpoint{$IFDEF D}: function{$ENDIF}(db:psqlite3;zDB: pansichar): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  997. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_checkpoint_v2{$IFDEF D}: function{$ENDIF}(db:psqlite3;zDB: pansichar;emode:cint;nLog:pcint;nCkpt:pcint): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  998. Const
  999. SQLITE_CHECKPOINT_PASSIVE = 0; (* Do as much as possible w/o blocking *)
  1000. SQLITE_CHECKPOINT_FULL = 1; (* Wait for writers, then checkpoint *)
  1001. SQLITE_CHECKPOINT_RESTART = 2; (* Like FULL but wait for for readers *)
  1002. SQLITE_CHECKPOINT_TRUNCATE = 3; (* Like RESTART but also truncate WAL *)
  1003. {String handling api}
  1004. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_strglob {$IFDEF D}:function{$ENDIF}(zGlob, zStr: pansichar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  1005. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_strlike {$IFDEF D}:function{$ENDIF}(zGlob, zStr: pansichar; cEsc: cuint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  1006. {$IFDEF LOAD_DYNAMICALLY}
  1007. function InitializeSqliteANSI(const LibraryName: AnsiString = ''): Integer; //needed as TLibraryLoadFunction
  1008. function InitializeSqlite(const LibraryName: UnicodeString = ''): Integer;
  1009. function TryInitializeSqlite(const LibraryName: Unicodestring = ''): Integer;
  1010. procedure ReleaseSqlite; //needed as TLibraryUnLoadFunction
  1011. function InitialiseSQLite: Integer; deprecated;
  1012. function InitialiseSQLite(const LibraryName: UnicodeString): Integer; deprecated;
  1013. var
  1014. SQLiteLibraryHandle: TLibHandle;
  1015. SQLiteDefaultLibrary: String = Sqlite3Lib;
  1016. SQLiteLoadedLibrary: UnicodeString;
  1017. {$ENDIF LOAD_DYNAMICALLY}
  1018. implementation
  1019. function sqlite3_version(): pansichar;
  1020. begin
  1021. Result := sqlite3_libversion();
  1022. end;
  1023. {$IFDEF LOAD_DYNAMICALLY}
  1024. resourcestring
  1025. SErrLoadFailed = 'Can not load SQLite client library "%s". Check your installation.';
  1026. SErrAlreadyLoaded = 'SQLite interface already initialized from library %s.';
  1027. procedure LoadAddresses(LibHandle: TLibHandle);
  1028. begin
  1029. pointer(sqlite3_libversion) := GetProcedureAddress(LibHandle,'sqlite3_libversion');
  1030. pointer(sqlite3_libversion_number) := GetProcedureAddress(LibHandle,'sqlite3_libversion_number');
  1031. pointer(sqlite3_threadsafe) := GetProcedureAddress(LibHandle,'sqlite3_threadsafe');
  1032. pointer(sqlite3_close) := GetProcedureAddress(LibHandle,'sqlite3_close');
  1033. pointer(sqlite3_close_v2) := GetProcedureAddress(LibHandle,'sqlite3_close_v2');
  1034. pointer(sqlite3_exec) := GetProcedureAddress(LibHandle,'sqlite3_exec');
  1035. pointer(sqlite3_extended_result_codes) := GetProcedureAddress(LibHandle,'sqlite3_extended_result_codes');
  1036. pointer(sqlite3_last_insert_rowid) := GetProcedureAddress(LibHandle,'sqlite3_last_insert_rowid');
  1037. pointer(sqlite3_changes) := GetProcedureAddress(LibHandle,'sqlite3_changes');
  1038. pointer(sqlite3_total_changes) := GetProcedureAddress(LibHandle,'sqlite3_total_changes');
  1039. pointer(sqlite3_complete) := GetProcedureAddress(LibHandle,'sqlite3_complete');
  1040. pointer(sqlite3_complete16) := GetProcedureAddress(LibHandle,'sqlite3_complete16');
  1041. pointer(sqlite3_busy_handler) := GetProcedureAddress(LibHandle,'sqlite3_busy_handler');
  1042. pointer(sqlite3_busy_timeout) := GetProcedureAddress(LibHandle,'sqlite3_busy_timeout');
  1043. pointer(sqlite3_get_table) := GetProcedureAddress(LibHandle,'sqlite3_get_table');
  1044. pointer(sqlite3_malloc) := GetProcedureAddress(LibHandle,'sqlite3_malloc');
  1045. pointer(sqlite3_realloc) := GetProcedureAddress(LibHandle,'sqlite3_realloc');
  1046. pointer(sqlite3_memory_used) := GetProcedureAddress(LibHandle,'sqlite3_memory_used');
  1047. pointer(sqlite3_memory_highwater) := GetProcedureAddress(LibHandle,'sqlite3_memory_highwater');
  1048. pointer(sqlite3_set_authorizer) := GetProcedureAddress(LibHandle,'sqlite3_set_authorizer');
  1049. pointer(sqlite3_trace) := GetProcedureAddress(LibHandle,'sqlite3_trace');
  1050. pointer(sqlite3_profile) := GetProcedureAddress(LibHandle,'sqlite3_profile');
  1051. pointer(sqlite3_open) := GetProcedureAddress(LibHandle,'sqlite3_open');
  1052. pointer(sqlite3_open16) := GetProcedureAddress(LibHandle,'sqlite3_open16');
  1053. pointer(sqlite3_open_v2) := GetProcedureAddress(LibHandle,'sqlite3_open_v2');
  1054. pointer(sqlite3_errcode) := GetProcedureAddress(LibHandle,'sqlite3_errcode');
  1055. pointer(sqlite3_extended_errcode) := GetProcedureAddress(LibHandle,'sqlite3_extended_errcode');
  1056. pointer(sqlite3_errmsg) := GetProcedureAddress(LibHandle,'sqlite3_errmsg');
  1057. pointer(sqlite3_errmsg16) := GetProcedureAddress(LibHandle,'sqlite3_errmsg16');
  1058. pointer(sqlite3_errstr) := GetProcedureAddress(LibHandle,'sqlite3_errstr');
  1059. pointer(sqlite3_limit) := GetProcedureAddress(LibHandle,'sqlite3_limit');
  1060. pointer(sqlite3_prepare) := GetProcedureAddress(LibHandle,'sqlite3_prepare');
  1061. pointer(sqlite3_prepare_v2) := GetProcedureAddress(LibHandle,'sqlite3_prepare_v2');
  1062. pointer(sqlite3_prepare16) := GetProcedureAddress(LibHandle,'sqlite3_prepare16');
  1063. pointer(sqlite3_prepare16_v2) := GetProcedureAddress(LibHandle,'sqlite3_prepare16_v2');
  1064. pointer(sqlite3_sql) := GetProcedureAddress(LibHandle,'sqlite3_sql');
  1065. pointer(sqlite3_expanded_sql) := GetProcedureAddress(LibHandle,'sqlite3_expanded_sql');
  1066. pointer(sqlite3_bind_blob) := GetProcedureAddress(LibHandle,'sqlite3_bind_blob');
  1067. pointer(sqlite3_bind_blob64) := GetProcedureAddress(LibHandle,'sqlite3_bind_blob64');
  1068. pointer(sqlite3_bind_double) := GetProcedureAddress(LibHandle,'sqlite3_bind_double');
  1069. pointer(sqlite3_bind_int) := GetProcedureAddress(LibHandle,'sqlite3_bind_int');
  1070. pointer(sqlite3_bind_int64) := GetProcedureAddress(LibHandle,'sqlite3_bind_int64');
  1071. pointer(sqlite3_bind_null) := GetProcedureAddress(LibHandle,'sqlite3_bind_null');
  1072. pointer(sqlite3_bind_text) := GetProcedureAddress(LibHandle,'sqlite3_bind_text');
  1073. pointer(sqlite3_bind_text64) := GetProcedureAddress(LibHandle,'sqlite3_bind_text64');
  1074. pointer(sqlite3_bind_text16) := GetProcedureAddress(LibHandle,'sqlite3_bind_text16');
  1075. pointer(sqlite3_bind_value) := GetProcedureAddress(LibHandle,'sqlite3_bind_value');
  1076. pointer(sqlite3_bind_zeroblob) := GetProcedureAddress(LibHandle,'sqlite3_bind_zeroblob');
  1077. pointer(sqlite3_bind_zeroblob64) := GetProcedureAddress(LibHandle,'sqlite3_bind_zeroblob64');
  1078. pointer(sqlite3_bind_parameter_count) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_count');
  1079. pointer(sqlite3_bind_parameter_name) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_name');
  1080. pointer(sqlite3_bind_parameter_index) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_index');
  1081. pointer(sqlite3_clear_bindings) := GetProcedureAddress(LibHandle,'sqlite3_clear_bindings');
  1082. pointer(sqlite3_column_count) := GetProcedureAddress(LibHandle,'sqlite3_column_count');
  1083. pointer(sqlite3_column_name) := GetProcedureAddress(LibHandle,'sqlite3_column_name');
  1084. pointer(sqlite3_column_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_name16');
  1085. pointer(sqlite3_column_database_name) := GetProcedureAddress(LibHandle,'sqlite3_column_database_name');
  1086. pointer(sqlite3_column_database_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_database_name16');
  1087. pointer(sqlite3_column_table_name) := GetProcedureAddress(LibHandle,'sqlite3_column_table_name');
  1088. pointer(sqlite3_column_table_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_table_name16');
  1089. pointer(sqlite3_column_origin_name) := GetProcedureAddress(LibHandle,'sqlite3_column_origin_name');
  1090. pointer(sqlite3_column_origin_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_origin_name16');
  1091. pointer(sqlite3_column_decltype) := GetProcedureAddress(LibHandle,'sqlite3_column_decltype');
  1092. pointer(sqlite3_column_decltype16) := GetProcedureAddress(LibHandle,'sqlite3_column_decltype16');
  1093. pointer(sqlite3_step) := GetProcedureAddress(LibHandle,'sqlite3_step');
  1094. pointer(sqlite3_data_count) := GetProcedureAddress(LibHandle,'sqlite3_data_count');
  1095. pointer(sqlite3_column_blob) := GetProcedureAddress(LibHandle,'sqlite3_column_blob');
  1096. pointer(sqlite3_column_bytes) := GetProcedureAddress(LibHandle,'sqlite3_column_bytes');
  1097. pointer(sqlite3_column_bytes16) := GetProcedureAddress(LibHandle,'sqlite3_column_bytes16');
  1098. pointer(sqlite3_column_double) := GetProcedureAddress(LibHandle,'sqlite3_column_double');
  1099. pointer(sqlite3_column_int) := GetProcedureAddress(LibHandle,'sqlite3_column_int');
  1100. pointer(sqlite3_column_int64) := GetProcedureAddress(LibHandle,'sqlite3_column_int64');
  1101. pointer(sqlite3_column_text) := GetProcedureAddress(LibHandle,'sqlite3_column_text');
  1102. pointer(sqlite3_column_text16) := GetProcedureAddress(LibHandle,'sqlite3_column_text16');
  1103. pointer(sqlite3_column_type) := GetProcedureAddress(LibHandle,'sqlite3_column_type');
  1104. pointer(sqlite3_column_value) := GetProcedureAddress(LibHandle,'sqlite3_column_value');
  1105. pointer(sqlite3_finalize) := GetProcedureAddress(LibHandle,'sqlite3_finalize');
  1106. pointer(sqlite3_reset) := GetProcedureAddress(LibHandle,'sqlite3_reset');
  1107. pointer(sqlite3_create_function) := GetProcedureAddress(LibHandle,'sqlite3_create_function');
  1108. pointer(sqlite3_create_function16) := GetProcedureAddress(LibHandle,'sqlite3_create_function16');
  1109. pointer(sqlite3_create_function_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_function_v2');
  1110. pointer(sqlite3_value_blob) := GetProcedureAddress(LibHandle,'sqlite3_value_blob');
  1111. pointer(sqlite3_value_bytes) := GetProcedureAddress(LibHandle,'sqlite3_value_bytes');
  1112. pointer(sqlite3_value_bytes16) := GetProcedureAddress(LibHandle,'sqlite3_value_bytes16');
  1113. pointer(sqlite3_value_double) := GetProcedureAddress(LibHandle,'sqlite3_value_double');
  1114. pointer(sqlite3_value_int) := GetProcedureAddress(LibHandle,'sqlite3_value_int');
  1115. pointer(sqlite3_value_int64) := GetProcedureAddress(LibHandle,'sqlite3_value_int64');
  1116. pointer(sqlite3_value_text) := GetProcedureAddress(LibHandle,'sqlite3_value_text');
  1117. pointer(sqlite3_value_text16) := GetProcedureAddress(LibHandle,'sqlite3_value_text16');
  1118. pointer(sqlite3_value_text16le) := GetProcedureAddress(LibHandle,'sqlite3_value_text16le');
  1119. pointer(sqlite3_value_text16be) := GetProcedureAddress(LibHandle,'sqlite3_value_text16be');
  1120. pointer(sqlite3_value_type) := GetProcedureAddress(LibHandle,'sqlite3_value_type');
  1121. pointer(sqlite3_value_numeric_type) := GetProcedureAddress(LibHandle,'sqlite3_value_numeric_type');
  1122. pointer(sqlite3_value_subtype) := GetProcedureAddress(LibHandle,'sqlite3_value_subtype');
  1123. pointer(sqlite3_aggregate_context) := GetProcedureAddress(LibHandle,'sqlite3_aggregate_context');
  1124. pointer(sqlite3_user_data) := GetProcedureAddress(LibHandle,'sqlite3_user_data');
  1125. pointer(sqlite3_context_db_handle) := GetProcedureAddress(LibHandle,'sqlite3_context_db_handle');
  1126. pointer(sqlite3_get_auxdata) := GetProcedureAddress(LibHandle,'sqlite3_get_auxdata');
  1127. pointer(sqlite3_create_collation) := GetProcedureAddress(LibHandle,'sqlite3_create_collation');
  1128. pointer(sqlite3_create_collation_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_collation_v2');
  1129. pointer(sqlite3_create_collation16) := GetProcedureAddress(LibHandle,'sqlite3_create_collation16');
  1130. pointer(sqlite3_collation_needed) := GetProcedureAddress(LibHandle,'sqlite3_collation_needed');
  1131. pointer(sqlite3_collation_needed16) := GetProcedureAddress(LibHandle,'sqlite3_collation_needed16');
  1132. pointer(sqlite3_key) := GetProcedureAddress(LibHandle,'sqlite3_key');
  1133. pointer(sqlite3_key_v2) := GetProcedureAddress(LibHandle,'sqlite3_key_v2');
  1134. pointer(sqlite3_rekey) := GetProcedureAddress(LibHandle,'sqlite3_rekey');
  1135. pointer(sqlite3_rekey_v2) := GetProcedureAddress(LibHandle,'sqlite3_rekey_v2');
  1136. pointer(sqlite3_sleep) := GetProcedureAddress(LibHandle,'sqlite3_sleep');
  1137. pointer(sqlite3_get_autocommit) := GetProcedureAddress(LibHandle,'sqlite3_get_autocommit');
  1138. pointer(sqlite3_db_handle) := GetProcedureAddress(LibHandle,'sqlite3_db_handle');
  1139. pointer(sqlite3_commit_hook) := GetProcedureAddress(LibHandle,'sqlite3_commit_hook');
  1140. pointer(sqlite3_rollback_hook) := GetProcedureAddress(LibHandle,'sqlite3_rollback_hook');
  1141. pointer(sqlite3_update_hook) := GetProcedureAddress(LibHandle,'sqlite3_update_hook');
  1142. pointer(sqlite3_enable_shared_cache) := GetProcedureAddress(LibHandle,'sqlite3_enable_shared_cache');
  1143. pointer(sqlite3_release_memory) := GetProcedureAddress(LibHandle,'sqlite3_release_memory');
  1144. pointer(sqlite3_table_column_metadata) := GetProcedureAddress(LibHandle,'sqlite3_table_column_metadata');
  1145. pointer(sqlite3_load_extension) := GetProcedureAddress(LibHandle,'sqlite3_load_extension');
  1146. pointer(sqlite3_enable_load_extension) := GetProcedureAddress(LibHandle,'sqlite3_enable_load_extension');
  1147. pointer(sqlite3_auto_extension) := GetProcedureAddress(LibHandle,'sqlite3_auto_extension');
  1148. pointer(sqlite3_create_module) := GetProcedureAddress(LibHandle,'sqlite3_create_module');
  1149. pointer(sqlite3_create_module_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_module_v2');
  1150. pointer(sqlite3_declare_vtab) := GetProcedureAddress(LibHandle,'sqlite3_declare_vtab');
  1151. pointer(sqlite3_overload_function) := GetProcedureAddress(LibHandle,'sqlite3_overload_function');
  1152. pointer(sqlite3_blob_open) := GetProcedureAddress(LibHandle,'sqlite3_blob_open');
  1153. pointer(sqlite3_blob_reopen) := GetProcedureAddress(LibHandle,'sqlite3_blob_reopen');
  1154. pointer(sqlite3_blob_close) := GetProcedureAddress(LibHandle,'sqlite3_blob_close');
  1155. pointer(sqlite3_blob_bytes) := GetProcedureAddress(LibHandle,'sqlite3_blob_bytes');
  1156. pointer(sqlite3_blob_read) := GetProcedureAddress(LibHandle,'sqlite3_blob_read');
  1157. pointer(sqlite3_blob_write) := GetProcedureAddress(LibHandle,'sqlite3_blob_write');
  1158. pointer(sqlite3_vfs_find) := GetProcedureAddress(LibHandle,'sqlite3_vfs_find');
  1159. pointer(sqlite3_vfs_register) := GetProcedureAddress(LibHandle,'sqlite3_vfs_register');
  1160. pointer(sqlite3_vfs_unregister) := GetProcedureAddress(LibHandle,'sqlite3_vfs_unregister');
  1161. pointer(sqlite3_mutex_alloc) := GetProcedureAddress(LibHandle,'sqlite3_mutex_alloc');
  1162. pointer(sqlite3_mutex_try) := GetProcedureAddress(LibHandle,'sqlite3_mutex_try');
  1163. pointer(sqlite3_mutex_held) := GetProcedureAddress(LibHandle,'sqlite3_mutex_held');
  1164. pointer(sqlite3_mutex_notheld) := GetProcedureAddress(LibHandle,'sqlite3_mutex_notheld');
  1165. pointer(sqlite3_db_mutex) := GetProcedureAddress(LibHandle,'sqlite3_db_mutex');
  1166. pointer(sqlite3_file_control) := GetProcedureAddress(LibHandle,'sqlite3_file_control');
  1167. pointer(sqlite3_test_control) := GetProcedureAddress(LibHandle,'sqlite3_test_control');
  1168. pointer(sqlite3_status) := GetProcedureAddress(LibHandle,'sqlite3_status');
  1169. pointer(sqlite3_status64) := GetProcedureAddress(LibHandle,'sqlite3_status64');
  1170. pointer(sqlite3_db_status) := GetProcedureAddress(LibHandle,'sqlite3_db_status');
  1171. pointer(sqlite3_stmt_status) := GetProcedureAddress(LibHandle,'sqlite3_stmt_status');
  1172. pointer(sqlite3_interrupt) := GetProcedureAddress(LibHandle,'sqlite3_interrupt');
  1173. pointer(sqlite3_free_table) := GetProcedureAddress(LibHandle,'sqlite3_free_table');
  1174. pointer(sqlite3_free) := GetProcedureAddress(LibHandle,'sqlite3_free');
  1175. pointer(sqlite3_randomness) := GetProcedureAddress(LibHandle,'sqlite3_randomness');
  1176. pointer(sqlite3_progress_handler) := GetProcedureAddress(LibHandle,'sqlite3_progress_handler');
  1177. pointer(sqlite3_set_auxdata) := GetProcedureAddress(LibHandle,'sqlite3_set_auxdata');
  1178. pointer(sqlite3_result_blob) := GetProcedureAddress(LibHandle,'sqlite3_result_blob');
  1179. pointer(sqlite3_result_blob64) := GetProcedureAddress(LibHandle,'sqlite3_result_blob64');
  1180. pointer(sqlite3_result_double) := GetProcedureAddress(LibHandle,'sqlite3_result_double');
  1181. pointer(sqlite3_result_error) := GetProcedureAddress(LibHandle,'sqlite3_result_error');
  1182. pointer(sqlite3_result_error16) := GetProcedureAddress(LibHandle,'sqlite3_result_error16');
  1183. pointer(sqlite3_result_error_toobig) := GetProcedureAddress(LibHandle,'sqlite3_result_error_toobig');
  1184. pointer(sqlite3_result_error_nomem) := GetProcedureAddress(LibHandle,'sqlite3_result_error_nomem');
  1185. pointer(sqlite3_result_error_code) := GetProcedureAddress(LibHandle,'sqlite3_result_error_code');
  1186. pointer(sqlite3_result_int) := GetProcedureAddress(LibHandle,'sqlite3_result_int');
  1187. pointer(sqlite3_result_int64) := GetProcedureAddress(LibHandle,'sqlite3_result_int64');
  1188. pointer(sqlite3_result_null) := GetProcedureAddress(LibHandle,'sqlite3_result_null');
  1189. pointer(sqlite3_result_text) := GetProcedureAddress(LibHandle,'sqlite3_result_text');
  1190. pointer(sqlite3_result_text64) := GetProcedureAddress(LibHandle,'sqlite3_result_text64');
  1191. pointer(sqlite3_result_text16) := GetProcedureAddress(LibHandle,'sqlite3_result_text16');
  1192. pointer(sqlite3_result_text16le) := GetProcedureAddress(LibHandle,'sqlite3_result_text16le');
  1193. pointer(sqlite3_result_text16be) := GetProcedureAddress(LibHandle,'sqlite3_result_text16be');
  1194. pointer(sqlite3_result_value) := GetProcedureAddress(LibHandle,'sqlite3_result_value');
  1195. pointer(sqlite3_result_zeroblob) := GetProcedureAddress(LibHandle,'sqlite3_result_zeroblob');
  1196. pointer(sqlite3_result_zeroblob64) := GetProcedureAddress(LibHandle,'sqlite3_result_zeroblob64');
  1197. pointer(sqlite3_soft_heap_limit) := GetProcedureAddress(LibHandle,'sqlite3_soft_heap_limit');
  1198. pointer(sqlite3_soft_heap_limit64) := GetProcedureAddress(LibHandle,'sqlite3_soft_heap_limit64');
  1199. pointer(sqlite3_reset_auto_extension) := GetProcedureAddress(LibHandle,'sqlite3_reset_auto_extension');
  1200. pointer(sqlite3_mutex_free) := GetProcedureAddress(LibHandle,'sqlite3_mutex_free');
  1201. pointer(sqlite3_mutex_enter) := GetProcedureAddress(LibHandle,'sqlite3_mutex_enter');
  1202. pointer(sqlite3_mutex_leave) := GetProcedureAddress(LibHandle,'sqlite3_mutex_leave');
  1203. pointer(sqlite3_backup_init) := GetProcedureAddress(LibHandle,'sqlite3_backup_init');
  1204. pointer(sqlite3_backup_step) := GetProcedureAddress(LibHandle,'sqlite3_backup_step');
  1205. pointer(sqlite3_backup_finish) := GetProcedureAddress(LibHandle,'sqlite3_backup_finish');
  1206. pointer(sqlite3_backup_remaining) := GetProcedureAddress(LibHandle,'sqlite3_backup_remaining');
  1207. pointer(sqlite3_backup_pagecount) := GetProcedureAddress(LibHandle,'sqlite3_backup_pagecount');
  1208. pointer(sqlite3_unlock_notify) := GetProcedureAddress(LibHandle,'sqlite3_unlock_notify');
  1209. pointer(sqlite3_log) := GetProcedureAddress(LibHandle,'sqlite3_log');
  1210. pointer(sqlite3_wal_hook) := GetProcedureAddress(LibHandle,'sqlite3_wal_hook');
  1211. pointer(sqlite3_wal_autocheckpoint) := GetProcedureAddress(LibHandle,'sqlite3_wal_autocheckpoint');
  1212. pointer(sqlite3_wal_checkpoint) := GetProcedureAddress(LibHandle,'sqlite3_wal_checkpoint');
  1213. pointer(sqlite3_wal_checkpoint_v2) := GetProcedureAddress(LibHandle,'sqlite3_wal_checkpoint_v2');
  1214. pointer(sqlite3_strlike) := GetProcedureAddress(LibHandle,'sqlite3_strlike');
  1215. pointer(sqlite3_initialize) := GetProcedureAddress(LibHandle,'sqlite3_initialize');
  1216. pointer(sqlite3_shutdown) := GetProcedureAddress(LibHandle,'sqlite3_shutdown');
  1217. pointer(sqlite3_os_init) := GetProcedureAddress(LibHandle,'sqlite3_os_init');
  1218. pointer(sqlite3_os_end) := GetProcedureAddress(LibHandle,'sqlite3_os_end');
  1219. pointer(sqlite3_config) := GetProcedureAddress(LibHandle,'sqlite3_config');
  1220. pointer(sqlite3_db_config) := GetProcedureAddress(LibHandle,'sqlite3_db_config');
  1221. pointer(sqlite3_uri_parameter) := GetProcedureAddress(LibHandle,'sqlite3_uri_parameter');
  1222. {$IFDEF SQLITE_OBSOLETE}
  1223. pointer(sqlite3_aggregate_count) := GetProcedureAddress(LibHandle,'sqlite3_aggregate_count');
  1224. pointer(sqlite3_expired) := GetProcedureAddress(LibHandle,'sqlite3_expired');
  1225. pointer(sqlite3_transfer_bindings) := GetProcedureAddress(LibHandle,'sqlite3_transfer_bindings');
  1226. pointer(sqlite3_global_recover) := GetProcedureAddress(LibHandle,'sqlite3_global_recover');
  1227. pointer(sqlite3_memory_alarm) := GetProcedureAddress(LibHandle,'sqlite3_memory_alarm');
  1228. pointer(sqlite3_thread_cleanup) := GetProcedureAddress(LibHandle,'sqlite3_thread_cleanup');
  1229. {$ENDIF}
  1230. end;
  1231. var
  1232. RefCount: Integer;
  1233. function TryInitializeSqlite(const LibraryName: UnicodeString): Integer;
  1234. Var
  1235. N : UnicodeString;
  1236. begin
  1237. N:=LibraryName;
  1238. if (N='') then
  1239. N:=SQLiteDefaultLibrary;
  1240. result:=InterlockedIncrement(RefCount);
  1241. if result = 1 then
  1242. begin
  1243. SQLiteLibraryHandle := LoadLibrary(N);
  1244. if (SQLiteLibraryHandle = NilHandle) then
  1245. begin
  1246. RefCount := 0;
  1247. Exit(-1);
  1248. end;
  1249. SQLiteLoadedLibrary := N;
  1250. LoadAddresses(SQLiteLibraryHandle);
  1251. end;
  1252. end;
  1253. function InitialiseSQLite:integer;
  1254. begin
  1255. result:=InitializeSqlite(SQLiteDefaultLibrary);
  1256. end;
  1257. function InitializeSQLiteANSI(const LibraryName: AnsiString):integer;
  1258. begin
  1259. result:=InitializeSQLite(LibraryName);
  1260. end;
  1261. function InitializeSQLite(const LibraryName: UnicodeString) :integer;
  1262. begin
  1263. if (LibraryName<>'') and (SQLiteLoadedLibrary <> '') and (SQLiteLoadedLibrary <> LibraryName) then
  1264. raise EInoutError.CreateFmt(SErrAlreadyLoaded,[SQLiteLoadedLibrary]);
  1265. result:= TryInitializeSQLite(LibraryName);
  1266. if result=-1 then
  1267. if LibraryName='' then
  1268. raise EInOutError.CreateFmt(SErrLoadFailed,[SQLiteDefaultLibrary])
  1269. else
  1270. raise EInOutError.CreateFmt(SErrLoadFailed,[LibraryName]);
  1271. end;
  1272. function InitialiseSQLite(const LibraryName: UnicodeString):integer;
  1273. begin
  1274. result:=InitializeSqlite(LibraryName);
  1275. end;
  1276. procedure ReleaseSQLite;
  1277. begin
  1278. if InterlockedDecrement(RefCount) <= 0 then
  1279. begin
  1280. if SQLiteLibraryHandle <> NilHandle then
  1281. UnloadLibrary(SQLiteLibraryHandle);
  1282. SQLiteLibraryHandle := NilHandle;
  1283. SQLiteLoadedLibrary := '';
  1284. RefCount := 0;
  1285. end;
  1286. end;
  1287. {$ENDIF}