sqlite3.inc 76 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283
  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. const
  31. SQLITE_VERSION = '3.7.9';
  32. SQLITE_VERSION_NUMBER = 3007009;
  33. SQLITE_SOURCE_ID = '2011-11-01 00:52:41 c7c6050ef060877ebe77b41d959e9df13f8c9b5e';
  34. //SQLITE_EXTERN const char sqlite3_version[];
  35. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_libversion{$IFDEF D}: function{$ENDIF}(): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  36. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_libversion_number{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  37. function sqlite3_version(): pchar;
  38. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_threadsafe{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  39. type
  40. ppsqlite3 = ^psqlite3;
  41. psqlite3 = ^_sqlite3;
  42. _sqlite3 = record end;
  43. type
  44. sqlite3_destructor_type = procedure(user: pointer); cdecl;
  45. const
  46. SQLITE_STATIC = sqlite3_destructor_type(nil);
  47. SQLITE_TRANSIENT = pointer(-1);//sqlite3_destructor_type(-1);
  48. type
  49. psqlite_int64 = ^sqlite_int64;
  50. sqlite_int64 = Int64;
  51. psqlite_uint64 = ^sqlite_uint64;
  52. sqlite_uint64 = QWord;
  53. psqlite3_int64 = ^sqlite3_int64;
  54. sqlite3_int64 = sqlite_int64;
  55. psqlite3_uint64 = ^sqlite3_uint64;
  56. sqlite3_uint64 = sqlite_uint64;
  57. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_close{$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: ppchar): cint; cdecl;
  60. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_exec{$IFDEF D}: function{$ENDIF}(
  61. db: psqlite3; (* An open database *)
  62. sql: pchar; (* SQL to be evaluted *)
  63. cb: sqlite3_callback; (* Callback function *)
  64. user: pointer; (* 1st argument to callback *)
  65. errmsg: ppchar (* 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_ROW = 100; (* sqlite3_step() has another row ready *)
  97. SQLITE_DONE = 101; (* sqlite3_step() has finished executing *)
  98. SQLITE_IOERR_READ = (SQLITE_IOERR or (1 shl 8));
  99. SQLITE_IOERR_SHORT_READ = (SQLITE_IOERR or (2 shl 8));
  100. SQLITE_IOERR_WRITE = (SQLITE_IOERR or (3 shl 8));
  101. SQLITE_IOERR_FSYNC = (SQLITE_IOERR or (4 shl 8));
  102. SQLITE_IOERR_DIR_FSYNC = (SQLITE_IOERR or (5 shl 8));
  103. SQLITE_IOERR_TRUNCATE = (SQLITE_IOERR or (6 shl 8));
  104. SQLITE_IOERR_FSTAT = (SQLITE_IOERR or (7 shl 8));
  105. SQLITE_IOERR_UNLOCK = (SQLITE_IOERR or (8 shl 8));
  106. SQLITE_IOERR_RDLOCK = (SQLITE_IOERR or (9 shl 8));
  107. SQLITE_IOERR_DELETE = (SQLITE_IOERR or (10 shl 8));
  108. SQLITE_IOERR_BLOCKED = (SQLITE_IOERR or (11 shl 8));
  109. SQLITE_IOERR_NOMEM = (SQLITE_IOERR or (12 shl 8));
  110. SQLITE_IOERR_ACCESS = (SQLITE_IOERR or (13 shl 8));
  111. SQLITE_IOERR_CHECKRESERVEDLOCK = (SQLITE_IOERR or (14 shl 8));
  112. SQLITE_IOERR_LOCK = (SQLITE_IOERR or (15 shl 8));
  113. SQLITE_IOERR_CLOSE = (SQLITE_IOERR or (16 shl 8));
  114. SQLITE_IOERR_DIR_CLOSE = (SQLITE_IOERR or (17 shl 8));
  115. SQLITE_IOERR_SHMOPEN = (SQLITE_IOERR or (18 shl 8));
  116. SQLITE_IOERR_SHMSIZE = (SQLITE_IOERR or (19 shl 8));
  117. SQLITE_IOERR_SHMLOCK = (SQLITE_IOERR or (20 shl 8));
  118. SQLITE_IOERR_SHMMAP = (SQLITE_IOERR or (21 shl 8));
  119. SQLITE_IOERR_SEEK = (SQLITE_IOERR or (22 shl 8));
  120. SQLITE_LOCKED_SHAREDCACHE = (SQLITE_LOCKED or (1 shl 8));
  121. SQLITE_BUSY_RECOVERY = (SQLITE_BUSY or (1 shl 8));
  122. SQLITE_CANTOPEN_NOTEMPDIR = (SQLITE_CANTOPEN or (1 shl 8));
  123. SQLITE_CORRUPT_VTAB = (SQLITE_CORRUPT or (1 shl 8));
  124. SQLITE_READONLY_RECOVERY = (SQLITE_READONLY or (1 shl 8));
  125. SQLITE_READONLY_CANTLOCK = (SQLITE_READONLY or (2 shl 8));
  126. SQLITE_OPEN_READONLY = $00000001;
  127. SQLITE_OPEN_READWRITE = $00000002;
  128. SQLITE_OPEN_CREATE = $00000004;
  129. SQLITE_OPEN_DELETEONCLOSE = $00000008;
  130. SQLITE_OPEN_EXCLUSIVE = $00000010;
  131. SQLITE_OPEN_MAIN_DB = $00000100;
  132. SQLITE_OPEN_TEMP_DB = $00000200;
  133. SQLITE_OPEN_TRANSIENT_DB = $00000400;
  134. SQLITE_OPEN_MAIN_JOURNAL = $00000800;
  135. SQLITE_OPEN_TEMP_JOURNAL = $00001000;
  136. SQLITE_OPEN_SUBJOURNAL = $00002000;
  137. SQLITE_OPEN_MASTER_JOURNAL = $00004000;
  138. SQLITE_OPEN_NOMUTEX = $00008000;
  139. SQLITE_OPEN_FULLMUTEX = $00010000;
  140. SQLITE_OPEN_SHAREDCACHE = $00020000;
  141. SQLITE_OPEN_PRIVATECACHE = $00040000;
  142. SQLITE_OPEN_WAL = $00080000;
  143. SQLITE_IOCAP_ATOMIC = $00000001;
  144. SQLITE_IOCAP_ATOMIC512 = $00000002;
  145. SQLITE_IOCAP_ATOMIC1K = $00000004;
  146. SQLITE_IOCAP_ATOMIC2K = $00000008;
  147. SQLITE_IOCAP_ATOMIC4K = $00000010;
  148. SQLITE_IOCAP_ATOMIC8K = $00000020;
  149. SQLITE_IOCAP_ATOMIC16K = $00000040;
  150. SQLITE_IOCAP_ATOMIC32K = $00000080;
  151. SQLITE_IOCAP_ATOMIC64K = $00000100;
  152. SQLITE_IOCAP_SAFE_APPEND = $00000200;
  153. SQLITE_IOCAP_SEQUENTIAL = $00000400;
  154. SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN = $00000800;
  155. SQLITE_LOCK_NONE = 0;
  156. SQLITE_LOCK_SHARED = 1;
  157. SQLITE_LOCK_RESERVED = 2;
  158. SQLITE_LOCK_PENDING = 3;
  159. SQLITE_LOCK_EXCLUSIVE = 4;
  160. SQLITE_SYNC_NORMAL = $00002;
  161. SQLITE_SYNC_FULL = $00003;
  162. SQLITE_SYNC_DATAONLY = $00010;
  163. type
  164. psqlite3_io_methods = ^sqlite3_io_methods;
  165. psqlite3_file = ^sqlite3_file;
  166. sqlite3_file = record
  167. pMethods: psqlite3_io_methods; (* Methods for an open file *)
  168. end;
  169. sqlite3_io_methods = record
  170. iVersion : cint;
  171. Close : function(f: psqlite3_file): cint; stdcall;
  172. Read : function(f: psqlite3_file; addr: pointer; iAmt: cint; iOfst: sqlite3_int64): cint; stdcall;
  173. Write : function(f: psqlite3_file; size: sqlite3_int64): cint; stdcall;
  174. Truncate : function(f: psqlite3_file; size: sqlite3_int64): cint; stdcall;
  175. Sync : function(f: psqlite3_file; flags: cint): cint; stdcall;
  176. FileSize : function(f: psqlite3_file; pSize: psqlite3_int64): cint; stdcall;
  177. Lock : function(f: psqlite3_file; flags: cint): cint; stdcall;
  178. Unlock : function(f: psqlite3_file; flags: cint): cint; stdcall;
  179. CheckReservedLock : function(f: psqlite3_file): cint; stdcall;
  180. FileControl : function(f: psqlite3_file; op: cint; pArg: pointer): cint; stdcall;
  181. SectorSize : function(f: psqlite3_file): cint; stdcall;
  182. DeviceCharacteristics: function(f: psqlite3_file): cint; stdcall;
  183. xShmMap : function(f : psqlite3_file; iPg: cint; pgsz: cint; volatile : pointer) : cint;stdcall;
  184. xShmLock : function(f : psqlite3_file; offset: cint; n : cint; flags : cint) : cint; stdcall;
  185. xShmBarrier : procedure (f : psqlite3_file); stdcall;
  186. xShmUnmap : function(f : psqlite3_file; deleteFlag : cint) : cint; stdcall;
  187. (* Additional methods may be added in future releases *)
  188. end;
  189. const
  190. SQLITE_FCNTL_LOCKSTATE = 1;
  191. SQLITE_GET_LOCKPROXYFILE = 2;
  192. SQLITE_SET_LOCKPROXYFILE = 3;
  193. SQLITE_LAST_ERRNO = 4;
  194. SQLITE_FCNTL_SIZE_HINT = 5;
  195. SQLITE_FCNTL_CHUNK_SIZE = 6;
  196. SQLITE_FCNTL_FILE_POINTER = 7;
  197. SQLITE_FCNTL_SYNC_OMITTED = 8;
  198. SQLITE_FCNTL_WIN32_AV_RETRY = 9;
  199. SQLITE_FCNTL_PERSIST_WAL = 10;
  200. SQLITE_FCNTL_OVERWRITE = 11;
  201. type
  202. psqlite3_mutex = ^sqlite3_mutex;
  203. sqlite3_mutex = record end;
  204. type
  205. psqlite3_vfs = ^sqlite3_vfs;
  206. sqlite3_vfs = record
  207. iVersion : cint; (* Structure version number *)
  208. szOsFile : cint; (* Size of subclassed sqlite3_file *)
  209. mxPathname : cint; (* Maximum file pathname length *)
  210. pNext : psqlite3_vfs; (* Next registered VFS *)
  211. zName : pchar; (* Name of this virtual file system *)
  212. pAppData : ppointer; (* Pointer to application-specific *)
  213. Open : function(vfs: psqlite3_vfs; zName: pchar; f: psqlite3_file; flags: cint; pOutFlags: pcint): cint; cdecl;
  214. Delete : function(vfs: psqlite3_vfs; zName: pchar; syncDir: cint): cint; cdecl;
  215. Access : function(vfs: psqlite3_vfs; zName: pchar; flags: cint): cint; cdecl;
  216. GetTempname : function(vfs: psqlite3_vfs; nOut: cint; zOut: pchar): cint; cdecl;
  217. FullPathname : function(vfs: psqlite3_vfs; zName: pchar; nOut: cint; zOut: pchar): cint; cdecl;
  218. DlOpen : function(vfs: psqlite3_vfs; zFilename: pchar): pointer; cdecl;
  219. DlError : procedure(vfs: psqlite3_vfs; nByte: cint; zErrMsg: pchar); cdecl;
  220. DlSym : function(vfs: psqlite3_vfs; addr: pointer; zSymbol: pchar): pointer; cdecl;
  221. DlClose : procedure(vfs: psqlite3_vfs; addr: pointer); cdecl;
  222. Randomness : function(vfs: psqlite3_vfs; nByte: cint; zOut: pchar): cint; cdecl;
  223. Sleep : function(vfs: psqlite3_vfs; microseconds: cint): cint; cdecl;
  224. CurrentTime : function(vfs: psqlite3_vfs; time: pcdouble): cint; cdecl;
  225. xSetSystemCall : function(vfs: psqlite3_vfs; zName: pchar; sqlite3_syscall_ptr : pointer) : cint;
  226. xGetSystemCall : function(vfs: psqlite3_vfs; zName: pchar) : pointer; cdecl;
  227. xNextSystemCall : function(vfs: psqlite3_vfs; zName: pchar) : pchar; cdecl;
  228. end;
  229. const
  230. SQLITE_ACCESS_EXISTS = 0;
  231. SQLITE_ACCESS_READWRITE = 1;
  232. SQLITE_ACCESS_READ = 2;
  233. SQLITE_SHM_UNLOCK = 1;
  234. SQLITE_SHM_LOCK = 2;
  235. SQLITE_SHM_SHARED = 4;
  236. SQLITE_SHM_EXCLUSIVE = 8;
  237. SQLITE_SHM_NLOCK = 8;
  238. {$IFDEF S}
  239. function sqlite3_initialize : cint;cdecl; external Sqlite3Lib;
  240. function sqlite3_shutdown : cint;cdecl; external Sqlite3Lib;
  241. function sqlite3_os_init : cint;cdecl; external Sqlite3Lib;
  242. function sqlite3_os_end : cint;cdecl; external Sqlite3Lib;
  243. {$endif}
  244. {$ifdef D}
  245. Var
  246. sqlite3_initialize,
  247. sqlite3_shutdown,
  248. sqlite3_os_init,
  249. sqlite3_os_end : Function : cint; cdecl;
  250. {$endif}
  251. {$IFDEF S}
  252. function sqlite3_config (a : cint): cint;cdecl;varargs; external Sqlite3Lib;
  253. {$ENDIF}
  254. {$IFDEF D}
  255. var
  256. sqlite3_config : function (a : cint): cint;cdecl;varargs;
  257. {$ENDIF}
  258. {$IFDEF S}
  259. function sqlite3_db_config (f : psqlite3; op : cint):cint;cdecl;varargs;external Sqlite3Lib;
  260. {$ENDIF}
  261. {$IFDEF D}
  262. var
  263. sqlite3_db_config : function (f : psqlite3; op : cint): cint;cdecl;varargs;
  264. {$ENDIF}
  265. Type
  266. sqlite3_mem_methods = record
  267. xMalloc : function(size : cint) : pointer;cdecl;
  268. xFree : procedure(p : pointer); cdecl;
  269. xRealloc : function(p : pointer;size : cint) : pointer;cdecl;
  270. xSize : function(p : pointer) : cint; cdecl;
  271. xRoundup : function(size : cint) : cint; cdecl;
  272. xInit : function(): cint; cdecl;
  273. xShutdown : procedure(p : pointer); cdecl;
  274. pAppData: pointer;
  275. end;
  276. Tsqlite3_mem_methods = sqlite3_mem_methods;
  277. Const
  278. SQLITE_CONFIG_SINGLETHREAD = 1;
  279. SQLITE_CONFIG_MULTITHREAD = 2;
  280. SQLITE_CONFIG_SERIALIZED = 3;
  281. SQLITE_CONFIG_MALLOC = 4;
  282. SQLITE_CONFIG_GETMALLOC = 5;
  283. SQLITE_CONFIG_SCRATCH = 6;
  284. SQLITE_CONFIG_PAGECACHE = 7;
  285. SQLITE_CONFIG_HEAP = 8;
  286. SQLITE_CONFIG_MEMSTATUS = 9;
  287. SQLITE_CONFIG_MUTEX = 10;
  288. SQLITE_CONFIG_GETMUTEX = 11;
  289. SQLITE_CONFIG_LOOKASIDE = 13;
  290. SQLITE_CONFIG_PCACHE = 14;
  291. SQLITE_CONFIG_GETPCACHE = 15;
  292. SQLITE_CONFIG_LOG = 16;
  293. SQLITE_CONFIG_URI = 17;
  294. SQLITE_DBCONFIG_LOOKASIDE = 1001;
  295. SQLITE_DBCONFIG_ENABLE_FKEY = 1002;
  296. SQLITE_DBCONFIG_ENABLE_TRIGGER = 1003;
  297. {$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}
  298. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_last_insert_rowid{$IFDEF D}: function{$ENDIF}(db: psqlite3): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  299. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_changes{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  300. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_total_changes{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  301. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_interrupt{$IFDEF D}: procedure{$ENDIF}(db: psqlite3); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  302. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_complete{$IFDEF D}: function{$ENDIF}(sql: pchar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  303. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_complete16{$IFDEF D}: function{$ENDIF}(sql: pchar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  304. type
  305. busyhandler_callback = function(user: pointer; cnt: cint): cint; cdecl;
  306. {$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}
  307. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_busy_timeout{$IFDEF D}: function{$ENDIF}(db: psqlite3; ms: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  308. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_get_table{$IFDEF D}: function{$ENDIF}(
  309. db: psqlite3; (* An open database *)
  310. sql: pchar; (* SQL to be evaluated *)
  311. pResult: pppchar; (* Results of the query *)
  312. nrow: pcint; (* Number of result rows written here *)
  313. ncolumn: pcint; (* Number of result columns written here *)
  314. errmsg: ppchar (* Error msg written here *)
  315. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  316. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_free_table{$IFDEF D}: procedure{$ENDIF}(result: ppchar); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  317. //char *sqlite3_mprintf(const char*,...);
  318. //char *sqlite3_vmprintf(const char*, va_list);
  319. //char *sqlite3_snprintf(int,char*,const char*, ...);
  320. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_malloc{$IFDEF D}: function{$ENDIF}(size: cint): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  321. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_realloc{$IFDEF D}: function{$ENDIF}(ptr: pointer; size: cint): pointer;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  322. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_free{$IFDEF D}: procedure{$ENDIF}(ptr: pointer);cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  323. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_memory_used{$IFDEF D}: function{$ENDIF}(): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  324. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_memory_highwater{$IFDEF D}: function{$ENDIF}(resetFlag: cint): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  325. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_randomness{$IFDEF D}: procedure{$ENDIF}(N: cint; P: pointer); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  326. type
  327. xAuth = function(pUserData: pointer; code: cint; s1, s2, s3, s4: pchar): cint; cdecl;
  328. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_set_authorizer{$IFDEF D}: function{$ENDIF}(
  329. db: psqlite3;
  330. cb: xAuth;
  331. pUserData: pointer
  332. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  333. const
  334. SQLITE_DENY = 1; (* Abort the SQL statement with an error *)
  335. SQLITE_IGNORE = 2; (* Don't allow access, but don't generate an error *)
  336. const
  337. SQLITE_CREATE_INDEX = 1; (* Index Name Table Name *)
  338. SQLITE_CREATE_TABLE = 2; (* Table Name NULL *)
  339. SQLITE_CREATE_TEMP_INDEX = 3; (* Index Name Table Name *)
  340. SQLITE_CREATE_TEMP_TABLE = 4; (* Table Name NULL *)
  341. SQLITE_CREATE_TEMP_TRIGGER = 5; (* Trigger Name Table Name *)
  342. SQLITE_CREATE_TEMP_VIEW = 6; (* View Name NULL *)
  343. SQLITE_CREATE_TRIGGER = 7; (* Trigger Name Table Name *)
  344. SQLITE_CREATE_VIEW = 8; (* View Name NULL *)
  345. SQLITE_DELETE = 9; (* Table Name NULL *)
  346. SQLITE_DROP_INDEX = 10; (* Index Name Table Name *)
  347. SQLITE_DROP_TABLE = 11; (* Table Name NULL *)
  348. SQLITE_DROP_TEMP_INDEX = 12; (* Index Name Table Name *)
  349. SQLITE_DROP_TEMP_TABLE = 13; (* Table Name NULL *)
  350. SQLITE_DROP_TEMP_TRIGGER = 14; (* Trigger Name Table Name *)
  351. SQLITE_DROP_TEMP_VIEW = 15; (* View Name NULL *)
  352. SQLITE_DROP_TRIGGER = 16; (* Trigger Name Table Name *)
  353. SQLITE_DROP_VIEW = 17; (* View Name NULL *)
  354. SQLITE_INSERT = 18; (* Table Name NULL *)
  355. SQLITE_PRAGMA = 19; (* Pragma Name 1st arg or NULL *)
  356. SQLITE_READ = 20; (* Table Name Column Name *)
  357. SQLITE_SELECT = 21; (* NULL NULL *)
  358. SQLITE_TRANSACTION = 22; (* NULL NULL *)
  359. SQLITE_UPDATE = 23; (* Table Name Column Name *)
  360. SQLITE_ATTACH = 24; (* Filename NULL *)
  361. SQLITE_DETACH = 25; (* Database Name NULL *)
  362. SQLITE_ALTER_TABLE = 26; (* Database Name Table Name *)
  363. SQLITE_REINDEX = 27; (* Index Name NULL *)
  364. SQLITE_ANALYZE = 28; (* Table Name NULL *)
  365. SQLITE_CREATE_VTABLE = 29; (* Table Name Module Name *)
  366. SQLITE_DROP_VTABLE = 30; (* Table Name Module Name *)
  367. SQLITE_FUNCTION = 31; (* Function Name NULL *)
  368. SQLITE_SAVEPOINT = 32; (* Operation Savepoint Name *)
  369. SQLITE_COPY = 0; (* No longer used *)
  370. type
  371. xTrace = procedure(user: pointer; s: pchar); cdecl;
  372. xProfile = procedure(user: pointer; s: char; i: sqlite3_uint64); cdecl;
  373. {$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}
  374. {$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}
  375. type
  376. progress_callback = function(user: pointer): cint; cdecl;
  377. {$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}
  378. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open{$IFDEF D}: function{$ENDIF}(
  379. filename: pchar; (* Database filename (UTF-8) *)
  380. ppDb: ppsqlite3 (* OUT: SQLite db handle *)
  381. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  382. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open16{$IFDEF D}: function{$ENDIF}(
  383. filename: pwidechar; (* Database filename (UTF-16) *)
  384. ppDb: ppsqlite3 (* OUT: SQLite db handle *)
  385. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  386. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_open_v2{$IFDEF D}: function{$ENDIF}(
  387. filename: pchar; (* Database filename (UTF-8) *)
  388. ppDb: ppsqlite3; (* OUT: SQLite db handle *)
  389. flags: cint; (* Flags *)
  390. zVfs: pchar (* Name of VFS module to use *)
  391. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  392. {$IFDEF S}
  393. function sqlite3_uri_parameter(zFilename : pchar; zParam :pchar) : pchar;cdecl;external Sqlite3Lib;
  394. {$ENDIF}
  395. {$IFDEF D}
  396. var
  397. sqlite3_uri_parameter : function(zFilename : pchar; zParam :pchar) : pchar;cdecl;
  398. {$ENDIF}
  399. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errcode{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  400. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_extended_errcode{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  401. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errmsg{$IFDEF D}: function{$ENDIF}(db: psqlite3): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  402. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_errmsg16{$IFDEF D}: function{$ENDIF}(db: psqlite3): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  403. type
  404. ppsqlite3_stmt = ^psqlite3_stmt;
  405. psqlite3_stmt = ^sqlite3_stmt;
  406. sqlite3_stmt = record end;
  407. {$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}
  408. const
  409. SQLITE_LIMIT_LENGTH = 0;
  410. SQLITE_LIMIT_SQL_LENGTH = 1;
  411. SQLITE_LIMIT_COLUMN = 2;
  412. SQLITE_LIMIT_EXPR_DEPTH = 3;
  413. SQLITE_LIMIT_COMPOUND_SELECT = 4;
  414. SQLITE_LIMIT_VDBE_OP = 5;
  415. SQLITE_LIMIT_FUNCTION_ARG = 6;
  416. SQLITE_LIMIT_ATTACHED = 7;
  417. SQLITE_LIMIT_LIKE_PATTERN_LENGTH = 8;
  418. SQLITE_LIMIT_VARIABLE_NUMBER = 9;
  419. SQLITE_LIMIT_TRIGGER_DEPTH = 10;
  420. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare{$IFDEF D}: function{$ENDIF}(
  421. db: psqlite3; (* Database handle *)
  422. zSql: pchar; (* SQL statement, UTF-8 encoded *)
  423. nByte: cint; (* Maximum length of zSql in bytes. *)
  424. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  425. pzTail: ppchar (* OUT: Pointer to unused portion of zSql *)
  426. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  427. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare_v2{$IFDEF D}: function{$ENDIF}(
  428. db: psqlite3; (* Database handle *)
  429. zSql: pchar; (* SQL statement, UTF-8 encoded *)
  430. nByte: cint; (* Maximum length of zSql in bytes. *)
  431. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  432. pzTail: ppchar (* OUT: Pointer to unused portion of zSql *)
  433. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  434. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare16{$IFDEF D}: function{$ENDIF}(
  435. db: psqlite3; (* Database handle *)
  436. zSql: pwidechar; (* SQL statement, UTF-16 encoded *)
  437. nByte: cint; (* Maximum length of zSql in bytes. *)
  438. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  439. pzTail: ppwidechar (* OUT: Pointer to unused portion of zSql *)
  440. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  441. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_prepare16_v2{$IFDEF D}: function{$ENDIF}(
  442. db: psqlite3; (* Database handle *)
  443. zSql: pwidechar; (* SQL statement, UTF-16 encoded *)
  444. nByte: cint; (* Maximum length of zSql in bytes. *)
  445. ppStmt: ppsqlite3_stmt; (* OUT: Statement handle *)
  446. pzTail: ppwidechar (* OUT: Pointer to unused portion of zSql *)
  447. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  448. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_sql{$IFDEF D}: function{$ENDIF}(pStmt: psqlite3_stmt): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  449. type
  450. ppsqlite3_value = ^psqlite3_value;
  451. psqlite3_value = ^sqlite3_value;
  452. sqlite3_value = record end;
  453. psqlite3_context = ^sqlite3_context;
  454. sqlite3_context = record end;
  455. {$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}
  456. {$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}
  457. {$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}
  458. {$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}
  459. {$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}
  460. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_text{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint; V: pchar; L: cint; D: sqlite3_destructor_type): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  461. {$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}
  462. {$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}
  463. {$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}
  464. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  465. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  466. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_bind_parameter_index{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; zName: pchar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  467. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_clear_bindings{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  468. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  469. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  470. {$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}
  471. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_database_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  472. {$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}
  473. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_table_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  474. {$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}
  475. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_origin_name{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  476. {$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}
  477. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_decltype{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; N: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  478. {$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}
  479. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_step{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  480. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_data_count{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  481. const
  482. SQLITE_INTEGER = 1;
  483. SQLITE_FLOAT = 2;
  484. SQLITE_BLOB = 4;
  485. SQLITE_NULL = 5;
  486. SQLITE_TEXT = 3;
  487. SQLITE3_TEXT = 3;
  488. {$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}
  489. {$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}
  490. {$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}
  491. {$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}
  492. {$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}
  493. {$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}
  494. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_column_text{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt; iCol: cint): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  495. {$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}
  496. {$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}
  497. {$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}
  498. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_finalize{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  499. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_reset{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  500. type
  501. xFunc = procedure(ctx: psqlite3_context; N: cint; V: ppsqlite3_value); cdecl;
  502. xStep = procedure(ctx: psqlite3_context; N: cint; V: ppsqlite3_value); cdecl;
  503. xFinal = procedure(ctx: psqlite3_context); cdecl;
  504. xDestroy = sqlite3_destructor_type;
  505. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function{$IFDEF D}: function{$ENDIF}(
  506. db: psqlite3;
  507. zFunctionName: pchar;
  508. nArg: cint;
  509. eTextRep: cint;
  510. pApp: pointer;
  511. funccb: xFunc;
  512. stepcb: xStep;
  513. finalcb: xFinal
  514. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  515. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function16{$IFDEF D}: function{$ENDIF}(
  516. db: psqlite3;
  517. zFunctionName: pwidechar;
  518. nArg: cint;
  519. eTextRep: cint;
  520. pApp: pointer;
  521. funccb: xFunc;
  522. stepcb: xStep;
  523. finalcb: xFinal
  524. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  525. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_function_v2{$IFDEF D}: function{$ENDIF}(
  526. db: psqlite3;
  527. zFunctionName: pchar;
  528. nArg: cint;
  529. eTextRep: cint;
  530. pApp: pointer;
  531. funccb: xFunc;
  532. stepcb: xStep;
  533. finalcb: xFinal;
  534. destroycb : xDestroy
  535. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  536. const
  537. SQLITE_UTF8 = 1;
  538. SQLITE_UTF16LE = 2;
  539. SQLITE_UTF16BE = 3;
  540. SQLITE_UTF16 = 4; (* Use native byte order *)
  541. SQLITE_ANY = 5; (* sqlite3_create_function only *)
  542. SQLITE_UTF16_ALIGNED = 8; (* sqlite3_create_collation only *)
  543. {$IFDEF SQLITE_OBSOLETE}
  544. type
  545. memory_alarm_cb = function(user: pointer; i64: sqlite3_int64; i: cint): pointer; cdecl;
  546. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_aggregate_count{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  547. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_expired{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  548. {$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}
  549. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_global_recover{$IFDEF D}: function{$ENDIF}(): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  550. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_thread_cleanup{$IFDEF D}: procedure{$ENDIF}(); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  551. {$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}
  552. {$ENDIF}
  553. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_blob{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  554. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_bytes{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  555. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_bytes16{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  556. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_double{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cdouble; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  557. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_int{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  558. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_int64{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): sqlite3_int64; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  559. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pchar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  560. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  561. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16le{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  562. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_text16be{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): pwidechar; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  563. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_type{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  564. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_value_numeric_type{$IFDEF D}: function{$ENDIF}(val: psqlite3_value): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  565. {$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}
  566. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_user_data{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): pointer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  567. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_context_db_handle{$IFDEF D}: function{$ENDIF}(ctx: psqlite3_context): psqlite3; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  568. type
  569. set_auxdata_cb = function(p: pointer): pointer; cdecl;
  570. {$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}
  571. {$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}
  572. {$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}
  573. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_double{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cdouble); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  574. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pchar; N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  575. {$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}
  576. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error_toobig{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  577. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_error_nomem{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  578. {$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}
  579. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_int{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  580. {$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}
  581. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_null{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  582. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_text{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: pchar; N: cint; D: sqlite3_destructor_type); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  583. {$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}
  584. {$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}
  585. {$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}
  586. {$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}
  587. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_result_zeroblob{$IFDEF D}: procedure{$ENDIF}(ctx: psqlite3_context; V: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  588. type
  589. xCompare = function(user: pointer; A: cint; B: pointer; C: cint; D: pointer): cint; cdecl;
  590. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation{$IFDEF D}: function{$ENDIF}(
  591. db: psqlite3;
  592. zName: pchar;
  593. eTextRep: cint;
  594. user: pointer;
  595. xcomparecb: xCompare
  596. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  597. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation_v2{$IFDEF D}: function{$ENDIF}(
  598. db: psqlite3;
  599. zName: pchar;
  600. eTextRep: cint;
  601. user: pointer;
  602. xcomparecb: xCompare;
  603. xdestroycb: xDestroy
  604. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  605. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_collation16{$IFDEF D}: function{$ENDIF}(
  606. db: psqlite3;
  607. zName: pwidechar;
  608. eTextRep: cint;
  609. user: pointer;
  610. xcomparecb: xCompare
  611. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  612. type
  613. collation_needed_cb = function(user: pointer; db: psqlite3; eTextRep: cint; s: pchar): pointer; cdecl;
  614. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_collation_needed{$IFDEF D}: function{$ENDIF}(
  615. db: psqlite3;
  616. user: pointer;
  617. cb: collation_needed_cb
  618. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  619. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_collation_needed16{$IFDEF D}: function{$ENDIF}(
  620. db: psqlite3;
  621. user: pointer;
  622. cb: collation_needed_cb
  623. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  624. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_key{$IFDEF D}: function{$ENDIF}(
  625. db: psqlite3; (* Database to be rekeyed *)
  626. pKey: pointer; nKey: cint (* The key *)
  627. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  628. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_rekey{$IFDEF D}: function{$ENDIF}(
  629. db: psqlite3; (* Database to be rekeyed *)
  630. pKey: pointer; nKey: cint (* The new key *)
  631. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  632. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_sleep{$IFDEF D}: function{$ENDIF}(M: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  633. {$ifndef win32}
  634. var
  635. sqlite3_temp_directory: pchar; cvar; external {Sqlite3Lib};
  636. {$endif}
  637. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_get_autocommit{$IFDEF D}: function{$ENDIF}(db: psqlite3): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  638. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_handle{$IFDEF D}: function{$ENDIF}(stmt: psqlite3_stmt): psqlite3; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  639. {$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}
  640. type
  641. commit_callback = function(user: pointer): cint; cdecl;
  642. {$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}
  643. {$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}
  644. type
  645. update_callback = procedure(user: pointer; event: cint; database, table: pchar; rowid: sqlite3_int64); cdecl;
  646. {$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}
  647. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_enable_shared_cache{$IFDEF D}: function{$ENDIF}(B: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  648. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_release_memory{$IFDEF D}: function{$ENDIF}(N: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  649. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_soft_heap_limit{$IFDEF D}: procedure{$ENDIF}(N: cint); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  650. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_soft_heap_limit64{$IFDEF D}: function{$ENDIF}(N: int64):int64;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  651. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_table_column_metadata{$IFDEF D}: function{$ENDIF}(
  652. db: psqlite3; (* Connection handle *)
  653. zDbName: pchar; (* Database name or NULL *)
  654. zTableName: pchar; (* Table name *)
  655. zColumnName: pchar; (* Column name *)
  656. pzDataType: ppchar; (* OUTPUT: Declared data type *)
  657. pzCollSeq: ppchar; (* OUTPUT: Collation sequence name *)
  658. pNotNull: pcint; (* OUTPUT: True if NOT NULL constracint exists *)
  659. pPrimaryKey: pcint; (* OUTPUT: True if column part of PK *)
  660. pAutoinc: pcint (* OUTPUT: True if column is auto-increment *)
  661. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  662. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_load_extension{$IFDEF D}: function{$ENDIF}(
  663. db: psqlite3; (* Load the extension cinto this database connection *)
  664. zFile: pchar; (* Name of the shared library containing extension *)
  665. zProc: pchar; (* Entry point. Derived from zFile if 0 *)
  666. pzErrMsg: ppchar (* Put error message here if not 0 *)
  667. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  668. {$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}
  669. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_auto_extension{$IFDEF D}: function{$ENDIF}(xEntrypoint: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  670. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_reset_auto_extension{$IFDEF D}: procedure{$ENDIF}(); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  671. type
  672. psqlite3_module = ^sqlite3_module;
  673. sqlite3_module = record{
  674. iVersion : cint;
  675. // xCreate : function(db: psqlite3; pAux: pointer; argc: cint; ): cint; cdecl;
  676. cint (*xCreate)(db: psqlite3; void *pAux;
  677. cint argc; const char *const*argv;
  678. sqlite3_vtab **ppVTab; char**);
  679. cint (*xConnect)(db: psqlite3; void *pAux;
  680. cint argc; const char *const*argv;
  681. sqlite3_vtab **ppVTab; char**);
  682. cint (*xBestIndex)(sqlite3_vtab *pVTab; sqlite3_index_info*);
  683. cint (*xDisconnect)(sqlite3_vtab *pVTab);
  684. cint (*xDestroy)(sqlite3_vtab *pVTab);
  685. cint (*xOpen)(sqlite3_vtab *pVTab; sqlite3_vtab_cursor **ppCursor);
  686. cint (*xClose)(sqlite3_vtab_cursor*);
  687. cint (*xFilter)(sqlite3_vtab_cursor*; cint idxNum; const char *idxStr;
  688. cint argc; sqlite3_value **argv);
  689. xNext : function(pVCurs: sqlite3_vtab_cursor): cint; cdecl;
  690. xEof : function(pVCurs: sqlite3_vtab_cursor): cint; cdecl;
  691. xColumn : function(pVCurs: sqlite3_vtab_cursor; ctx: psqlite3_context; i: cint): cint; cdecl;
  692. xRowid : function(pVCurs: sqlite3_vtab_cursor; var pRowid: sqlite3_int64): cint; cdecl;
  693. xUpdate : function(pVtab: psqlite3_vtab; var v: psqlite3_value; var p: sqlite3_int64): cint; cdecl;
  694. xBegin : function(pVtab: psqlite3_vtab): cint; cdecl;
  695. xSync : function(pVtab: psqlite3_vtab): cint; cdecl;
  696. xCommit : function(pVtab: psqlite3_vtab): cint; cdecl;
  697. xRollback : function(pVtab: psqlite3_vtab): cint; cdecl;
  698. xFindFunction : function(pVtab: psqlite3_vtab; nArg: cint; zName: pchar; var pxFunc: xFunc; var ppArg: pointer): cint; cdecl;
  699. xRename : function(pVtab: psqlite3_vtab; zNew: pchar): cint; cdecl;
  700. }end;
  701. {.$WARNING TODO}
  702. type
  703. psqlite3_index_constracint = ^sqlite3_index_constracint;
  704. sqlite3_index_constracint = record
  705. iColumn: cint; (* Column on left-hand side of constracint *)
  706. op: char; (* Constracint operator *)
  707. usable: char; (* True if this constracint is usable *)
  708. iTermOffset: cint; (* Used cinternally - xBestIndex should ignore *)
  709. end;
  710. psqlite3_index_orderby = ^sqlite3_index_orderby;
  711. sqlite3_index_orderby = record
  712. iColumn: cint; (* Column number *)
  713. desc: char; (* True for DESC. False for ASC. *)
  714. end;
  715. psqlite3_index_constracint_usage = ^sqlite3_index_constracint_usage;
  716. sqlite3_index_constracint_usage = record
  717. argvIndex: cint; (* if >0; constracint is part of argv to xFilter *)
  718. omit: char; (* Do not code a test for this constracint *)
  719. end;
  720. psqlite3_index_info = ^sqlite3_index_info;
  721. sqlite3_index_info = record
  722. (* Inputs *)
  723. nConstracint: cint; (* Number of entries in aConstracint *)
  724. aConstracint: psqlite3_index_constracint;
  725. nOrderBy: cint; (* Number of terms in the ORDER BY clause *)
  726. aOrderBy: psqlite3_index_orderby;
  727. (* Outputs *)
  728. aConstracintUsage: psqlite3_index_constracint_usage;
  729. idxNum: cint; (* Number used to identify the index *)
  730. idxStr: pchar; (* String; possibly obtained from sqlite3_malloc *)
  731. needToFreeIdxStr: cint; (* Free idxStr using sqlite3_free() if true *)
  732. orderByConsumed: cint; (* True if output is already ordered *)
  733. estimatedCost: cdouble; (* Estimated cost of using this index *)
  734. end;
  735. const
  736. SQLITE_INDEX_CONSTRAINT_EQ = 2;
  737. SQLITE_INDEX_CONSTRAINT_GT = 4;
  738. SQLITE_INDEX_CONSTRAINT_LE = 8;
  739. SQLITE_INDEX_CONSTRAINT_LT = 16;
  740. SQLITE_INDEX_CONSTRAINT_GE = 32;
  741. SQLITE_INDEX_CONSTRAINT_MATCH = 64;
  742. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_module{$IFDEF D}: function{$ENDIF}(
  743. db: psqlite3; (* SQLite connection to register module with *)
  744. zName: pchar; (* Name of the module *)
  745. module: psqlite3_module; (* Methods for the module *)
  746. user: pointer (* Client data for xCreate/xConnect *)
  747. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  748. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_create_module_v2{$IFDEF D}: function{$ENDIF}(
  749. db: psqlite3; (* SQLite connection to register module with *)
  750. zName: pchar; (* Name of the module *)
  751. module: psqlite3_module; (* Methods for the module *)
  752. user: pointer; (* Client data for xCreate/xConnect *)
  753. xdestroycb: xDestroy (* Module destructor function *)
  754. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  755. type
  756. psqlite3_vtab = ^sqlite3_vtab;
  757. sqlite3_vtab = record
  758. pModule: psqlite3_module; (* The module for this virtual table *)
  759. nRef: cint; (* Used cinternally *)
  760. zErrMsg: pchar; (* Error message from sqlite3_mprcintf() *)
  761. (* Virtual table implementations will typically add additional fields *)
  762. end;
  763. type
  764. psqlite3_vtab_cursor = ^sqlite3_vtab_cursor;
  765. sqlite3_vtab_cursor = record
  766. pVtab: psqlite3_vtab; (* Virtual table of this cursor *)
  767. (* Virtual table implementations will typically add additional fields *)
  768. end;
  769. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_declare_vtab{$IFDEF D}: function{$ENDIF}(db: psqlite3; zCreateTable: pchar): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  770. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_overload_function{$IFDEF D}: function{$ENDIF}(db: psqlite3; zFuncName: pchar; nArg: cint): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  771. type
  772. ppsqlite3_blob = ^psqlite3_blob;
  773. psqlite3_blob = ^sqlite3_blob;
  774. sqlite3_blob = record end;
  775. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_open{$IFDEF D}: function{$ENDIF}(
  776. db: psqlite3;
  777. zDb: pchar;
  778. zTable: pchar;
  779. zColumn: pchar;
  780. iRow: sqlite3_int64;
  781. flags: cint;
  782. ppBlob: ppsqlite3_blob
  783. ): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  784. {$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}
  785. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_close{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  786. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_blob_bytes{$IFDEF D}: function{$ENDIF}(blob: psqlite3_blob): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  787. {$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}
  788. {$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}
  789. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_vfs_find{$IFDEF D}: function{$ENDIF}(zVfsName: pchar): psqlite3_vfs; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  790. {$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}
  791. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_vfs_unregister{$IFDEF D}: function{$ENDIF}(vfs: psqlite3_vfs): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  792. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_alloc{$IFDEF D}: function{$ENDIF}(n: cint): psqlite3_mutex; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  793. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_free{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  794. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_ente{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  795. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_try{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  796. {$IFDEF S}procedure{$ELSE}var{$ENDIF}sqlite3_mutex_leave{$IFDEF D}: procedure{$ENDIF}(mtx: psqlite3_mutex); cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  797. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_held{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  798. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_mutex_notheld{$IFDEF D}: function{$ENDIF}(mtx: psqlite3_mutex): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  799. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_db_mutex{$IFDEF D}: function{$ENDIF}(db: psqlite3): psqlite3_mutex; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  800. const
  801. SQLITE_MUTEX_FAST = 0;
  802. SQLITE_MUTEX_RECURSIVE = 1;
  803. SQLITE_MUTEX_STATIC_MASTER = 2;
  804. SQLITE_MUTEX_STATIC_MEM = 3; (* sqlite3_malloc() *)
  805. SQLITE_MUTEX_STATIC_MEM2 = 4; (* sqlite3_release_memory() *)
  806. SQLITE_MUTEX_STATIC_PRNG = 5; (* sqlite3_random() *)
  807. SQLITE_MUTEX_STATIC_LRU = 6; (* lru page list *)
  808. SQLITE_MUTEX_STATIC_LRU2 = 7; (* lru page list *)
  809. {$IFDEF S}function{$ELSE}var{$ENDIF}sqlite3_file_control{$IFDEF D}: function{$ENDIF}(db: psqlite3; zDbName: pchar; op: cint; p: pointer): cint; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  810. {$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}
  811. {$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}
  812. {$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}
  813. {$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}
  814. const
  815. SQLITE_TESTCTRL_FAULT_CONFIG = 1;
  816. SQLITE_TESTCTRL_FAULT_FAILURES = 2;
  817. SQLITE_TESTCTRL_FAULT_BENIGN_FAILURES = 3;
  818. SQLITE_TESTCTRL_FAULT_PENDING = 4;
  819. SQLITE_TESTCTRL_PRNG_SAVE = 5;
  820. SQLITE_TESTCTRL_PRNG_RESTORE = 6;
  821. SQLITE_TESTCTRL_PRNG_RESET = 7;
  822. SQLITE_TESTCTRL_BITVEC_TEST = 8;
  823. {Backup api}
  824. type
  825. psqlite3backup = Pointer;
  826. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_init{$IFDEF D}: function{$ENDIF}(pDest: psqlite3; const zDestName: pchar; pSource: psqlite3; const zSourceName: pchar): psqlite3backup; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  827. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_step{$IFDEF D}: function{$ENDIF}(p: psqlite3backup; nPage: Integer): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  828. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_finish{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  829. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_remaining{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  830. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_backup_pagecount{$IFDEF D}: function{$ENDIF}(p: psqlite3backup): Integer; cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  831. Type
  832. xNotifycb = procedure (Argp: pointer; narg : cint);cdecl;
  833. {$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}
  834. {$IFDEF S}procedure{$ELSE}var{$ENDIF} sqlite3_log{$IFDEF D}: procedure{$ENDIF}(iErrCode:cint;fmt : pchar); cdecl;varargs;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  835. Type
  836. wal_hook_cb = function (p : pointer; db :psqlite3; c : pchar; d: cint): cint;cdecl;
  837. {$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}
  838. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_autocheckpoint{$IFDEF D}: function{$ENDIF}(db:psqlite3;n : cint): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  839. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_checkpoint{$IFDEF D}: function{$ENDIF}(db:psqlite3;zDB: pchar): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  840. {$IFDEF S}function{$ELSE}var{$ENDIF} sqlite3_wal_checkpoint_v2{$IFDEF D}: function{$ENDIF}(db:psqlite3;zDB: pchar;emode:cint;nLog:pcint;nCkpt:pcint): cint;cdecl;{$IFDEF S}external Sqlite3Lib;{$ENDIF}
  841. {$IFDEF LOAD_DYNAMICALLY}
  842. function InitializeSqliteANSI(const LibraryName: AnsiString = ''): Integer; //needed as TLibraryLoadFunction
  843. function InitializeSqlite(const LibraryName: UnicodeString = ''): Integer;
  844. function TryInitializeSqlite(const LibraryName: Unicodestring = ''): Integer;
  845. function ReleaseSqlite: Integer;
  846. procedure ReleaseSqlite; //needed as TLibraryUnLoadFunction
  847. function InitialiseSQLite: Integer; deprecated;
  848. function InitialiseSQLite(const LibraryName: UnicodeString): Integer; deprecated;
  849. var
  850. SQLiteLibraryHandle: TLibHandle;
  851. SQLiteDefaultLibrary: String = Sqlite3Lib;
  852. SQLiteLoadedLibrary: UnicodeString;
  853. {$ENDIF LOAD_DYNAMICALLY}
  854. implementation
  855. function sqlite3_version(): pchar;
  856. begin
  857. Result := sqlite3_libversion();
  858. end;
  859. {$IFDEF LOAD_DYNAMICALLY}
  860. resourcestring
  861. SErrLoadFailed = 'Can not load SQLite client library "%s". Check your installation.';
  862. SErrAlreadyLoaded = 'SQLite interface already initialized from library %s.';
  863. procedure LoadAddresses(LibHandle: TLibHandle);
  864. begin
  865. pointer(sqlite3_libversion) := GetProcedureAddress(LibHandle,'sqlite3_libversion');
  866. pointer(sqlite3_libversion_number) := GetProcedureAddress(LibHandle,'sqlite3_libversion_number');
  867. pointer(sqlite3_threadsafe) := GetProcedureAddress(LibHandle,'sqlite3_threadsafe');
  868. pointer(sqlite3_close) := GetProcedureAddress(LibHandle,'sqlite3_close');
  869. pointer(sqlite3_exec) := GetProcedureAddress(LibHandle,'sqlite3_exec');
  870. pointer(sqlite3_extended_result_codes) := GetProcedureAddress(LibHandle,'sqlite3_extended_result_codes');
  871. pointer(sqlite3_last_insert_rowid) := GetProcedureAddress(LibHandle,'sqlite3_last_insert_rowid');
  872. pointer(sqlite3_changes) := GetProcedureAddress(LibHandle,'sqlite3_changes');
  873. pointer(sqlite3_total_changes) := GetProcedureAddress(LibHandle,'sqlite3_total_changes');
  874. pointer(sqlite3_complete) := GetProcedureAddress(LibHandle,'sqlite3_complete');
  875. pointer(sqlite3_complete16) := GetProcedureAddress(LibHandle,'sqlite3_complete16');
  876. pointer(sqlite3_busy_handler) := GetProcedureAddress(LibHandle,'sqlite3_busy_handler');
  877. pointer(sqlite3_busy_timeout) := GetProcedureAddress(LibHandle,'sqlite3_busy_timeout');
  878. pointer(sqlite3_get_table) := GetProcedureAddress(LibHandle,'sqlite3_get_table');
  879. pointer(sqlite3_malloc) := GetProcedureAddress(LibHandle,'sqlite3_malloc');
  880. pointer(sqlite3_realloc) := GetProcedureAddress(LibHandle,'sqlite3_realloc');
  881. pointer(sqlite3_memory_used) := GetProcedureAddress(LibHandle,'sqlite3_memory_used');
  882. pointer(sqlite3_memory_highwater) := GetProcedureAddress(LibHandle,'sqlite3_memory_highwater');
  883. pointer(sqlite3_set_authorizer) := GetProcedureAddress(LibHandle,'sqlite3_set_authorizer');
  884. pointer(sqlite3_trace) := GetProcedureAddress(LibHandle,'sqlite3_trace');
  885. pointer(sqlite3_profile) := GetProcedureAddress(LibHandle,'sqlite3_profile');
  886. pointer(sqlite3_open) := GetProcedureAddress(LibHandle,'sqlite3_open');
  887. pointer(sqlite3_open16) := GetProcedureAddress(LibHandle,'sqlite3_open16');
  888. pointer(sqlite3_open_v2) := GetProcedureAddress(LibHandle,'sqlite3_open_v2');
  889. pointer(sqlite3_errcode) := GetProcedureAddress(LibHandle,'sqlite3_errcode');
  890. pointer(sqlite3_extended_errcode) := GetProcedureAddress(LibHandle,'sqlite3_extended_errcode');
  891. pointer(sqlite3_errmsg) := GetProcedureAddress(LibHandle,'sqlite3_errmsg');
  892. pointer(sqlite3_errmsg16) := GetProcedureAddress(LibHandle,'sqlite3_errmsg16');
  893. pointer(sqlite3_limit) := GetProcedureAddress(LibHandle,'sqlite3_limit');
  894. pointer(sqlite3_prepare) := GetProcedureAddress(LibHandle,'sqlite3_prepare');
  895. pointer(sqlite3_prepare_v2) := GetProcedureAddress(LibHandle,'sqlite3_prepare_v2');
  896. pointer(sqlite3_prepare16) := GetProcedureAddress(LibHandle,'sqlite3_prepare16');
  897. pointer(sqlite3_prepare16_v2) := GetProcedureAddress(LibHandle,'sqlite3_prepare16_v2');
  898. pointer(sqlite3_sql) := GetProcedureAddress(LibHandle,'sqlite3_sql');
  899. pointer(sqlite3_bind_blob) := GetProcedureAddress(LibHandle,'sqlite3_bind_blob');
  900. pointer(sqlite3_bind_double) := GetProcedureAddress(LibHandle,'sqlite3_bind_double');
  901. pointer(sqlite3_bind_int) := GetProcedureAddress(LibHandle,'sqlite3_bind_int');
  902. pointer(sqlite3_bind_int64) := GetProcedureAddress(LibHandle,'sqlite3_bind_int64');
  903. pointer(sqlite3_bind_null) := GetProcedureAddress(LibHandle,'sqlite3_bind_null');
  904. pointer(sqlite3_bind_text) := GetProcedureAddress(LibHandle,'sqlite3_bind_text');
  905. pointer(sqlite3_bind_text16) := GetProcedureAddress(LibHandle,'sqlite3_bind_text16');
  906. pointer(sqlite3_bind_value) := GetProcedureAddress(LibHandle,'sqlite3_bind_value');
  907. pointer(sqlite3_bind_zeroblob) := GetProcedureAddress(LibHandle,'sqlite3_bind_zeroblob');
  908. pointer(sqlite3_bind_parameter_count) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_count');
  909. pointer(sqlite3_bind_parameter_name) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_name');
  910. pointer(sqlite3_bind_parameter_index) := GetProcedureAddress(LibHandle,'sqlite3_bind_parameter_index');
  911. pointer(sqlite3_clear_bindings) := GetProcedureAddress(LibHandle,'sqlite3_clear_bindings');
  912. pointer(sqlite3_column_count) := GetProcedureAddress(LibHandle,'sqlite3_column_count');
  913. pointer(sqlite3_column_name) := GetProcedureAddress(LibHandle,'sqlite3_column_name');
  914. pointer(sqlite3_column_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_name16');
  915. pointer(sqlite3_column_database_name) := GetProcedureAddress(LibHandle,'sqlite3_column_database_name');
  916. pointer(sqlite3_column_database_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_database_name16');
  917. pointer(sqlite3_column_table_name) := GetProcedureAddress(LibHandle,'sqlite3_column_table_name');
  918. pointer(sqlite3_column_table_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_table_name16');
  919. pointer(sqlite3_column_origin_name) := GetProcedureAddress(LibHandle,'sqlite3_column_origin_name');
  920. pointer(sqlite3_column_origin_name16) := GetProcedureAddress(LibHandle,'sqlite3_column_origin_name16');
  921. pointer(sqlite3_column_decltype) := GetProcedureAddress(LibHandle,'sqlite3_column_decltype');
  922. pointer(sqlite3_column_decltype16) := GetProcedureAddress(LibHandle,'sqlite3_column_decltype16');
  923. pointer(sqlite3_step) := GetProcedureAddress(LibHandle,'sqlite3_step');
  924. pointer(sqlite3_data_count) := GetProcedureAddress(LibHandle,'sqlite3_data_count');
  925. pointer(sqlite3_column_blob) := GetProcedureAddress(LibHandle,'sqlite3_column_blob');
  926. pointer(sqlite3_column_bytes) := GetProcedureAddress(LibHandle,'sqlite3_column_bytes');
  927. pointer(sqlite3_column_bytes16) := GetProcedureAddress(LibHandle,'sqlite3_column_bytes16');
  928. pointer(sqlite3_column_double) := GetProcedureAddress(LibHandle,'sqlite3_column_double');
  929. pointer(sqlite3_column_int) := GetProcedureAddress(LibHandle,'sqlite3_column_int');
  930. pointer(sqlite3_column_int64) := GetProcedureAddress(LibHandle,'sqlite3_column_int64');
  931. pointer(sqlite3_column_text) := GetProcedureAddress(LibHandle,'sqlite3_column_text');
  932. pointer(sqlite3_column_text16) := GetProcedureAddress(LibHandle,'sqlite3_column_text16');
  933. pointer(sqlite3_column_type) := GetProcedureAddress(LibHandle,'sqlite3_column_type');
  934. pointer(sqlite3_column_value) := GetProcedureAddress(LibHandle,'sqlite3_column_value');
  935. pointer(sqlite3_finalize) := GetProcedureAddress(LibHandle,'sqlite3_finalize');
  936. pointer(sqlite3_reset) := GetProcedureAddress(LibHandle,'sqlite3_reset');
  937. pointer(sqlite3_create_function) := GetProcedureAddress(LibHandle,'sqlite3_create_function');
  938. pointer(sqlite3_create_function16) := GetProcedureAddress(LibHandle,'sqlite3_create_function16');
  939. pointer(sqlite3_create_function_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_function_v2');
  940. pointer(sqlite3_value_blob) := GetProcedureAddress(LibHandle,'sqlite3_value_blob');
  941. pointer(sqlite3_value_bytes) := GetProcedureAddress(LibHandle,'sqlite3_value_bytes');
  942. pointer(sqlite3_value_bytes16) := GetProcedureAddress(LibHandle,'sqlite3_value_bytes16');
  943. pointer(sqlite3_value_double) := GetProcedureAddress(LibHandle,'sqlite3_value_double');
  944. pointer(sqlite3_value_int) := GetProcedureAddress(LibHandle,'sqlite3_value_int');
  945. pointer(sqlite3_value_int64) := GetProcedureAddress(LibHandle,'sqlite3_value_int64');
  946. pointer(sqlite3_value_text) := GetProcedureAddress(LibHandle,'sqlite3_value_text');
  947. pointer(sqlite3_value_text16) := GetProcedureAddress(LibHandle,'sqlite3_value_text16');
  948. pointer(sqlite3_value_text16le) := GetProcedureAddress(LibHandle,'sqlite3_value_text16le');
  949. pointer(sqlite3_value_text16be) := GetProcedureAddress(LibHandle,'sqlite3_value_text16be');
  950. pointer(sqlite3_value_type) := GetProcedureAddress(LibHandle,'sqlite3_value_type');
  951. pointer(sqlite3_value_numeric_type) := GetProcedureAddress(LibHandle,'sqlite3_value_numeric_type');
  952. pointer(sqlite3_aggregate_context) := GetProcedureAddress(LibHandle,'sqlite3_aggregate_context');
  953. pointer(sqlite3_user_data) := GetProcedureAddress(LibHandle,'sqlite3_user_data');
  954. pointer(sqlite3_context_db_handle) := GetProcedureAddress(LibHandle,'sqlite3_context_db_handle');
  955. pointer(sqlite3_get_auxdata) := GetProcedureAddress(LibHandle,'sqlite3_get_auxdata');
  956. pointer(sqlite3_create_collation) := GetProcedureAddress(LibHandle,'sqlite3_create_collation');
  957. pointer(sqlite3_create_collation_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_collation_v2');
  958. pointer(sqlite3_create_collation16) := GetProcedureAddress(LibHandle,'sqlite3_create_collation16');
  959. pointer(sqlite3_collation_needed) := GetProcedureAddress(LibHandle,'sqlite3_collation_needed');
  960. pointer(sqlite3_collation_needed16) := GetProcedureAddress(LibHandle,'sqlite3_collation_needed16');
  961. pointer(sqlite3_key) := GetProcedureAddress(LibHandle,'sqlite3_key');
  962. pointer(sqlite3_rekey) := GetProcedureAddress(LibHandle,'sqlite3_rekey');
  963. pointer(sqlite3_sleep) := GetProcedureAddress(LibHandle,'sqlite3_sleep');
  964. pointer(sqlite3_get_autocommit) := GetProcedureAddress(LibHandle,'sqlite3_get_autocommit');
  965. pointer(sqlite3_db_handle) := GetProcedureAddress(LibHandle,'sqlite3_db_handle');
  966. pointer(sqlite3_commit_hook) := GetProcedureAddress(LibHandle,'sqlite3_commit_hook');
  967. pointer(sqlite3_rollback_hook) := GetProcedureAddress(LibHandle,'sqlite3_rollback_hook');
  968. pointer(sqlite3_update_hook) := GetProcedureAddress(LibHandle,'sqlite3_update_hook');
  969. pointer(sqlite3_enable_shared_cache) := GetProcedureAddress(LibHandle,'sqlite3_enable_shared_cache');
  970. pointer(sqlite3_release_memory) := GetProcedureAddress(LibHandle,'sqlite3_release_memory');
  971. pointer(sqlite3_table_column_metadata) := GetProcedureAddress(LibHandle,'sqlite3_table_column_metadata');
  972. pointer(sqlite3_load_extension) := GetProcedureAddress(LibHandle,'sqlite3_load_extension');
  973. pointer(sqlite3_enable_load_extension) := GetProcedureAddress(LibHandle,'sqlite3_enable_load_extension');
  974. pointer(sqlite3_auto_extension) := GetProcedureAddress(LibHandle,'sqlite3_auto_extension');
  975. pointer(sqlite3_create_module) := GetProcedureAddress(LibHandle,'sqlite3_create_module');
  976. pointer(sqlite3_create_module_v2) := GetProcedureAddress(LibHandle,'sqlite3_create_module_v2');
  977. pointer(sqlite3_declare_vtab) := GetProcedureAddress(LibHandle,'sqlite3_declare_vtab');
  978. pointer(sqlite3_overload_function) := GetProcedureAddress(LibHandle,'sqlite3_overload_function');
  979. pointer(sqlite3_blob_open) := GetProcedureAddress(LibHandle,'sqlite3_blob_open');
  980. pointer(sqlite3_blob_reopen) := GetProcedureAddress(LibHandle,'sqlite3_blob_reopen');
  981. pointer(sqlite3_blob_close) := GetProcedureAddress(LibHandle,'sqlite3_blob_close');
  982. pointer(sqlite3_blob_bytes) := GetProcedureAddress(LibHandle,'sqlite3_blob_bytes');
  983. pointer(sqlite3_blob_read) := GetProcedureAddress(LibHandle,'sqlite3_blob_read');
  984. pointer(sqlite3_blob_write) := GetProcedureAddress(LibHandle,'sqlite3_blob_write');
  985. pointer(sqlite3_vfs_find) := GetProcedureAddress(LibHandle,'sqlite3_vfs_find');
  986. pointer(sqlite3_vfs_register) := GetProcedureAddress(LibHandle,'sqlite3_vfs_register');
  987. pointer(sqlite3_vfs_unregister) := GetProcedureAddress(LibHandle,'sqlite3_vfs_unregister');
  988. pointer(sqlite3_mutex_alloc) := GetProcedureAddress(LibHandle,'sqlite3_mutex_alloc');
  989. pointer(sqlite3_mutex_try) := GetProcedureAddress(LibHandle,'sqlite3_mutex_try');
  990. pointer(sqlite3_mutex_held) := GetProcedureAddress(LibHandle,'sqlite3_mutex_held');
  991. pointer(sqlite3_mutex_notheld) := GetProcedureAddress(LibHandle,'sqlite3_mutex_notheld');
  992. pointer(sqlite3_db_mutex) := GetProcedureAddress(LibHandle,'sqlite3_db_mutex');
  993. pointer(sqlite3_file_control) := GetProcedureAddress(LibHandle,'sqlite3_file_control');
  994. pointer(sqlite3_test_control) := GetProcedureAddress(LibHandle,'sqlite3_test_control');
  995. pointer(sqlite3_status) := GetProcedureAddress(LibHandle,'sqlite3_status');
  996. pointer(sqlite3_db_status) := GetProcedureAddress(LibHandle,'sqlite3_db_status');
  997. pointer(sqlite3_stmt_status) := GetProcedureAddress(LibHandle,'sqlite3_stmt_status');
  998. pointer(sqlite3_interrupt) := GetProcedureAddress(LibHandle,'sqlite3_interrupt');
  999. pointer(sqlite3_free_table) := GetProcedureAddress(LibHandle,'sqlite3_free_table');
  1000. pointer(sqlite3_free) := GetProcedureAddress(LibHandle,'sqlite3_free');
  1001. pointer(sqlite3_randomness) := GetProcedureAddress(LibHandle,'sqlite3_randomness');
  1002. pointer(sqlite3_progress_handler) := GetProcedureAddress(LibHandle,'sqlite3_progress_handler');
  1003. pointer(sqlite3_set_auxdata) := GetProcedureAddress(LibHandle,'sqlite3_set_auxdata');
  1004. pointer(sqlite3_result_blob) := GetProcedureAddress(LibHandle,'sqlite3_result_blob');
  1005. pointer(sqlite3_result_double) := GetProcedureAddress(LibHandle,'sqlite3_result_double');
  1006. pointer(sqlite3_result_error) := GetProcedureAddress(LibHandle,'sqlite3_result_error');
  1007. pointer(sqlite3_result_error16) := GetProcedureAddress(LibHandle,'sqlite3_result_error16');
  1008. pointer(sqlite3_result_error_toobig) := GetProcedureAddress(LibHandle,'sqlite3_result_error_toobig');
  1009. pointer(sqlite3_result_error_nomem) := GetProcedureAddress(LibHandle,'sqlite3_result_error_nomem');
  1010. pointer(sqlite3_result_error_code) := GetProcedureAddress(LibHandle,'sqlite3_result_error_code');
  1011. pointer(sqlite3_result_int) := GetProcedureAddress(LibHandle,'sqlite3_result_int');
  1012. pointer(sqlite3_result_int64) := GetProcedureAddress(LibHandle,'sqlite3_result_int64');
  1013. pointer(sqlite3_result_null) := GetProcedureAddress(LibHandle,'sqlite3_result_null');
  1014. pointer(sqlite3_result_text) := GetProcedureAddress(LibHandle,'sqlite3_result_text');
  1015. pointer(sqlite3_result_text16) := GetProcedureAddress(LibHandle,'sqlite3_result_text16');
  1016. pointer(sqlite3_result_text16le) := GetProcedureAddress(LibHandle,'sqlite3_result_text16le');
  1017. pointer(sqlite3_result_text16be) := GetProcedureAddress(LibHandle,'sqlite3_result_text16be');
  1018. pointer(sqlite3_result_value) := GetProcedureAddress(LibHandle,'sqlite3_result_value');
  1019. pointer(sqlite3_result_zeroblob) := GetProcedureAddress(LibHandle,'sqlite3_result_zeroblob');
  1020. pointer(sqlite3_soft_heap_limit) := GetProcedureAddress(LibHandle,'sqlite3_soft_heap_limit');
  1021. pointer(sqlite3_soft_heap_limit64) := GetProcedureAddress(LibHandle,'sqlite3_soft_heap_limit64');
  1022. pointer(sqlite3_reset_auto_extension) := GetProcedureAddress(LibHandle,'sqlite3_reset_auto_extension');
  1023. pointer(sqlite3_mutex_free) := GetProcedureAddress(LibHandle,'sqlite3_mutex_free');
  1024. pointer(sqlite3_mutex_ente) := GetProcedureAddress(LibHandle,'sqlite3_mutex_ente');
  1025. pointer(sqlite3_mutex_leave) := GetProcedureAddress(LibHandle,'sqlite3_mutex_leave');
  1026. pointer(sqlite3_backup_init) := GetProcedureAddress(LibHandle,'sqlite3_backup_init');
  1027. pointer(sqlite3_backup_step) := GetProcedureAddress(LibHandle,'sqlite3_backup_step');
  1028. pointer(sqlite3_backup_finish) := GetProcedureAddress(LibHandle,'sqlite3_backup_finish');
  1029. pointer(sqlite3_backup_remaining) := GetProcedureAddress(LibHandle,'sqlite3_backup_remaining');
  1030. pointer(sqlite3_backup_pagecount) := GetProcedureAddress(LibHandle,'sqlite3_backup_pagecount');
  1031. pointer(sqlite3_unlock_notify) := GetProcedureAddress(LibHandle,'sqlite3_unlock_notify');
  1032. pointer(sqlite3_log) := GetProcedureAddress(LibHandle,'sqlite3_log');
  1033. pointer(sqlite3_wal_hook) := GetProcedureAddress(LibHandle,'sqlite3_wal_hook');
  1034. pointer(sqlite3_wal_autocheckpoint) := GetProcedureAddress(LibHandle,'sqlite3_wal_autocheckpoint');
  1035. pointer(sqlite3_wal_checkpoint) := GetProcedureAddress(LibHandle,'sqlite3_wal_checkpoint');
  1036. pointer(sqlite3_wal_checkpoint_v2) := GetProcedureAddress(LibHandle,'sqlite3_wal_checkpoint_v2');
  1037. pointer(sqlite3_initialize) := GetProcedureAddress(LibHandle,'sqlite3_initialize');
  1038. pointer(sqlite3_shutdown) := GetProcedureAddress(LibHandle,'sqlite3_shutdown');
  1039. pointer(sqlite3_os_init) := GetProcedureAddress(LibHandle,'sqlite3_os_init');
  1040. pointer(sqlite3_os_end) := GetProcedureAddress(LibHandle,'sqlite3_os_end');
  1041. pointer(sqlite3_config) := GetProcedureAddress(LibHandle,'sqlite3_config');
  1042. pointer(sqlite3_db_config) := GetProcedureAddress(LibHandle,'sqlite3_db_config');
  1043. pointer(sqlite3_uri_parameter) := GetProcedureAddress(LibHandle,'sqlite3_uri_parameter');
  1044. {$IFDEF SQLITE_OBSOLETE}
  1045. pointer(sqlite3_aggregate_count) := GetProcedureAddress(LibHandle,'sqlite3_aggregate_count');
  1046. pointer(sqlite3_expired) := GetProcedureAddress(LibHandle,'sqlite3_expired');
  1047. pointer(sqlite3_transfer_bindings) := GetProcedureAddress(LibHandle,'sqlite3_transfer_bindings');
  1048. pointer(sqlite3_global_recover) := GetProcedureAddress(LibHandle,'sqlite3_global_recover');
  1049. pointer(sqlite3_memory_alarm) := GetProcedureAddress(LibHandle,'sqlite3_memory_alarm');
  1050. pointer(sqlite3_thread_cleanup) := GetProcedureAddress(LibHandle,'sqlite3_thread_cleanup');
  1051. {$ENDIF}
  1052. end;
  1053. var
  1054. RefCount: Integer;
  1055. function TryInitializeSqlite(const LibraryName: UnicodeString): Integer;
  1056. Var
  1057. N : UnicodeString;
  1058. begin
  1059. N:=LibraryName;
  1060. if (N='') then
  1061. N:=SQLiteDefaultLibrary;
  1062. result:=InterlockedIncrement(RefCount);
  1063. if result = 1 then
  1064. begin
  1065. SQLiteLibraryHandle := LoadLibrary(N);
  1066. if (SQLiteLibraryHandle = NilHandle) then
  1067. begin
  1068. RefCount := 0;
  1069. Exit(-1);
  1070. end;
  1071. SQLiteLoadedLibrary := N;
  1072. LoadAddresses(SQLiteLibraryHandle);
  1073. end;
  1074. end;
  1075. function InitialiseSQLite:integer;
  1076. begin
  1077. result:=InitializeSqlite(SQLiteDefaultLibrary);
  1078. end;
  1079. function InitializeSQLiteANSI(const LibraryName: AnsiString):integer;
  1080. begin
  1081. result:=InitializeSQLite(LibraryName);
  1082. end;
  1083. function InitializeSQLite(const LibraryName: UnicodeString) :integer;
  1084. begin
  1085. if (LibraryName<>'') and (SQLiteLoadedLibrary <> '') and (SQLiteLoadedLibrary <> LibraryName) then
  1086. raise EInoutError.CreateFmt(SErrAlreadyLoaded,[SQLiteLoadedLibrary]);
  1087. result:= TryInitializeSQLite(LibraryName);
  1088. if result=-1 then
  1089. if LibraryName='' then
  1090. raise EInOutError.CreateFmt(SErrLoadFailed,[SQLiteDefaultLibrary])
  1091. else
  1092. raise EInOutError.CreateFmt(SErrLoadFailed,[LibraryName]);
  1093. end;
  1094. function InitialiseSQLite(const LibraryName: UnicodeString):integer;
  1095. begin
  1096. result:=InitializeSqlite(LibraryName);
  1097. end;
  1098. function ReleaseSQLite:integer;
  1099. begin
  1100. if InterlockedDecrement(RefCount) <= 0 then
  1101. begin
  1102. if SQLiteLibraryHandle <> NilHandle then
  1103. UnloadLibrary(SQLiteLibraryHandle);
  1104. SQLiteLibraryHandle := NilHandle;
  1105. SQLiteLoadedLibrary := '';
  1106. RefCount := 0;
  1107. end;
  1108. end;
  1109. procedure ReleaseSQLite;
  1110. begin
  1111. ReleaseSQLite;
  1112. end;
  1113. {$ENDIF}