PageRenderTime 77ms CodeModel.GetById 10ms RepoModel.GetById 0ms app.codeStats 2ms

/Community.CsharpSqlite/src/sqlite3_h.cs

https://bitbucket.org/eumario/csharp-sqlite
C# | 7485 lines | 703 code | 209 blank | 6573 comment | 1 complexity | 567165b45bb3aa2ee8635f8eeb4ebd54 MD5 | raw file
  1. using u8 = System.Byte;
  2. using System.Diagnostics;
  3. namespace Community.CsharpSqlite
  4. {
  5. public partial class Sqlite3
  6. {
  7. /*
  8. ** 2001 September 15
  9. **
  10. ** The author disclaims copyright to this source code. In place of
  11. ** a legal notice, here is a blessing:
  12. **
  13. ** May you do good and not evil.
  14. ** May you find forgiveness for yourself and forgive others.
  15. ** May you share freely, never taking more than you give.
  16. **
  17. *************************************************************************
  18. ** This header file defines the interface that the SQLite library
  19. ** presents to client programs. If a C-function, structure, datatype,
  20. ** or constant definition does not appear in this file, then it is
  21. ** not a published API of SQLite, is subject to change without
  22. ** notice, and should not be referenced by programs that use SQLite.
  23. **
  24. ** Some of the definitions that are in this file are marked as
  25. ** "experimental". Experimental interfaces are normally new
  26. ** features recently added to SQLite. We do not anticipate changes
  27. ** to experimental interfaces but reserve the right to make minor changes
  28. ** if experience from use "in the wild" suggest such changes are prudent.
  29. **
  30. ** The official C-language API documentation for SQLite is derived
  31. ** from comments in this file. This file is the authoritative source
  32. ** on how SQLite interfaces are suppose to operate.
  33. **
  34. ** The name of this file under configuration management is "sqlite.h.in".
  35. ** The makefile makes some minor changes to this file (such as inserting
  36. ** the version number) and changes its name to "sqlite3.h" as
  37. ** part of the build process.
  38. *************************************************************************
  39. ** Included in SQLite3 port to C#-SQLite; 2008 Noah B Hart
  40. ** C#-SQLite is an independent reimplementation of the SQLite software library
  41. **
  42. ** SQLITE_SOURCE_ID: 2011-06-23 19:49:22 4374b7e83ea0a3fbc3691f9c0c936272862f32f2
  43. **
  44. *************************************************************************
  45. */
  46. //#if !_SQLITE3_H_
  47. //#define _SQLITE3_H_
  48. //#include <stdarg.h> /* Needed for the definition of va_list */
  49. /*
  50. ** Make sure we can call this stuff from C++.
  51. */
  52. //#if __cplusplus
  53. //extern "C" {
  54. //#endif
  55. /*
  56. ** Add the ability to override 'extern'
  57. */
  58. //#if !SQLITE_EXTERN
  59. //# define SQLITE_EXTERN extern
  60. //#endif
  61. //#if !SQLITE_API
  62. //# define SQLITE_API
  63. //#endif
  64. /*
  65. ** These no-op macros are used in front of interfaces to mark those
  66. ** interfaces as either deprecated or experimental. New applications
  67. ** should not use deprecated interfaces - they are support for backwards
  68. ** compatibility only. Application writers should be aware that
  69. ** experimental interfaces are subject to change in point releases.
  70. **
  71. ** These macros used to resolve to various kinds of compiler magic that
  72. ** would generate warning messages when they were used. But that
  73. ** compiler magic ended up generating such a flurry of bug reports
  74. ** that we have taken it all out and gone back to using simple
  75. ** noop macros.
  76. */
  77. //#define SQLITE_DEPRECATED
  78. //#define SQLITE_EXPERIMENTAL
  79. /*
  80. ** Ensure these symbols were not defined by some previous header file.
  81. */
  82. //#if SQLITE_VERSION
  83. //# undef SQLITE_VERSION
  84. //#endif
  85. //#if SQLITE_VERSION_NUMBER
  86. //# undef SQLITE_VERSION_NUMBER
  87. //#endif
  88. /*
  89. ** CAPI3REF: Compile-Time Library Version Numbers
  90. **
  91. ** ^(The [SQLITE_VERSION] C preprocessor macro in the sqlite3.h header
  92. ** evaluates to a string literal that is the SQLite version in the
  93. ** format "X.Y.Z" where X is the major version number (always 3 for
  94. ** SQLite3) and Y is the minor version number and Z is the release number.)^
  95. ** ^(The [SQLITE_VERSION_NUMBER] C preprocessor macro resolves to an integer
  96. ** with the value (X*1000000 + Y*1000 + Z) where X, Y, and Z are the same
  97. ** numbers used in [SQLITE_VERSION].)^
  98. ** The SQLITE_VERSION_NUMBER for any given release of SQLite will also
  99. ** be larger than the release from which it is derived. Either Y will
  100. ** be held constant and Z will be incremented or else Y will be incremented
  101. ** and Z will be reset to zero.
  102. **
  103. ** Since version 3.6.18, SQLite source code has been stored in the
  104. ** <a href="http://www.fossil-scm.org/">Fossil configuration management
  105. ** system</a>. ^The SQLITE_SOURCE_ID macro evaluates to
  106. ** a string which identifies a particular check-in of SQLite
  107. ** within its configuration management system. ^The SQLITE_SOURCE_ID
  108. ** string contains the date and time of the check-in (UTC) and an SHA1
  109. ** hash of the entire source tree.
  110. **
  111. ** See also: [sqlite3_libversion()],
  112. ** [sqlite3_libversion_number()], [sqlite3_sourceid()],
  113. ** [sqlite_version()] and [sqlite_source_id()].
  114. */
  115. //#define SQLITE_VERSION "3.7.7"
  116. //#define SQLITE_VERSION_NUMBER 3007007
  117. //#define SQLITE_SOURCE_ID "2011-06-23 19:49:22 4374b7e83ea0a3fbc3691f9c0c936272862f32f2"
  118. public const string SQLITE_VERSION = "3.7.7(C#)";
  119. public const int SQLITE_VERSION_NUMBER = 300700701;
  120. public const string SQLITE_SOURCE_ID = "2011-06-23 19:49:22 4374b7e83ea0a3fbc3691f9c0c936272862f32f2";
  121. /*
  122. ** CAPI3REF: Run-Time Library Version Numbers
  123. ** KEYWORDS: sqlite3_version, sqlite3_sourceid
  124. **
  125. ** These interfaces provide the same information as the [SQLITE_VERSION],
  126. ** [SQLITE_VERSION_NUMBER], and [SQLITE_SOURCE_ID] C preprocessor macros
  127. ** but are associated with the library instead of the header file. ^(Cautious
  128. ** programmers might include Debug.Assert() statements in their application to
  129. ** verify that values returned by these interfaces match the macros in
  130. ** the header, and thus insure that the application is
  131. ** compiled with matching library and header files.
  132. **
  133. ** <blockquote><pre>
  134. ** Debug.Assert( sqlite3_libversion_number()==SQLITE_VERSION_NUMBER );
  135. ** Debug.Assert( strcmp(sqlite3_sourceid(),SQLITE_SOURCE_ID)==0 );
  136. ** Debug.Assert( strcmp(sqlite3_libversion(),SQLITE_VERSION)==0 );
  137. ** </pre></blockquote>)^
  138. **
  139. ** ^The sqlite3_version[] string constant contains the text of [SQLITE_VERSION]
  140. ** macro. ^The sqlite3_libversion() function returns a pointer to the
  141. ** to the sqlite3_version[] string constant. The sqlite3_libversion()
  142. ** function is provided for use in DLLs since DLL users usually do not have
  143. ** direct access to string constants within the DLL. ^The
  144. ** sqlite3_libversion_number() function returns an integer equal to
  145. ** [SQLITE_VERSION_NUMBER]. ^The sqlite3_sourceid() function returns
  146. ** a pointer to a string constant whose value is the same as the
  147. ** [SQLITE_SOURCE_ID] C preprocessor macro.
  148. **
  149. ** See also: [sqlite_version()] and [sqlite_source_id()].
  150. */
  151. //SQLITE_API SQLITE_EXTERN const char sqlite3_version[];
  152. //SQLITE_API string sqlite3_libversion(void);
  153. //SQLITE_API string sqlite3_sourceid(void);
  154. //SQLITE_API int sqlite3_libversion_number(void);
  155. /*
  156. ** CAPI3REF: Run-Time Library Compilation Options Diagnostics
  157. **
  158. ** ^The sqlite3_compileoption_used() function returns 0 or 1
  159. ** indicating whether the specified option was defined at
  160. ** compile time. ^The SQLITE_ prefix may be omitted from the
  161. ** option name passed to sqlite3_compileoption_used().
  162. **
  163. ** ^The sqlite3_compileoption_get() function allows iterating
  164. ** over the list of options that were defined at compile time by
  165. ** returning the N-th compile time option string. ^If N is out of range,
  166. ** sqlite3_compileoption_get() returns a NULL pointer. ^The SQLITE_
  167. ** prefix is omitted from any strings returned by
  168. ** sqlite3_compileoption_get().
  169. **
  170. ** ^Support for the diagnostic functions sqlite3_compileoption_used()
  171. ** and sqlite3_compileoption_get() may be omitted by specifying the
  172. ** [SQLITE_OMIT_COMPILEOPTION_DIAGS] option at compile time.
  173. **
  174. ** See also: SQL functions [sqlite_compileoption_used()] and
  175. ** [sqlite_compileoption_get()] and the [compile_options pragma].
  176. */
  177. //#if !SQLITE_OMIT_COMPILEOPTION_DIAGS
  178. //SQLITE_API int sqlite3_compileoption_used(string zOptName);
  179. //SQLITE_API string sqlite3_compileoption_get(int N);
  180. //#endif
  181. /*
  182. ** CAPI3REF: Test To See If The Library Is Threadsafe
  183. **
  184. ** ^The sqlite3_threadsafe() function returns zero if and only if
  185. ** SQLite was compiled mutexing code omitted due to the
  186. ** [SQLITE_THREADSAFE] compile-time option being set to 0.
  187. **
  188. ** SQLite can be compiled with or without mutexes. When
  189. ** the [SQLITE_THREADSAFE] C preprocessor macro is 1 or 2, mutexes
  190. ** are enabled and SQLite is threadsafe. When the
  191. ** [SQLITE_THREADSAFE] macro is 0,
  192. ** the mutexes are omitted. Without the mutexes, it is not safe
  193. ** to use SQLite concurrently from more than one thread.
  194. **
  195. ** Enabling mutexes incurs a measurable performance penalty.
  196. ** So if speed is of utmost importance, it makes sense to disable
  197. ** the mutexes. But for maximum safety, mutexes should be enabled.
  198. ** ^The default behavior is for mutexes to be enabled.
  199. **
  200. ** This interface can be used by an application to make sure that the
  201. ** version of SQLite that it is linking against was compiled with
  202. ** the desired setting of the [SQLITE_THREADSAFE] macro.
  203. **
  204. ** This interface only reports on the compile-time mutex setting
  205. ** of the [SQLITE_THREADSAFE] flag. If SQLite is compiled with
  206. ** SQLITE_THREADSAFE=1 or =2 then mutexes are enabled by default but
  207. ** can be fully or partially disabled using a call to [sqlite3_config()]
  208. ** with the verbs [SQLITE_CONFIG_SINGLETHREAD], [SQLITE_CONFIG_MULTITHREAD],
  209. ** or [SQLITE_CONFIG_MUTEX]. ^(The return value of the
  210. ** sqlite3_threadsafe() function shows only the compile-time setting of
  211. ** thread safety, not any run-time changes to that setting made by
  212. ** sqlite3_config(). In other words, the return value from sqlite3_threadsafe()
  213. ** is unchanged by calls to sqlite3_config().)^
  214. **
  215. ** See the [threading mode] documentation for additional information.
  216. */
  217. //SQLITE_API int sqlite3_threadsafe(void);
  218. /*
  219. ** CAPI3REF: Database Connection Handle
  220. ** KEYWORDS: {database connection} {database connections}
  221. **
  222. ** Each open SQLite database is represented by a pointer to an instance of
  223. ** the opaque structure named "sqlite3". It is useful to think of an sqlite3
  224. ** pointer as an object. The [sqlite3_open()], [sqlite3_open16()], and
  225. ** [sqlite3_open_v2()] interfaces are its constructors, and [sqlite3_close()]
  226. ** is its destructor. There are many other interfaces (such as
  227. ** [sqlite3_prepare_v2()], [sqlite3_create_function()], and
  228. ** [sqlite3_busy_timeout()] to name but three) that are methods on an
  229. ** sqlite3 object.
  230. */
  231. //typedef struct sqlite3 sqlite3;
  232. /*
  233. ** CAPI3REF: 64-Bit Integer Types
  234. ** KEYWORDS: sqlite_int64 sqlite_uint64
  235. **
  236. ** Because there is no cross-platform way to specify 64-bit integer types
  237. ** SQLite includes typedefs for 64-bit signed and unsigned integers.
  238. **
  239. ** The sqlite3_int64 and sqlite3_uint64 are the preferred type definitions.
  240. ** The sqlite_int64 and sqlite_uint64 types are supported for backwards
  241. ** compatibility only.
  242. **
  243. ** ^The sqlite3_int64 and sqlite_int64 types can store integer values
  244. ** between -9223372036854775808 and +9223372036854775807 inclusive. ^The
  245. ** sqlite3_uint64 and sqlite_uint64 types can store integer values
  246. ** between 0 and +18446744073709551615 inclusive.
  247. */
  248. //#if SQLITE_INT64_TYPE
  249. // typedef SQLITE_INT64_TYPE sqlite_int64;
  250. // typedef unsigned SQLITE_INT64_TYPE sqlite_uint64;
  251. //#elif defined(_MSC_VER) || defined(__BORLANDC__)
  252. // typedef __int64 sqlite_int64;
  253. // typedef unsigned __int64 sqlite_uint64;
  254. //#else
  255. // typedef long long int sqlite_int64;
  256. // typedef unsigned long long int sqlite_uint64;
  257. //#endif
  258. //typedef sqlite_int64 sqlite3_int64;
  259. //typedef sqlite_uint64 sqlite3_uint64;
  260. /*
  261. ** If compiling for a processor that lacks floating point support,
  262. ** substitute integer for floating-point.
  263. */
  264. //#if SQLITE_OMIT_FLOATING_POINT
  265. //# define double sqlite3_int64
  266. //#endif
  267. /*
  268. ** CAPI3REF: Closing A Database Connection
  269. **
  270. ** ^The sqlite3_close() routine is the destructor for the [sqlite3] object.
  271. ** ^Calls to sqlite3_close() return SQLITE_OK if the [sqlite3] object is
  272. ** successfully destroyed and all associated resources are deallocated.
  273. **
  274. ** Applications must [sqlite3_finalize | finalize] all [prepared statements]
  275. ** and [sqlite3_blob_close | close] all [BLOB handles] associated with
  276. ** the [sqlite3] object prior to attempting to close the object. ^If
  277. ** sqlite3_close() is called on a [database connection] that still has
  278. ** outstanding [prepared statements] or [BLOB handles], then it returns
  279. ** SQLITE_BUSY.
  280. **
  281. ** ^If [sqlite3_close()] is invoked while a transaction is open,
  282. ** the transaction is automatically rolled back.
  283. **
  284. ** The C parameter to [sqlite3_close(C)] must be either a NULL
  285. ** pointer or an [sqlite3] object pointer obtained
  286. ** from [sqlite3_open()], [sqlite3_open16()], or
  287. ** [sqlite3_open_v2()], and not previously closed.
  288. ** ^Calling sqlite3_close() with a NULL pointer argument is a
  289. ** harmless no-op.
  290. */
  291. //SQLITE_API int sqlite3_close(sqlite3 );
  292. /*
  293. ** The type for a callback function.
  294. ** This is legacy and deprecated. It is included for historical
  295. ** compatibility and is not documented.
  296. */
  297. //typedef int (*sqlite3_callback)(void*,int,char**, char*);
  298. /*
  299. ** CAPI3REF: One-Step Query Execution Interface
  300. **
  301. ** The sqlite3_exec() interface is a convenience wrapper around
  302. ** [sqlite3_prepare_v2()], [sqlite3_step()], and [sqlite3_finalize()],
  303. ** that allows an application to run multiple statements of SQL
  304. ** without having to use a lot of C code.
  305. **
  306. ** ^The sqlite3_exec() interface runs zero or more UTF-8 encoded,
  307. ** semicolon-separate SQL statements passed into its 2nd argument,
  308. ** in the context of the [database connection] passed in as its 1st
  309. ** argument. ^If the callback function of the 3rd argument to
  310. ** sqlite3_exec() is not NULL, then it is invoked for each result row
  311. ** coming out of the evaluated SQL statements. ^The 4th argument to
  312. ** sqlite3_exec() is relayed through to the 1st argument of each
  313. ** callback invocation. ^If the callback pointer to sqlite3_exec()
  314. ** is NULL, then no callback is ever invoked and result rows are
  315. ** ignored.
  316. **
  317. ** ^If an error occurs while evaluating the SQL statements passed into
  318. ** sqlite3_exec(), then execution of the current statement stops and
  319. ** subsequent statements are skipped. ^If the 5th parameter to sqlite3_exec()
  320. ** is not NULL then any error message is written into memory obtained
  321. ** from [sqlite3_malloc()] and passed back through the 5th parameter.
  322. ** To avoid memory leaks, the application should invoke [sqlite3_free()]
  323. ** on error message strings returned through the 5th parameter of
  324. ** of sqlite3_exec() after the error message string is no longer needed.
  325. ** ^If the 5th parameter to sqlite3_exec() is not NULL and no errors
  326. ** occur, then sqlite3_exec() sets the pointer in its 5th parameter to
  327. ** NULL before returning.
  328. **
  329. ** ^If an sqlite3_exec() callback returns non-zero, the sqlite3_exec()
  330. ** routine returns SQLITE_ABORT without invoking the callback again and
  331. ** without running any subsequent SQL statements.
  332. **
  333. ** ^The 2nd argument to the sqlite3_exec() callback function is the
  334. ** number of columns in the result. ^The 3rd argument to the sqlite3_exec()
  335. ** callback is an array of pointers to strings obtained as if from
  336. ** [sqlite3_column_text()], one for each column. ^If an element of a
  337. ** result row is NULL then the corresponding string pointer for the
  338. ** sqlite3_exec() callback is a NULL pointer. ^The 4th argument to the
  339. ** sqlite3_exec() callback is an array of pointers to strings where each
  340. ** entry represents the name of corresponding result column as obtained
  341. ** from [sqlite3_column_name()].
  342. **
  343. ** ^If the 2nd parameter to sqlite3_exec() is a NULL pointer, a pointer
  344. ** to an empty string, or a pointer that contains only whitespace and/or
  345. ** SQL comments, then no SQL statements are evaluated and the database
  346. ** is not changed.
  347. **
  348. ** Restrictions:
  349. **
  350. ** <ul>
  351. ** <li> The application must insure that the 1st parameter to sqlite3_exec()
  352. ** is a valid and open [database connection].
  353. ** <li> The application must not close [database connection] specified by
  354. ** the 1st parameter to sqlite3_exec() while sqlite3_exec() is running.
  355. ** <li> The application must not modify the SQL statement text passed into
  356. ** the 2nd parameter of sqlite3_exec() while sqlite3_exec() is running.
  357. ** </ul>
  358. */
  359. //SQLITE_API int sqlite3_exec(
  360. // sqlite3*, /* An open database */
  361. // string sql, /* SQL to be evaluated */
  362. // int (*callback)(void*,int,char**,char*), /* Callback function */
  363. // void *, /* 1st argument to callback */
  364. // char **errmsg /* Error msg written here */
  365. //);
  366. /*
  367. ** CAPI3REF: Result Codes
  368. ** KEYWORDS: SQLITE_OK {error code} {error codes}
  369. ** KEYWORDS: {result code} {result codes}
  370. **
  371. ** Many SQLite functions return an integer result code from the set shown
  372. ** here in order to indicates success or failure.
  373. **
  374. ** New error codes may be added in future versions of SQLite.
  375. **
  376. ** See also: [SQLITE_IOERR_READ | extended result codes],
  377. ** [sqlite3_vtab_on_conflict()] [SQLITE_ROLLBACK | result codes].
  378. */
  379. //#define SQLITE_OK 0 /* Successful result */
  380. ///* beginning-of-error-codes */
  381. //#define SQLITE_ERROR 1 /* SQL error or missing database */
  382. //#define SQLITE_INTERNAL 2 /* Internal logic error in SQLite */
  383. //#define SQLITE_PERM 3 /* Access permission denied */
  384. //#define SQLITE_ABORT 4 /* Callback routine requested an abort */
  385. //#define SQLITE_BUSY 5 /* The database file is locked */
  386. //#define SQLITE_LOCKED 6 /* A table in the database is locked */
  387. //#define SQLITE_NOMEM 7 /* A malloc() failed */
  388. //#define SQLITE_READONLY 8 /* Attempt to write a readonly database */
  389. //#define SQLITE_INTERRUPT 9 /* Operation terminated by sqlite3_interrupt()*/
  390. //#define SQLITE_IOERR 10 /* Some kind of disk I/O error occurred */
  391. //#define SQLITE_CORRUPT 11 /* The database disk image is malformed */
  392. //#define SQLITE_NOTFOUND 12 /* Unknown opcode in sqlite3_file_control() */
  393. //#define SQLITE_FULL 13 /* Insertion failed because database is full */
  394. //#define SQLITE_CANTOPEN 14 /* Unable to open the database file */
  395. //#define SQLITE_PROTOCOL 15 /* Database lock protocol error */
  396. //#define SQLITE_EMPTY 16 /* Database is empty */
  397. //#define SQLITE_SCHEMA 17 /* The database schema changed */
  398. //#define SQLITE_TOOBIG 18 /* String or BLOB exceeds size limit */
  399. //#define SQLITE_CONSTRAINT 19 /* Abort due to constraint violation */
  400. //#define SQLITE_MISMATCH 20 /* Data type mismatch */
  401. //#define SQLITE_MISUSE 21 /* Library used incorrectly */
  402. //#define SQLITE_NOLFS 22 /* Uses OS features not supported on host */
  403. //#define SQLITE_AUTH 23 /* Authorization denied */
  404. //#define SQLITE_FORMAT 24 /* Auxiliary database format error */
  405. //#define SQLITE_RANGE 25 /* 2nd parameter to sqlite3_bind out of range */
  406. //#define SQLITE_NOTADB 26 /* File opened that is not a database file */
  407. //#define SQLITE_ROW 100 /* sqlite3_step() has another row ready */
  408. //#define SQLITE_DONE 101 /* sqlite3_step() has finished executing */
  409. /* end-of-error-codes */
  410. public const int SQLITE_OK = 0;
  411. public const int SQLITE_ERROR = 1;
  412. public const int SQLITE_INTERNAL = 2;
  413. public const int SQLITE_PERM = 3;
  414. public const int SQLITE_ABORT = 4;
  415. public const int SQLITE_BUSY = 5;
  416. public const int SQLITE_LOCKED = 6;
  417. public const int SQLITE_NOMEM = 7;
  418. public const int SQLITE_READONLY = 8;
  419. public const int SQLITE_INTERRUPT = 9;
  420. public const int SQLITE_IOERR = 10;
  421. public const int SQLITE_CORRUPT = 11;
  422. public const int SQLITE_NOTFOUND = 12;
  423. public const int SQLITE_FULL = 13;
  424. public const int SQLITE_CANTOPEN = 14;
  425. public const int SQLITE_PROTOCOL = 15;
  426. public const int SQLITE_EMPTY = 16;
  427. public const int SQLITE_SCHEMA = 17;
  428. public const int SQLITE_TOOBIG = 18;
  429. public const int SQLITE_CONSTRAINT = 19;
  430. public const int SQLITE_MISMATCH = 20;
  431. public const int SQLITE_MISUSE = 21;
  432. public const int SQLITE_NOLFS = 22;
  433. public const int SQLITE_AUTH = 23;
  434. public const int SQLITE_FORMAT = 24;
  435. public const int SQLITE_RANGE = 25;
  436. public const int SQLITE_NOTADB = 26;
  437. public const int SQLITE_ROW = 100;
  438. public const int SQLITE_DONE = 101;
  439. /*
  440. ** CAPI3REF: Extended Result Codes
  441. ** KEYWORDS: {extended error code} {extended error codes}
  442. ** KEYWORDS: {extended result code} {extended result codes}
  443. **
  444. ** In its default configuration, SQLite API routines return one of 26 integer
  445. ** [SQLITE_OK | result codes]. However, experience has shown that many of
  446. ** these result codes are too coarse-grained. They do not provide as
  447. ** much information about problems as programmers might like. In an effort to
  448. ** address this, newer versions of SQLite (version 3.3.8 and later) include
  449. ** support for additional result codes that provide more detailed information
  450. ** about errors. The extended result codes are enabled or disabled
  451. ** on a per database connection basis using the
  452. ** [sqlite3_extended_result_codes()] API.
  453. **
  454. ** Some of the available extended result codes are listed here.
  455. ** One may expect the number of extended result codes will be expand
  456. ** over time. Software that uses extended result codes should expect
  457. ** to see new result codes in future releases of SQLite.
  458. **
  459. ** The SQLITE_OK result code will never be extended. It will always
  460. ** be exactly zero.
  461. */
  462. //#define SQLITE_IOERR_READ (SQLITE_IOERR | (1<<8))
  463. //#define SQLITE_IOERR_SHORT_READ (SQLITE_IOERR | (2<<8))
  464. //#define SQLITE_IOERR_WRITE (SQLITE_IOERR | (3<<8))
  465. //#define SQLITE_IOERR_FSYNC (SQLITE_IOERR | (4<<8))
  466. //#define SQLITE_IOERR_DIR_FSYNC (SQLITE_IOERR | (5<<8))
  467. //#define SQLITE_IOERR_TRUNCATE (SQLITE_IOERR | (6<<8))
  468. //#define SQLITE_IOERR_FSTAT (SQLITE_IOERR | (7<<8))
  469. //#define SQLITE_IOERR_UNLOCK (SQLITE_IOERR | (8<<8))
  470. //#define SQLITE_IOERR_RDLOCK (SQLITE_IOERR | (9<<8))
  471. //#define SQLITE_IOERR_DELETE (SQLITE_IOERR | (10<<8))
  472. //#define SQLITE_IOERR_BLOCKED (SQLITE_IOERR | (11<<8))
  473. //#define SQLITE_IOERR_NOMEM (SQLITE_IOERR | (12<<8))
  474. //#define SQLITE_IOERR_ACCESS (SQLITE_IOERR | (13<<8))
  475. //#define SQLITE_IOERR_CHECKRESERVEDLOCK (SQLITE_IOERR | (14<<8))
  476. //#define SQLITE_IOERR_LOCK (SQLITE_IOERR | (15<<8))
  477. //#define SQLITE_IOERR_CLOSE (SQLITE_IOERR | (16<<8))
  478. //#define SQLITE_IOERR_DIR_CLOSE (SQLITE_IOERR | (17<<8))
  479. //#define SQLITE_IOERR_SHMOPEN (SQLITE_IOERR | (18<<8))
  480. //#define SQLITE_IOERR_SHMSIZE (SQLITE_IOERR | (19<<8))
  481. //#define SQLITE_IOERR_SHMLOCK (SQLITE_IOERR | (20<<8))
  482. //#define SQLITE_IOERR_SHMMAP (SQLITE_IOERR | (21<<8))
  483. //#define SQLITE_IOERR_SEEK (SQLITE_IOERR | (22<<8))
  484. //#define SQLITE_LOCKED_SHAREDCACHE (SQLITE_LOCKED | (1<<8))
  485. //#define SQLITE_BUSY_RECOVERY (SQLITE_BUSY | (1<<8))
  486. //#define SQLITE_CANTOPEN_NOTEMPDIR (SQLITE_CANTOPEN | (1<<8))
  487. //#define SQLITE_CORRUPT_VTAB (SQLITE_CORRUPT | (1<<8))
  488. //#define SQLITE_READONLY_RECOVERY (SQLITE_READONLY | (1<<8))
  489. //#define SQLITE_READONLY_CANTLOCK (SQLITE_READONLY | (2<<8))
  490. const int SQLITE_IOERR_READ = ( SQLITE_IOERR | ( 1 << 8 ) );
  491. const int SQLITE_IOERR_SHORT_READ = ( SQLITE_IOERR | ( 2 << 8 ) );
  492. const int SQLITE_IOERR_WRITE = ( SQLITE_IOERR | ( 3 << 8 ) );
  493. const int SQLITE_IOERR_FSYNC = ( SQLITE_IOERR | ( 4 << 8 ) );
  494. const int SQLITE_IOERR_DIR_FSYNC = ( SQLITE_IOERR | ( 5 << 8 ) );
  495. const int SQLITE_IOERR_TRUNCATE = ( SQLITE_IOERR | ( 6 << 8 ) );
  496. const int SQLITE_IOERR_FSTAT = ( SQLITE_IOERR | ( 7 << 8 ) );
  497. const int SQLITE_IOERR_UNLOCK = ( SQLITE_IOERR | ( 8 << 8 ) );
  498. const int SQLITE_IOERR_RDLOCK = ( SQLITE_IOERR | ( 9 << 8 ) );
  499. const int SQLITE_IOERR_DELETE = ( SQLITE_IOERR | ( 10 << 8 ) );
  500. const int SQLITE_IOERR_BLOCKED = ( SQLITE_IOERR | ( 11 << 8 ) );
  501. const int SQLITE_IOERR_NOMEM = ( SQLITE_IOERR | ( 12 << 8 ) );
  502. const int SQLITE_IOERR_ACCESS = ( SQLITE_IOERR | ( 13 << 8 ) );
  503. const int SQLITE_IOERR_CHECKRESERVEDLOCK = ( SQLITE_IOERR | ( 14 << 8 ) );
  504. const int SQLITE_IOERR_LOCK = ( SQLITE_IOERR | ( 15 << 8 ) );
  505. const int SQLITE_IOERR_CLOSE = ( SQLITE_IOERR | ( 16 << 8 ) );
  506. const int SQLITE_IOERR_DIR_CLOSE = ( SQLITE_IOERR | ( 17 << 8 ) );
  507. const int SQLITE_IOERR_SHMOPEN = ( SQLITE_IOERR | ( 18 << 8 ) );
  508. const int SQLITE_IOERR_SHMSIZE = ( SQLITE_IOERR | ( 19 << 8 ) );
  509. const int SQLITE_IOERR_SHMLOCK = ( SQLITE_IOERR | ( 20 << 8 ) );
  510. const int SQLITE_IOERR_SHMMAP = ( SQLITE_IOERR | ( 21 << 8 ) );
  511. const int SQLITE_IOERR_SEEK = ( SQLITE_IOERR | ( 22 << 8 ) );
  512. const int SQLITE_LOCKED_SHAREDCACHE = ( SQLITE_LOCKED | ( 1 << 8 ) );
  513. const int SQLITE_BUSY_RECOVERY = ( SQLITE_BUSY | ( 1 << 8 ) );
  514. const int SQLITE_CANTOPEN_NOTEMPDIR = ( SQLITE_CANTOPEN | ( 1 << 8 ) );
  515. const int SQLITE_CORRUPT_VTAB = ( SQLITE_CORRUPT | ( 1 << 8 ) );
  516. const int SQLITE_READONLY_RECOVERY = ( SQLITE_READONLY | ( 1 << 8 ) );
  517. const int SQLITE_READONLY_CANTLOCK = ( SQLITE_READONLY | ( 2 << 8 ) );
  518. /*
  519. ** CAPI3REF: Flags For File Open Operations
  520. **
  521. ** These bit values are intended for use in the
  522. ** 3rd parameter to the [sqlite3_open_v2()] interface and
  523. ** in the 4th parameter to the [sqlite3_vfs.xOpen] method.
  524. */
  525. //#define SQLITE_OPEN_READONLY 0x00000001 /* Ok for sqlite3_open_v2() */
  526. //#define SQLITE_OPEN_READWRITE 0x00000002 /* Ok for sqlite3_open_v2() */
  527. //#define SQLITE_OPEN_CREATE 0x00000004 /* Ok for sqlite3_open_v2() */
  528. //#define SQLITE_OPEN_DELETEONCLOSE 0x00000008 /* VFS only */
  529. //#define SQLITE_OPEN_EXCLUSIVE 0x00000010 /* VFS only */
  530. //#define SQLITE_OPEN_AUTOPROXY 0x00000020 /* VFS only */
  531. //#define SQLITE_OPEN_URI 0x00000040 /* Ok for sqlite3_open_v2() */
  532. //#define SQLITE_OPEN_MAIN_DB 0x00000100 /* VFS only */
  533. //#define SQLITE_OPEN_TEMP_DB 0x00000200 /* VFS only */
  534. //#define SQLITE_OPEN_TRANSIENT_DB 0x00000400 /* VFS only */
  535. //#define SQLITE_OPEN_MAIN_JOURNAL 0x00000800 /* VFS only */
  536. //#define SQLITE_OPEN_TEMP_JOURNAL 0x00001000 /* VFS only */
  537. //#define SQLITE_OPEN_SUBJOURNAL 0x00002000 /* VFS only */
  538. //#define SQLITE_OPEN_MASTER_JOURNAL 0x00004000 /* VFS only */
  539. //#define SQLITE_OPEN_NOMUTEX 0x00008000 /* Ok for sqlite3_open_v2() */
  540. //#define SQLITE_OPEN_FULLMUTEX 0x00010000 /* Ok for sqlite3_open_v2() */
  541. //#define SQLITE_OPEN_SHAREDCACHE 0x00020000 /* Ok for sqlite3_open_v2() */
  542. //#define SQLITE_OPEN_PRIVATECACHE 0x00040000 /* Ok for sqlite3_open_v2() */
  543. //#define SQLITE_OPEN_WAL 0x00080000 /* VFS only */
  544. /* Reserved: 0x00F00000 */
  545. public const int SQLITE_OPEN_READONLY = 0x00000001;
  546. public const int SQLITE_OPEN_READWRITE = 0x00000002;
  547. public const int SQLITE_OPEN_CREATE = 0x00000004;
  548. public const int SQLITE_OPEN_DELETEONCLOSE = 0x00000008;
  549. public const int SQLITE_OPEN_EXCLUSIVE = 0x00000010;
  550. public const int SQLITE_OPEN_AUTOPROXY = 0x00000020;
  551. public const int SQLITE_OPEN_URI = 0x00000040;
  552. public const int SQLITE_OPEN_MAIN_DB = 0x00000100;
  553. public const int SQLITE_OPEN_TEMP_DB = 0x00000200;
  554. public const int SQLITE_OPEN_TRANSIENT_DB = 0x00000400;
  555. public const int SQLITE_OPEN_MAIN_JOURNAL = 0x00000800;
  556. public const int SQLITE_OPEN_TEMP_JOURNAL = 0x00001000;
  557. public const int SQLITE_OPEN_SUBJOURNAL = 0x00002000;
  558. public const int SQLITE_OPEN_MASTER_JOURNAL = 0x00004000;
  559. public const int SQLITE_OPEN_NOMUTEX = 0x00008000;
  560. public const int SQLITE_OPEN_FULLMUTEX = 0x00010000;
  561. public const int SQLITE_OPEN_SHAREDCACHE = 0x00020000;
  562. public const int SQLITE_OPEN_PRIVATECACHE = 0x00040000;
  563. public const int SQLITE_OPEN_WAL = 0x00080000;
  564. /*
  565. ** CAPI3REF: Device Characteristics
  566. **
  567. ** The xDeviceCharacteristics method of the [sqlite3_io_methods]
  568. ** object returns an integer which is a vector of the these
  569. ** bit values expressing I/O characteristics of the mass storage
  570. ** device that holds the file that the [sqlite3_io_methods]
  571. ** refers to.
  572. **
  573. ** The SQLITE_IOCAP_ATOMIC property means that all writes of
  574. ** any size are atomic. The SQLITE_IOCAP_ATOMICnnn values
  575. ** mean that writes of blocks that are nnn bytes in size and
  576. ** are aligned to an address which is an integer multiple of
  577. ** nnn are atomic. The SQLITE_IOCAP_SAFE_APPEND value means
  578. ** that when data is appended to a file, the data is appended
  579. ** first then the size of the file is extended, never the other
  580. ** way around. The SQLITE_IOCAP_SEQUENTIAL property means that
  581. ** information is written to disk in the same order as calls
  582. ** to xWrite().
  583. */
  584. //#define SQLITE_IOCAP_ATOMIC 0x00000001
  585. //#define SQLITE_IOCAP_ATOMIC512 0x00000002
  586. //#define SQLITE_IOCAP_ATOMIC1K 0x00000004
  587. //#define SQLITE_IOCAP_ATOMIC2K 0x00000008
  588. //#define SQLITE_IOCAP_ATOMIC4K 0x00000010
  589. //#define SQLITE_IOCAP_ATOMIC8K 0x00000020
  590. //#define SQLITE_IOCAP_ATOMIC16K 0x00000040
  591. //#define SQLITE_IOCAP_ATOMIC32K 0x00000080
  592. //#define SQLITE_IOCAP_ATOMIC64K 0x00000100
  593. //#define SQLITE_IOCAP_SAFE_APPEND 0x00000200
  594. //#define SQLITE_IOCAP_SEQUENTIAL 0x00000400
  595. //#define SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN 0x00000800
  596. const int SQLITE_IOCAP_ATOMIC = 0x00000001;
  597. const int SQLITE_IOCAP_ATOMIC512 = 0x00000002;
  598. const int SQLITE_IOCAP_ATOMIC1K = 0x00000004;
  599. const int SQLITE_IOCAP_ATOMIC2K = 0x00000008;
  600. const int SQLITE_IOCAP_ATOMIC4K = 0x00000010;
  601. const int SQLITE_IOCAP_ATOMIC8K = 0x00000020;
  602. const int SQLITE_IOCAP_ATOMIC16K = 0x00000040;
  603. const int SQLITE_IOCAP_ATOMIC32K = 0x00000080;
  604. const int SQLITE_IOCAP_ATOMIC64K = 0x00000100;
  605. const int SQLITE_IOCAP_SAFE_APPEND = 0x00000200;
  606. const int SQLITE_IOCAP_SEQUENTIAL = 0x00000400;
  607. const int SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN = 0x00000800;
  608. /*
  609. ** CAPI3REF: File Locking Levels
  610. **
  611. ** SQLite uses one of these integer values as the second
  612. ** argument to calls it makes to the xLock() and xUnlock() methods
  613. ** of an [sqlite3_io_methods] object.
  614. */
  615. //#define SQLITE_LOCK_NONE 0
  616. //#define SQLITE_LOCK_SHARED 1
  617. //#define SQLITE_LOCK_RESERVED 2
  618. //#define SQLITE_LOCK_PENDING 3
  619. //#define SQLITE_LOCK_EXCLUSIVE 4
  620. const int SQLITE_LOCK_NONE = 0;
  621. const int SQLITE_LOCK_SHARED = 1;
  622. const int SQLITE_LOCK_RESERVED = 2;
  623. const int SQLITE_LOCK_PENDING = 3;
  624. const int SQLITE_LOCK_EXCLUSIVE = 4;
  625. /*
  626. ** CAPI3REF: Synchronization Type Flags
  627. **
  628. ** When SQLite invokes the xSync() method of an
  629. ** [sqlite3_io_methods] object it uses a combination of
  630. ** these integer values as the second argument.
  631. **
  632. ** When the SQLITE_SYNC_DATAONLY flag is used, it means that the
  633. ** sync operation only needs to flush data to mass storage. Inode
  634. ** information need not be flushed. If the lower four bits of the flag
  635. ** equal SQLITE_SYNC_NORMAL, that means to use normal fsync() semantics.
  636. ** If the lower four bits equal SQLITE_SYNC_FULL, that means
  637. ** to use Mac OS X style fullsync instead of fsync().
  638. **
  639. ** Do not confuse the SQLITE_SYNC_NORMAL and SQLITE_SYNC_FULL flags
  640. ** with the [PRAGMA synchronous]=NORMAL and [PRAGMA synchronous]=FULL
  641. ** settings. The [synchronous pragma] determines when calls to the
  642. ** xSync VFS method occur and applies uniformly across all platforms.
  643. ** The SQLITE_SYNC_NORMAL and SQLITE_SYNC_FULL flags determine how
  644. ** energetic or rigorous or forceful the sync operations are and
  645. ** only make a difference on Mac OSX for the default SQLite code.
  646. ** (Third-party VFS implementations might also make the distinction
  647. ** between SQLITE_SYNC_NORMAL and SQLITE_SYNC_FULL, but among the
  648. ** operating systems natively supported by SQLite, only Mac OSX
  649. ** cares about the difference.)
  650. */
  651. //#define SQLITE_SYNC_NORMAL 0x00002
  652. //#define SQLITE_SYNC_FULL 0x00003
  653. //#define SQLITE_SYNC_DATAONLY 0x00010
  654. const int SQLITE_SYNC_NORMAL = 0x00002;
  655. const int SQLITE_SYNC_FULL = 0x00003;
  656. const int SQLITE_SYNC_DATAONLY = 0x00010;
  657. /*
  658. ** CAPI3REF: OS Interface Open File Handle
  659. **
  660. ** An [sqlite3_file] object represents an open file in the
  661. ** [sqlite3_vfs | OS interface layer]. Individual OS interface
  662. ** implementations will
  663. ** want to subclass this object by appending additional fields
  664. ** for their own use. The pMethods entry is a pointer to an
  665. ** [sqlite3_io_methods] object that defines methods for performing
  666. ** I/O operations on the open file.
  667. */
  668. //typedef struct sqlite3_file sqlite3_file;
  669. //struct sqlite3_file {
  670. // const struct sqlite3_io_methods *pMethods; /* Methods for an open file */
  671. //};
  672. public partial class sqlite3_file
  673. {
  674. public sqlite3_io_methods pMethods;/* Must be first */
  675. }
  676. /*
  677. ** CAPI3REF: OS Interface File Virtual Methods Object
  678. **
  679. ** Every file opened by the [sqlite3_vfs.xOpen] method populates an
  680. ** [sqlite3_file] object (or, more commonly, a subclass of the
  681. ** [sqlite3_file] object) with a pointer to an instance of this object.
  682. ** This object defines the methods used to perform various operations
  683. ** against the open file represented by the [sqlite3_file] object.
  684. **
  685. ** If the [sqlite3_vfs.xOpen] method sets the sqlite3_file.pMethods element
  686. ** to a non-NULL pointer, then the sqlite3_io_methods.xClose method
  687. ** may be invoked even if the [sqlite3_vfs.xOpen] reported that it failed. The
  688. ** only way to prevent a call to xClose following a failed [sqlite3_vfs.xOpen]
  689. ** is for the [sqlite3_vfs.xOpen] to set the sqlite3_file.pMethods element
  690. ** to NULL.
  691. **
  692. ** The flags argument to xSync may be one of [SQLITE_SYNC_NORMAL] or
  693. ** [SQLITE_SYNC_FULL]. The first choice is the normal fsync().
  694. ** The second choice is a Mac OS X style fullsync. The [SQLITE_SYNC_DATAONLY]
  695. ** flag may be ORed in to indicate that only the data of the file
  696. ** and not its inode needs to be synced.
  697. **
  698. ** The integer values to xLock() and xUnlock() are one of
  699. ** <ul>
  700. ** <li> [SQLITE_LOCK_NONE],
  701. ** <li> [SQLITE_LOCK_SHARED],
  702. ** <li> [SQLITE_LOCK_RESERVED],
  703. ** <li> [SQLITE_LOCK_PENDING], or
  704. ** <li> [SQLITE_LOCK_EXCLUSIVE].
  705. ** </ul>
  706. ** xLock() increases the lock. xUnlock() decreases the lock.
  707. ** The xCheckReservedLock() method checks whether any database connection,
  708. ** either in this process or in some other process, is holding a RESERVED,
  709. ** PENDING, or EXCLUSIVE lock on the file. It returns true
  710. ** if such a lock exists and false otherwise.
  711. **
  712. ** The xFileControl() method is a generic interface that allows custom
  713. ** VFS implementations to directly control an open file using the
  714. ** [sqlite3_file_control()] interface. The second "op" argument is an
  715. ** integer opcode. The third argument is a generic pointer intended to
  716. ** point to a structure that may contain arguments or space in which to
  717. ** write return values. Potential uses for xFileControl() might be
  718. ** functions to enable blocking locks with timeouts, to change the
  719. ** locking strategy (for example to use dot-file locks), to inquire
  720. ** about the status of a lock, or to break stale locks. The SQLite
  721. ** core reserves all opcodes less than 100 for its own use.
  722. ** A [SQLITE_FCNTL_LOCKSTATE | list of opcodes] less than 100 is available.
  723. ** Applications that define a custom xFileControl method should use opcodes
  724. ** greater than 100 to avoid conflicts. VFS implementations should
  725. ** return [SQLITE_NOTFOUND] for file control opcodes that they do not
  726. ** recognize.
  727. **
  728. ** The xSectorSize() method returns the sector size of the
  729. ** device that underlies the file. The sector size is the
  730. ** minimum write that can be performed without disturbing
  731. ** other bytes in the file. The xDeviceCharacteristics()
  732. ** method returns a bit vector describing behaviors of the
  733. ** underlying device:
  734. **
  735. ** <ul>
  736. ** <li> [SQLITE_IOCAP_ATOMIC]
  737. ** <li> [SQLITE_IOCAP_ATOMIC512]
  738. ** <li> [SQLITE_IOCAP_ATOMIC1K]
  739. ** <li> [SQLITE_IOCAP_ATOMIC2K]
  740. ** <li> [SQLITE_IOCAP_ATOMIC4K]
  741. ** <li> [SQLITE_IOCAP_ATOMIC8K]
  742. ** <li> [SQLITE_IOCAP_ATOMIC16K]
  743. ** <li> [SQLITE_IOCAP_ATOMIC32K]
  744. ** <li> [SQLITE_IOCAP_ATOMIC64K]
  745. ** <li> [SQLITE_IOCAP_SAFE_APPEND]
  746. ** <li> [SQLITE_IOCAP_SEQUENTIAL]
  747. ** </ul>
  748. **
  749. ** The SQLITE_IOCAP_ATOMIC property means that all writes of
  750. ** any size are atomic. The SQLITE_IOCAP_ATOMICnnn values
  751. ** mean that writes of blocks that are nnn bytes in size and
  752. ** are aligned to an address which is an integer multiple of
  753. ** nnn are atomic. The SQLITE_IOCAP_SAFE_APPEND value means
  754. ** that when data is appended to a file, the data is appended
  755. ** first then the size of the file is extended, never the other
  756. ** way around. The SQLITE_IOCAP_SEQUENTIAL property means that
  757. ** information is written to disk in the same order as calls
  758. ** to xWrite().
  759. **
  760. ** If xRead() returns SQLITE_IOERR_SHORT_READ it must also fill
  761. ** in the unread portions of the buffer with zeros. A VFS that
  762. ** fails to zero-fill short reads might seem to work. However,
  763. ** failure to zero-fill short reads will eventually lead to
  764. ** database corruption.
  765. */
  766. //typedef struct sqlite3_io_methods sqlite3_io_methods;
  767. //struct sqlite3_io_methods {
  768. // int iVersion;
  769. // int (*xClose)(sqlite3_file);
  770. // int (*xRead)(sqlite3_file*, void*, int iAmt, sqlite3_int64 iOfst);
  771. // int (*xWrite)(sqlite3_file*, const void*, int iAmt, sqlite3_int64 iOfst);
  772. // int (*xTruncate)(sqlite3_file*, sqlite3_int64 size);
  773. // int (*xSync)(sqlite3_file*, int flags);
  774. // int (*xFileSize)(sqlite3_file*, sqlite3_int64 *pSize);
  775. // int (*xLock)(sqlite3_file*, int);
  776. // int (*xUnlock)(sqlite3_file*, int);
  777. // int (*xCheckReservedLock)(sqlite3_file*, int *pResOut);
  778. // int (*xFileControl)(sqlite3_file*, int op, object *pArg);
  779. // int (*xSectorSize)(sqlite3_file);
  780. // int (*xDeviceCharacteristics)(sqlite3_file);
  781. // /* Methods above are valid for version 1 */
  782. // int (*xShmMap)(sqlite3_file*, int iPg, int pgsz, int, object volatile*);
  783. // int (*xShmLock)(sqlite3_file*, int offset, int n, int flags);
  784. // void (*xShmBarrier)(sqlite3_file);
  785. // int (*xShmUnmap)(sqlite3_file*, int deleteFlag);
  786. // /* Methods above are valid for version 2 */
  787. // /* Additional methods may be added in future releases */
  788. //};
  789. public class sqlite3_io_methods
  790. {
  791. public int iVersion;
  792. public dxClose xClose;
  793. public dxRead xRead;
  794. public dxWrite xWrite;
  795. public dxTruncate xTruncate;
  796. public dxSync xSync;
  797. public dxFileSize xFileSize;
  798. public dxLock xLock;
  799. public dxUnlock xUnlock;
  800. public dxCheckReservedLock xCheckReservedLock;
  801. public dxFileControl xFileControl;
  802. public dxSectorSize xSectorSize;
  803. public dxDeviceCharacteristics xDeviceCharacteristics;
  804. public dxShmMap xShmMap;//int (*xShmMap)(sqlite3_file*, int iPg, int pgsz, int, object volatile*);
  805. public dxShmLock xShmLock;//int (*xShmLock)(sqlite3_file*, int offset, int n, int flags);
  806. public dxShmBarrier xShmBarrier;//void (*xShmBarrier)(sqlite3_file);
  807. public dxShmUnmap xShmUnmap;//int (*xShmUnmap)(sqlite3_file*, int deleteFlag);
  808. /* Additional methods may be added in future releases */
  809. public sqlite3_io_methods( int iVersion,
  810. dxClose xClose,
  811. dxRead xRead,
  812. dxWrite xWrite,
  813. dxTruncate xTruncate,
  814. dxSync xSync,
  815. dxFileSize xFileSize,
  816. dxLock xLock,
  817. dxUnlock xUnlock,
  818. dxCheckReservedLock xCheckReservedLock,
  819. dxFileControl xFileControl,
  820. dxSectorSize xSectorSize,
  821. dxDeviceCharacteristics xDeviceCharacteristics,
  822. dxShmMap xShmMap,
  823. dxShmLock xShmLock,
  824. dxShmBarrier xShmBarrier,
  825. dxShmUnmap xShmUnmap
  826. )
  827. {
  828. this.iVersion = iVersion;
  829. this.xClose = xClose;
  830. this.xRead = xRead;
  831. this.xWrite = xWrite;
  832. this.xTruncate = xTruncate;
  833. this.xSync = xSync;
  834. this.xFileSize = xFileSize;
  835. this.xLock = xLock;
  836. this.xUnlock = xUnlock;
  837. this.xCheckReservedLock = xCheckReservedLock;
  838. this.xFileControl = xFileControl;
  839. this.xSectorSize = xSectorSize;
  840. this.xDeviceCharacteristics = xDeviceCharacteristics;
  841. this.xShmMap = xShmMap;
  842. this.xShmLock = xShmLock;
  843. this.xShmBarrier = xShmBarrier;
  844. this.xShmUnmap = xShmUnmap;
  845. }
  846. }
  847. /*
  848. ** CAPI3REF: Standard File Control Opcodes
  849. **
  850. ** These integer constants are opcodes for the xFileControl method
  851. ** of the [sqlite3_io_methods] object and for the [sqlite3_file_control()]
  852. ** interface.
  853. **
  854. ** The [SQLITE_FCNTL_LOCKSTATE] opcode is used for debugging. This
  855. ** opcode causes the xFileControl method to write the current state of
  856. ** the lock (one of [SQLITE_LOCK_NONE], [SQLITE_LOCK_SHARED],
  857. ** [SQLITE_LOCK_RESERVED], [SQLITE_LOCK_PENDING], or [SQLITE_LOCK_EXCLUSIVE])
  858. ** into an integer that the pArg argument points to. This capability
  859. ** is used during testing and only needs to be supported when SQLITE_TEST
  860. ** is defined.
  861. **
  862. ** The [SQLITE_FCNTL_SIZE_HINT] opcode is used by SQLite to give the VFS
  863. ** layer a hint of how large the database file will grow to be during the
  864. ** current transaction. This hint is not guaranteed to be accurate but it
  865. ** is often close. The underlying VFS might choose to preallocate database
  866. ** file space based on this hint in order to help writes to the database
  867. ** file run faster.
  868. **
  869. ** The [SQLITE_FCNTL_CHUNK_SIZE] opcode is used to request that the VFS
  870. ** extends and truncates the database file in chunks of a size specified
  871. ** by the user. The fourth argument to [sqlite3_file_control()] should
  872. ** point to an integer (type int) containing the new chunk-size to use
  873. ** for the nominated database. Allocating database file space in large
  874. ** chunks (say 1MB at a time), may reduce file-system fragmentation and
  875. ** improve performance on some systems.
  876. **
  877. ** The [SQLITE_FCNTL_FILE_POINTER] opcode is used to obtain a pointer
  878. ** to the [sqlite3_file] object associated with a particular database
  879. ** connection. See the [sqlite3_file_control()] documentation for
  880. ** additional information.
  881. **
  882. ** ^(The [SQLITE_FCNTL_SYNC_OMITTED] opcode is generated internally by
  883. ** SQLite and sent to all VFSes in place of a call to the xSync method
  884. ** when the database connection has [PRAGMA synchronous] set to OFF.)^
  885. ** Some specialized VFSes need this signal in order to operate correctly
  886. ** when [PRAGMA synchronous | PRAGMA synchronous=OFF] is set, but most
  887. ** VFSes do not need this signal and should silently ignore this opcode.
  888. ** Applications should not call [sqlite3_file_control()] with this
  889. ** opcode as doing so may disrupt the operation of the specialized VFSes
  890. ** that do require it.
  891. */
  892. //#define SQLITE_FCNTL_LOCKSTATE 1
  893. //#define SQLITE_GET_LOCKPROXYFILE 2
  894. //#define SQLITE_SET_LOCKPROXYFILE 3
  895. //#define SQLITE_LAST_ERRNO 4
  896. //#define SQLITE_FCNTL_SIZE_HINT 5
  897. //#define SQLITE_FCNTL_CHUNK_SIZE 6
  898. //#define SQLITE_FCNTL_FILE_POINTER 7
  899. //#define SQLITE_FCNTL_SYNC_OMITTED 8
  900. const int SQLITE_FCNTL_LOCKSTATE = 1;
  901. const int SQLITE_GET_LOCKPROXYFILE = 2;
  902. const int SQLITE_SET_LOCKPROXYFILE = 3;
  903. const int SQLITE_LAST_ERRNO = 4;
  904. const int SQLITE_FCNTL_SIZE_HINT = 5;
  905. const int SQLITE_FCNTL_CHUNK_SIZE = 6;
  906. const int SQLITE_FCNTL_FILE_POINTER = 7;
  907. const int SQLITE_FCNTL_SYNC_OMITTED = 8;
  908. /*
  909. ** CAPI3REF: Mutex Handle
  910. **
  911. ** The mutex module within SQLite defines [sqlite3_mutex] to be an
  912. ** abstract type for a mutex object. The SQLite core never looks
  913. ** at the internal representation of an [sqlite3_mutex]. It only
  914. ** deals with pointers to the [sqlite3_mutex] object.
  915. **
  916. ** Mutexes are created using [sqlite3_mutex_alloc()].
  917. */
  918. //typedef struct sqlite3_mutex sqlite3_mutex;
  919. /*
  920. ** CAPI3REF: OS Interface Object
  921. **
  922. ** An instance of the sqlite3_vfs object defines the interface between
  923. ** the SQLite core and the underlying operating system. The "vfs"
  924. ** in the name of the object stands for "virtual file system". See
  925. ** the [VFS | VFS documentation] for further information.
  926. **
  927. ** The value of the iVersion field is initially 1 but may be larger in
  928. ** future versions of SQLite. Additional fields may be appended to this
  929. ** object when the iVersion value is increased. Note that the structure
  930. ** of the sqlite3_vfs object changes in the transaction between
  931. ** SQLite version 3.5.9 and 3.6.0 and yet the iVersion field was not
  932. ** modified.
  933. **
  934. ** The szOsFile field is the size of the subclassed [sqlite3_file]
  935. ** structure used by this VFS. mxPathname is the maximum length of
  936. ** a pathname in this VFS.
  937. **
  938. ** Registered sqlite3_vfs objects are kept on a linked list formed by
  939. ** the pNext pointer. The [sqlite3_vfs_register()]
  940. ** and [sqlite3_vfs_unregister()] interfaces manage this list
  941. ** in a thread-safe way. The [sqlite3_vfs_find()] interface
  942. ** searches the list. Neither the application code nor the VFS
  943. ** implementation should use the pNext pointer.
  944. **
  945. ** The pNext field is the only field in the sqlite3_vfs
  946. ** structure that SQLite will ever modify. SQLite will only access
  947. ** or modify this field while holding a particular static mutex.
  948. ** The application should never modify anything within the sqlite3_vfs
  949. ** object once the object has been registered.
  950. **
  951. ** The zName field holds the name of the VFS module. The name must
  952. ** be unique across all VFS modules.
  953. **
  954. ** [[sqlite3_vfs.xOpen]
  955. ** ^SQLite guarantees that the zFilename parameter to xOpen
  956. ** is either a NULL pointer or string obtained
  957. ** from xFullPathname() with an optional suffix added.
  958. ** ^If a suffix is added to the zFilename parameter, it will
  959. ** consist of a single "-" character followed by no more than
  960. ** 10 alphanumeric and/or "-" characters.
  961. ** ^SQLite further guarantees that
  962. ** the string will be valid and unchanged until xClose() is
  963. ** called. Because of the previous sentence,
  964. ** the [sqlite3_file] can safely store a pointer to the
  965. ** filename if it needs to remember the filename for some reason.
  966. ** If the zFilename parameter to xOpen is a NULL pointer then xOpen
  967. ** must invent its own temporary name for the file. ^Whenever the
  968. ** xFilename parameter is NULL it will also be the case that the
  969. ** flags parameter will include [SQLITE_OPEN_DELETEONCLOSE].
  970. **
  971. ** The flags argument to xOpen() includes all bits set in
  972. ** the flags argument to [sqlite3_open_v2()]. Or if [sqlite3_open()]
  973. ** or [sqlite3_open16()] is used, then flags includes at least
  974. ** [SQLITE_OPEN_READWRITE] | [SQLITE_OPEN_CREATE].
  975. ** If xOpen() opens a file read-only then it sets *pOutFlags to
  976. ** include [SQLITE_OPEN_READONLY]. Other bits in *pOutFlags may be set.
  977. **
  978. ** ^(SQLite will also add one of the following flags to the xOpen()
  979. ** call, depending on the object being opened:
  980. **
  981. ** <ul>
  982. ** <li> [SQLITE_OPEN_MAIN_DB]
  983. ** <li> [SQLITE_OPEN_MAIN_JOURNAL]
  984. ** <li> [SQLITE_OPEN_TEMP_DB]
  985. ** <li> [SQLITE_OPEN_TEMP_JOURNAL]
  986. ** <li> [SQLITE_OPEN_TRANSIENT_DB]
  987. ** <li> [SQLITE_OPEN_SUBJOURNAL]
  988. ** <li> [SQLITE_OPEN_MASTER_JOURNAL]
  989. ** <li> [SQLITE_OPEN_WAL]
  990. ** </ul>)^
  991. **
  992. ** The file I/O implementation can use the object type flags to
  993. ** change the way it deals with files. For example, an application
  994. ** that does not care about crash recovery or rollback might make
  995. ** the open of a journal file a no-op. Writes to this journal would
  996. ** also be no-ops, and any attempt to read the journal would return
  997. ** SQLITE_IOERR. Or the implementation might recognize that a database
  998. ** file will be doing page-aligned sector reads and writes in a random
  999. ** order and set up its I/O subsystem accordingly.
  1000. **
  1001. ** SQLite might also add one of the following flags to the xOpen method:
  1002. **
  1003. ** <ul>
  1004. ** <li> [SQLITE_OPEN_DELETEONCLOSE]
  1005. ** <li> [SQLITE_OPEN_EXCLUSIVE]
  1006. ** </ul>
  1007. **
  1008. ** The [SQLITE_OPEN_DELETEONCLOSE] flag means the file should be
  1009. ** deleted when it is closed. ^The [SQLITE_OPEN_DELETEONCLOSE]
  1010. ** will be set for TEMP databases and their journals, transient
  1011. ** databases, and subjournals.
  1012. **
  1013. ** ^The [SQLITE_OPEN_EXCLUSIVE] flag is always used in conjunction
  1014. ** with the [SQLITE_OPEN_CREATE] flag, which are both directly
  1015. ** analogous to the O_EXCL and O_CREAT flags of the POSIX open()
  1016. ** API. The SQLITE_OPEN_EXCLUSIVE flag, when paired with the
  1017. ** SQLITE_OPEN_CREATE, is used to indicate that file should always
  1018. ** be created, and that it is an error if it already exists.
  1019. ** It is <i>not</i> used to indicate the file should be opened
  1020. ** for exclusive access.
  1021. **
  1022. ** ^At least szOsFile bytes of memory are allocated by SQLite
  1023. ** to hold the [sqlite3_file] structure passed as the third
  1024. ** argument to xOpen. The xOpen method does not have to
  1025. ** allocate the structure; it should just fill it in. Note that
  1026. ** the xOpen method must set the sqlite3_file.pMethods to either
  1027. ** a valid [sqlite3_io_methods] object or to NULL. xOpen must do
  1028. ** this even if the open fails. SQLite expects that the sqlite3_file.pMethods
  1029. ** element will be valid after xOpen returns regardless of the success
  1030. ** or failure of the xOpen call.
  1031. **
  1032. ** [[sqlite3_vfs.xAccess]
  1033. ** ^The flags argument to xAccess() may be [SQLITE_ACCESS_EXISTS]
  1034. ** to test for the existence of a file, or [SQLITE_ACCESS_READWRITE] to
  1035. ** test whether a file is readable and writable, or [SQLITE_ACCESS_READ]
  1036. ** to test whether a file is at least readable. The file can be a
  1037. ** directory.
  1038. **
  1039. ** ^SQLite will always allocate at least mxPathname+1 bytes for the
  1040. ** output buffer xFullPathname. The exact size of the output buffer
  1041. ** is also passed as a parameter to both methods. If the output buffer
  1042. ** is not large enough, [SQLITE_CANTOPEN] should be returned. Since this is
  1043. ** handled as a fatal error by SQLite, vfs implementations should endeavor
  1044. ** to prevent this by setting mxPathname to a sufficiently large value.
  1045. **
  1046. ** The xRandomness(), xSleep(), xCurrentTime(), and xCurrentTimeInt64()
  1047. ** interfaces are not strictly a part of the filesystem, but they are
  1048. ** included in the VFS structure for completeness.
  1049. ** The xRandomness() function attempts to return nBytes bytes
  1050. ** of good-quality randomness into zOut. The return value is
  1051. ** the actual number of bytes of randomness obtained.
  1052. ** The xSleep() method causes the calling thread to sleep for at
  1053. ** least the number of microseconds given. ^The xCurrentTime()
  1054. ** method returns a Julian Day Number for the current date and time as
  1055. ** a floating point value.
  1056. ** ^The xCurrentTimeInt64() method returns, as an integer, the Julian
  1057. ** Day Number multiplied by 86400000 (the number of milliseconds in
  1058. ** a 24-hour day).
  1059. ** ^SQLite will use the xCurrentTimeInt64() method to get the current
  1060. ** date and time if that method is available (if iVersion is 2 or
  1061. ** greater and the function pointer is not NULL) and will fall back
  1062. ** to xCurrentTime() if xCurrentTimeInt64() is unavailable.
  1063. **
  1064. ** ^The xSetSystemCall(), xGetSystemCall(), and xNestSystemCall() interfaces
  1065. ** are not used by the SQLite core. These optional interfaces are provided
  1066. ** by some VFSes to facilitate testing of the VFS code. By overriding
  1067. ** system calls with functions under its control, a test program can
  1068. ** simulate faults and error conditions that would otherwise be difficult
  1069. ** or impossible to induce. The set of system calls that can be overridden
  1070. ** varies from one VFS to another, and from one version of the same VFS to the
  1071. ** next. Applications that use these interfaces must be prepared for any
  1072. ** or all of these interfaces to be NULL or for their behavior to change
  1073. ** from one release to the next. Applications must not attempt to access
  1074. ** any of these methods if the iVersion of the VFS is less than 3.
  1075. */
  1076. //typedef struct sqlite3_vfs sqlite3_vfs;
  1077. //typedef void (*sqlite3_syscall_ptr)(void);
  1078. //struct sqlite3_vfs {
  1079. // int iVersion; /* Structure version number (currently 3) */
  1080. // int szOsFile; /* Size of subclassed sqlite3_file */
  1081. // int mxPathname; /* Maximum file pathname length */
  1082. // sqlite3_vfs *pNext; /* Next registered VFS */
  1083. // string zName; /* Name of this virtual file system */
  1084. // void *pAppData; /* Pointer to application-specific data */
  1085. // int (*xOpen)(sqlite3_vfs*, string zName, sqlite3_file*,
  1086. // int flags, int *pOutFlags);
  1087. // int (*xDelete)(sqlite3_vfs*, string zName, int syncDir);
  1088. // int (*xAccess)(sqlite3_vfs*, string zName, int flags, int *pResOut);
  1089. // int (*xFullPathname)(sqlite3_vfs*, string zName, int nOut, string zOut);
  1090. // void *(*xDlOpen)(sqlite3_vfs*, string zFilename);
  1091. // void (*xDlError)(sqlite3_vfs*, int nByte, string zErrMsg);
  1092. // void (*(*xDlSym)(sqlite3_vfs*,void*, string zSymbol))(void);
  1093. // void (*xDlClose)(sqlite3_vfs*, void);
  1094. // int (*xRandomness)(sqlite3_vfs*, int nByte, string zOut);
  1095. // int (*xSleep)(sqlite3_vfs*, int microseconds);
  1096. // int (*xCurrentTime)(sqlite3_vfs*, double);
  1097. // int (*xGetLastError)(sqlite3_vfs*, int, char );
  1098. // /*
  1099. // ** The methods above are in version 1 of the sqlite_vfs object
  1100. // ** definition. Those that follow are added in version 2 or later
  1101. // */
  1102. // int (*xCurrentTimeInt64)(sqlite3_vfs*, sqlite3_int64);
  1103. // /*
  1104. // ** The methods above are in versions 1 and 2 of the sqlite_vfs object.
  1105. // ** New fields may be appended in figure versions. The iVersion
  1106. // ** value will increment whenever this happens.
  1107. // */
  1108. //};
  1109. public class sqlite3_vfs
  1110. {
  1111. public int iVersion; /* Structure version number (currently 3) */
  1112. public int szOsFile; /* Size of subclassed sqlite3_file */
  1113. public int mxPathname; /* Maximum file pathname length */
  1114. public sqlite3_vfs pNext; /* Next registered VFS */
  1115. public string zName; /* Name of this virtual file system */
  1116. public object pAppData; /* Pointer to application-specific data */
  1117. public dxOpen xOpen;
  1118. public dxDelete xDelete;
  1119. public dxAccess xAccess;
  1120. public dxFullPathname xFullPathname;
  1121. public dxDlOpen xDlOpen;
  1122. public dxDlError xDlError;
  1123. public dxDlSym xDlSym;
  1124. public dxDlClose xDlClose;
  1125. public dxRandomness xRandomness;
  1126. public dxSleep xSleep;
  1127. public dxCurrentTime xCurrentTime;
  1128. public dxGetLastError xGetLastError;
  1129. /*
  1130. ** The methods above are in version 1 of the sqlite_vfs object
  1131. ** definition. Those that follow are added in version 2 or later
  1132. */
  1133. public dxCurrentTimeInt64 xCurrentTimeInt64;
  1134. /*
  1135. ** The methods above are in versions 1 and 2 of the sqlite_vfs object.
  1136. ** Those below are for version 3 and greater.
  1137. */
  1138. //int (*xSetSystemCall)(sqlite3_vfs*, string zName, sqlite3_syscall_ptr);
  1139. public dxSetSystemCall xSetSystemCall;
  1140. //sqlite3_syscall_ptr (*xGetSystemCall)(sqlite3_vfs*, string zName);
  1141. public dxGetSystemCall xGetSystemCall;
  1142. //string (*xNextSystemCall)(sqlite3_vfs*, string zName);
  1143. public dxNextSystemCall xNextSystemCall;
  1144. /*
  1145. ** The methods above are in versions 1 through 3 of the sqlite_vfs object.
  1146. ** New fields may be appended in figure versions. The iVersion
  1147. ** value will increment whenever this happens.
  1148. */
  1149. /* New fields may be appended in figure versions. The iVersion
  1150. ** value will increment whenever this happens. */
  1151. public sqlite3_vfs()
  1152. {
  1153. }
  1154. public sqlite3_vfs( int iVersion,
  1155. int szOsFile,
  1156. int mxPathname,
  1157. sqlite3_vfs pNext,
  1158. string zName,
  1159. object pAppData,
  1160. dxOpen xOpen,
  1161. dxDelete xDelete,
  1162. dxAccess xAccess,
  1163. dxFullPathname xFullPathname,
  1164. dxDlOpen xDlOpen,
  1165. dxDlError xDlError,
  1166. dxDlSym xDlSym,
  1167. dxDlClose xDlClose,
  1168. dxRandomness xRandomness,
  1169. dxSleep xSleep,
  1170. dxCurrentTime xCurrentTime,
  1171. dxGetLastError xGetLastError,
  1172. dxCurrentTimeInt64 xCurrentTimeInt64,
  1173. dxSetSystemCall xSetSystemCall,
  1174. dxGetSystemCall xGetSystemCall,
  1175. dxNextSystemCall xNextSystemCall)
  1176. {
  1177. this.iVersion = iVersion;
  1178. this.szOsFile = szOsFile;
  1179. this.mxPathname = mxPathname;
  1180. this.pNext = pNext;
  1181. this.zName = zName;
  1182. this.pAppData = pAppData;
  1183. this.xOpen = xOpen;
  1184. this.xDelete = xDelete;
  1185. this.xAccess = xAccess;
  1186. this.xFullPathname = xFullPathname;
  1187. this.xDlOpen = xDlOpen;
  1188. this.xDlError = xDlError;
  1189. this.xDlSym = xDlSym;
  1190. this.xDlClose = xDlClose;
  1191. this.xRandomness = xRandomness;
  1192. this.xSleep = xSleep;
  1193. this.xCurrentTime = xCurrentTime;
  1194. this.xGetLastError = xGetLastError;
  1195. this.xCurrentTimeInt64 = xCurrentTimeInt64;
  1196. }
  1197. public void CopyTo(sqlite3_vfs ct)
  1198. {
  1199. ct.iVersion = this.iVersion;
  1200. ct.szOsFile = this.szOsFile;
  1201. ct.mxPathname = this.mxPathname;
  1202. ct.pNext = this.pNext;
  1203. ct.zName = this.zName;
  1204. ct.pAppData = this.pAppData;
  1205. ct.xOpen = this.xOpen;
  1206. ct.xDelete = this.xDelete;
  1207. ct.xAccess = this.xAccess;
  1208. ct.xFullPathname = this.xFullPathname;
  1209. ct.xDlOpen = this.xDlOpen;
  1210. ct.xDlError = this.xDlError;
  1211. ct.xDlSym = this.xDlSym;
  1212. ct.xDlClose = this.xDlClose;
  1213. ct.xRandomness = this.xRandomness;
  1214. ct.xSleep = this.xSleep;
  1215. ct.xCurrentTime = this.xCurrentTime;
  1216. ct.xGetLastError = this.xGetLastError;
  1217. ct.xCurrentTimeInt64 = this.xCurrentTimeInt64;
  1218. }
  1219. }
  1220. /*
  1221. ** CAPI3REF: Flags for the xAccess VFS method
  1222. **
  1223. ** These integer constants can be used as the third parameter to
  1224. ** the xAccess method of an [sqlite3_vfs] object. They determine
  1225. ** what kind of permissions the xAccess method is looking for.
  1226. ** With SQLITE_ACCESS_EXISTS, the xAccess method
  1227. ** simply checks whether the file exists.
  1228. ** With SQLITE_ACCESS_READWRITE, the xAccess method
  1229. ** checks whether the named directory is both readable and writable
  1230. ** (in other words, if files can be added, removed, and renamed within
  1231. ** the directory).
  1232. ** The SQLITE_ACCESS_READWRITE constant is currently used only by the
  1233. ** [temp_store_directory pragma], though this could change in a future
  1234. ** release of SQLite.
  1235. ** With SQLITE_ACCESS_READ, the xAccess method
  1236. ** checks whether the file is readable. The SQLITE_ACCESS_READ constant is
  1237. ** currently unused, though it might be used in a future release of
  1238. ** SQLite.
  1239. */
  1240. //#define SQLITE_ACCESS_EXISTS 0
  1241. //#define SQLITE_ACCESS_READWRITE 1 /* Used by PRAGMA temp_store_directory */
  1242. //#define SQLITE_ACCESS_READ 2 /* Unused */
  1243. const int SQLITE_ACCESS_EXISTS = 0;
  1244. const int SQLITE_ACCESS_READWRITE = 1;
  1245. const int SQLITE_ACCESS_READ = 2;
  1246. /*
  1247. ** CAPI3REF: Flags for the xShmLock VFS method
  1248. **
  1249. ** These integer constants define the various locking operations
  1250. ** allowed by the xShmLock method of [sqlite3_io_methods]. The
  1251. ** following are the only legal combinations of flags to the
  1252. ** xShmLock method:
  1253. **
  1254. ** <ul>
  1255. ** <li> SQLITE_SHM_LOCK | SQLITE_SHM_SHARED
  1256. ** <li> SQLITE_SHM_LOCK | SQLITE_SHM_EXCLUSIVE
  1257. ** <li> SQLITE_SHM_UNLOCK | SQLITE_SHM_SHARED
  1258. ** <li> SQLITE_SHM_UNLOCK | SQLITE_SHM_EXCLUSIVE
  1259. ** </ul>
  1260. **
  1261. ** When unlocking, the same SHARED or EXCLUSIVE flag must be supplied as
  1262. ** was given no the corresponding lock.
  1263. **
  1264. ** The xShmLock method can transition between unlocked and SHARED or
  1265. ** between unlocked and EXCLUSIVE. It cannot transition between SHARED
  1266. ** and EXCLUSIVE.
  1267. */
  1268. //#define SQLITE_SHM_UNLOCK 1
  1269. //#define SQLITE_SHM_LOCK 2
  1270. //#define SQLITE_SHM_SHARED 4
  1271. //#define SQLITE_SHM_EXCLUSIVE 8
  1272. const int SQLITE_SHM_UNLOCK = 1;
  1273. const int SQLITE_SHM_LOCK = 2;
  1274. const int SQLITE_SHM_SHARED = 4;
  1275. const int SQLITE_SHM_EXCLUSIVE = 8;
  1276. /*
  1277. ** CAPI3REF: Maximum xShmLock index
  1278. **
  1279. ** The xShmLock method on [sqlite3_io_methods] may use values
  1280. ** between 0 and this upper bound as its "offset" argument.
  1281. ** The SQLite core will never attempt to acquire or release a
  1282. ** lock outside of this range
  1283. */
  1284. //#define SQLITE_SHM_NLOCK 8
  1285. const int SQLITE_SHM_NLOCK = 8;
  1286. /*
  1287. ** CAPI3REF: Initialize The SQLite Library
  1288. **
  1289. ** ^The sqlite3_initialize() routine initializes the
  1290. ** SQLite library. ^The sqlite3_shutdown() routine
  1291. ** deallocates any resources that were allocated by sqlite3_initialize().
  1292. ** These routines are designed to aid in process initialization and
  1293. ** shutdown on embedded systems. Workstation applications using
  1294. ** SQLite normally do not need to invoke either of these routines.
  1295. **
  1296. ** A call to sqlite3_initialize() is an "effective" call if it is
  1297. ** the first time sqlite3_initialize() is invoked during the lifetime of
  1298. ** the process, or if it is the first time sqlite3_initialize() is invoked
  1299. ** following a call to sqlite3_shutdown(). ^(Only an effective call
  1300. ** of sqlite3_initialize() does any initialization. All other calls
  1301. ** are harmless no-ops.)^
  1302. **
  1303. ** A call to sqlite3_shutdown() is an "effective" call if it is the first
  1304. ** call to sqlite3_shutdown() since the last sqlite3_initialize(). ^(Only
  1305. ** an effective call to sqlite3_shutdown() does any deinitialization.
  1306. ** All other valid calls to sqlite3_shutdown() are harmless no-ops.)^
  1307. **
  1308. ** The sqlite3_initialize() interface is threadsafe, but sqlite3_shutdown()
  1309. ** is not. The sqlite3_shutdown() interface must only be called from a
  1310. ** single thread. All open [database connections] must be closed and all
  1311. ** other SQLite resources must be deallocated prior to invoking
  1312. ** sqlite3_shutdown().
  1313. **
  1314. ** Among other things, ^sqlite3_initialize() will invoke
  1315. ** sqlite3_os_init(). Similarly, ^sqlite3_shutdown()
  1316. ** will invoke sqlite3_os_end().
  1317. **
  1318. ** ^The sqlite3_initialize() routine returns [SQLITE_OK] on success.
  1319. ** ^If for some reason, sqlite3_initialize() is unable to initialize
  1320. ** the library (perhaps it is unable to allocate a needed resource such
  1321. ** as a mutex) it returns an [error code] other than [SQLITE_OK].
  1322. **
  1323. ** ^The sqlite3_initialize() routine is called internally by many other
  1324. ** SQLite interfaces so that an application usually does not need to
  1325. ** invoke sqlite3_initialize() directly. For example, [sqlite3_open()]
  1326. ** calls sqlite3_initialize() so the SQLite library will be automatically
  1327. ** initialized when [sqlite3_open()] is called if it has not be initialized
  1328. ** already. ^However, if SQLite is compiled with the [SQLITE_OMIT_AUTOINIT]
  1329. ** compile-time option, then the automatic calls to sqlite3_initialize()
  1330. ** are omitted and the application must call sqlite3_initialize() directly
  1331. ** prior to using any other SQLite interface. For maximum portability,
  1332. ** it is recommended that applications always invoke sqlite3_initialize()
  1333. ** directly prior to using any other SQLite interface. Future releases
  1334. ** of SQLite may require this. In other words, the behavior exhibited
  1335. ** when SQLite is compiled with [SQLITE_OMIT_AUTOINIT] might become the
  1336. ** default behavior in some future release of SQLite.
  1337. **
  1338. ** The sqlite3_os_init() routine does operating-system specific
  1339. ** initialization of the SQLite library. The sqlite3_os_end()
  1340. ** routine undoes the effect of sqlite3_os_init(). Typical tasks
  1341. ** performed by these routines include allocation or deallocation
  1342. ** of static resources, initialization of global variables,
  1343. ** setting up a default [sqlite3_vfs] module, or setting up
  1344. ** a default configuration using [sqlite3_config()].
  1345. **
  1346. ** The application should never invoke either sqlite3_os_init()
  1347. ** or sqlite3_os_end() directly. The application should only invoke
  1348. ** sqlite3_initialize() and sqlite3_shutdown(). The sqlite3_os_init()
  1349. ** interface is called automatically by sqlite3_initialize() and
  1350. ** sqlite3_os_end() is called by sqlite3_shutdown(). Appropriate
  1351. ** implementations for sqlite3_os_init() and sqlite3_os_end()
  1352. ** are built into SQLite when it is compiled for Unix, Windows, or OS/2.
  1353. ** When [custom builds | built for other platforms]
  1354. ** (using the [SQLITE_OS_OTHER=1] compile-time
  1355. ** option) the application must supply a suitable implementation for
  1356. ** sqlite3_os_init() and sqlite3_os_end(). An application-supplied
  1357. ** implementation of sqlite3_os_init() or sqlite3_os_end()
  1358. ** must return [SQLITE_OK] on success and some other [error code] upon
  1359. ** failure.
  1360. */
  1361. //SQLITE_API int sqlite3_initialize(void);
  1362. //SQLITE_API int sqlite3_shutdown(void);
  1363. //SQLITE_API int sqlite3_os_init(void);
  1364. //SQLITE_API int sqlite3_os_end(void);
  1365. /*
  1366. ** CAPI3REF: Configuring The SQLite Library
  1367. **
  1368. ** The sqlite3_config() interface is used to make global configuration
  1369. ** changes to SQLite in order to tune SQLite to the specific needs of
  1370. ** the application. The default configuration is recommended for most
  1371. ** applications and so this routine is usually not necessary. It is
  1372. ** provided to support rare applications with unusual needs.
  1373. **
  1374. ** The sqlite3_config() interface is not threadsafe. The application
  1375. ** must insure that no other SQLite interfaces are invoked by other
  1376. ** threads while sqlite3_config() is running. Furthermore, sqlite3_config()
  1377. ** may only be invoked prior to library initialization using
  1378. ** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()].
  1379. ** ^If sqlite3_config() is called after [sqlite3_initialize()] and before
  1380. ** [sqlite3_shutdown()] then it will return SQLITE_MISUSE.
  1381. ** Note, however, that ^sqlite3_config() can be called as part of the
  1382. ** implementation of an application-defined [sqlite3_os_init()].
  1383. **
  1384. ** The first argument to sqlite3_config() is an integer
  1385. ** [configuration option] that determines
  1386. ** what property of SQLite is to be configured. Subsequent arguments
  1387. ** vary depending on the [configuration option]
  1388. ** in the first argument.
  1389. **
  1390. ** ^When a configuration option is set, sqlite3_config() returns [SQLITE_OK].
  1391. ** ^If the option is unknown or SQLite is unable to set the option
  1392. ** then this routine returns a non-zero [error code].
  1393. */
  1394. //SQLITE_API int sqlite3_config(int, ...);
  1395. /*
  1396. ** CAPI3REF: Configure database connections
  1397. **
  1398. ** The sqlite3_db_config() interface is used to make configuration
  1399. ** changes to a [database connection]. The interface is similar to
  1400. ** [sqlite3_config()] except that the changes apply to a single
  1401. ** [database connection] (specified in the first argument).
  1402. **
  1403. ** The second argument to sqlite3_db_config(D,V,...) is the
  1404. ** [SQLITE_DBCONFIG_LOOKASIDE | configuration verb] - an integer code
  1405. ** that indicates what aspect of the [database connection] is being configured.
  1406. ** Subsequent arguments vary depending on the configuration verb.
  1407. **
  1408. ** ^Calls to sqlite3_db_config() return SQLITE_OK if and only if
  1409. ** the call is considered successful.
  1410. */
  1411. //SQLITE_API int sqlite3_db_config(sqlite3*, int op, ...);
  1412. /*
  1413. ** CAPI3REF: Memory Allocation Routines
  1414. **
  1415. ** An instance of this object defines the interface between SQLite
  1416. ** and low-level memory allocation routines.
  1417. **
  1418. ** This object is used in only one place in the SQLite interface.
  1419. ** A pointer to an instance of this object is the argument to
  1420. ** [sqlite3_config()] when the configuration option is
  1421. ** [SQLITE_CONFIG_MALLOC] or [SQLITE_CONFIG_GETMALLOC].
  1422. ** By creating an instance of this object
  1423. ** and passing it to [sqlite3_config]([SQLITE_CONFIG_MALLOC])
  1424. ** during configuration, an application can specify an alternative
  1425. ** memory allocation subsystem for SQLite to use for all of its
  1426. ** dynamic memory needs.
  1427. **
  1428. ** Note that SQLite comes with several [built-in memory allocators]
  1429. ** that are perfectly adequate for the overwhelming majority of applications
  1430. ** and that this object is only useful to a tiny minority of applications
  1431. ** with specialized memory allocation requirements. This object is
  1432. ** also used during testing of SQLite in order to specify an alternative
  1433. ** memory allocator that simulates memory out-of-memory conditions in
  1434. ** order to verify that SQLite recovers gracefully from such
  1435. ** conditions.
  1436. **
  1437. ** The xMalloc and xFree methods must work like the
  1438. ** malloc() and free() functions from the standard C library.
  1439. ** The xRealloc method must work like realloc() from the standard C library
  1440. ** with the exception that if the second argument to xRealloc is zero,
  1441. ** xRealloc must be a no-op - it must not perform any allocation or
  1442. ** deallocation. ^SQLite guarantees that the second argument to
  1443. ** xRealloc is always a value returned by a prior call to xRoundup.
  1444. ** And so in cases where xRoundup always returns a positive number,
  1445. ** xRealloc can perform exactly as the standard library realloc() and
  1446. ** still be in compliance with this specification.
  1447. **
  1448. ** xSize should return the allocated size of a memory allocation
  1449. ** previously obtained from xMalloc or xRealloc. The allocated size
  1450. ** is always at least as big as the requested size but may be larger.
  1451. **
  1452. ** The xRoundup method returns what would be the allocated size of
  1453. ** a memory allocation given a particular requested size. Most memory
  1454. ** allocators round up memory allocations at least to the next multiple
  1455. ** of 8. Some allocators round up to a larger multiple or to a power of 2.
  1456. ** Every memory allocation request coming in through [sqlite3_malloc()]
  1457. ** or [sqlite3_realloc()] first calls xRoundup. If xRoundup returns 0,
  1458. ** that causes the corresponding memory allocation to fail.
  1459. **
  1460. ** The xInit method initializes the memory allocator. (For example,
  1461. ** it might allocate any require mutexes or initialize internal data
  1462. ** structures. The xShutdown method is invoked (indirectly) by
  1463. ** [sqlite3_shutdown()] and should deallocate any resources acquired
  1464. ** by xInit. The pAppData pointer is used as the only parameter to
  1465. ** xInit and xShutdown.
  1466. **
  1467. ** SQLite holds the [SQLITE_MUTEX_STATIC_MASTER] mutex when it invokes
  1468. ** the xInit method, so the xInit method need not be threadsafe. The
  1469. ** xShutdown method is only called from [sqlite3_shutdown()] so it does
  1470. ** not need to be threadsafe either. For all other methods, SQLite
  1471. ** holds the [SQLITE_MUTEX_STATIC_MEM] mutex as long as the
  1472. ** [SQLITE_CONFIG_MEMSTATUS] configuration option is turned on (which
  1473. ** it is by default) and so the methods are automatically serialized.
  1474. ** However, if [SQLITE_CONFIG_MEMSTATUS] is disabled, then the other
  1475. ** methods must be threadsafe or else make their own arrangements for
  1476. ** serialization.
  1477. **
  1478. ** SQLite will never invoke xInit() more than once without an intervening
  1479. ** call to xShutdown().
  1480. */
  1481. //typedef struct sqlite3_mem_methods sqlite3_mem_methods;
  1482. //struct sqlite3_mem_methods {
  1483. // void *(*xMalloc)(int); /* Memory allocation function */
  1484. // void (*xFree)(void); /* Free a prior allocation */
  1485. // void *(*xRealloc)(void*,int); /* Resize an allocation */
  1486. // int (*xSize)(void); /* Return the size of an allocation */
  1487. // int (*xRoundup)(int); /* Round up request size to allocation size */
  1488. // int (*xInit)(void); /* Initialize the memory allocator */
  1489. // void (*xShutdown)(void); /* Deinitialize the memory allocator */
  1490. // void *pAppData; /* Argument to xInit() and xShutdown() */
  1491. //};
  1492. public class sqlite3_mem_methods
  1493. {
  1494. public dxMalloc xMalloc; //void *(*xMalloc)(int); /* Memory allocation function */
  1495. public dxMallocInt xMallocInt; //void *(*xMalloc)(int); /* Memory allocation function */
  1496. public dxMallocMem xMallocMem; //void *(*xMalloc)(int); /* Memory allocation function */
  1497. public dxFree xFree; //void (*xFree)(void); /* Free a prior allocation */
  1498. public dxFreeInt xFreeInt; //void (*xFree)(void); /* Free a prior allocation */
  1499. public dxFreeMem xFreeMem; //void (*xFree)(void); /* Free a prior allocation */
  1500. public dxRealloc xRealloc; //void *(*xRealloc)(void*,int); /* Resize an allocation */
  1501. public dxSize xSize; //int (*xSize)(void); /* Return the size of an allocation */
  1502. public dxRoundup xRoundup; //int (*xRoundup)(int); /* Round up request size to allocation size */
  1503. public dxMemInit xInit; //int (*xInit)(void); /* Initialize the memory allocator */
  1504. public dxMemShutdown xShutdown; //void (*xShutdown)(void); /* Deinitialize the memory allocator */
  1505. public object pAppData; /* Argument to xInit() and xShutdown() */
  1506. public sqlite3_mem_methods()
  1507. {
  1508. }
  1509. public sqlite3_mem_methods(
  1510. dxMalloc xMalloc,
  1511. dxMallocInt xMallocInt,
  1512. dxMallocMem xMallocMem,
  1513. dxFree xFree,
  1514. dxFreeInt xFreeInt,
  1515. dxFreeMem xFreeMem,
  1516. dxRealloc xRealloc,
  1517. dxSize xSize,
  1518. dxRoundup xRoundup,
  1519. dxMemInit xInit,
  1520. dxMemShutdown xShutdown,
  1521. object pAppData
  1522. )
  1523. {
  1524. this.xMalloc = xMalloc;
  1525. this.xMallocInt = xMallocInt;
  1526. this.xMallocMem = xMallocMem;
  1527. this.xFree = xFree;
  1528. this.xFreeInt = xFreeInt;
  1529. this.xFreeMem = xFreeMem;
  1530. this.xRealloc = xRealloc;
  1531. this.xSize = xSize;
  1532. this.xRoundup = xRoundup;
  1533. this.xInit = xInit;
  1534. this.xShutdown = xShutdown;
  1535. this.pAppData = pAppData;
  1536. }
  1537. }
  1538. /*
  1539. ** CAPI3REF: Configuration Options
  1540. ** KEYWORDS: {configuration option}
  1541. **
  1542. ** These constants are the available integer configuration options that
  1543. ** can be passed as the first argument to the [sqlite3_config()] interface.
  1544. **
  1545. ** New configuration options may be added in future releases of SQLite.
  1546. ** Existing configuration options might be discontinued. Applications
  1547. ** should check the return code from [sqlite3_config()] to make sure that
  1548. ** the call worked. The [sqlite3_config()] interface will return a
  1549. ** non-zero [error code] if a discontinued or unsupported configuration option
  1550. ** is invoked.
  1551. **
  1552. ** <dl>
  1553. ** [[SQLITE_CONFIG_SINGLETHREAD]] <dt>SQLITE_CONFIG_SINGLETHREAD</dt>
  1554. ** <dd>There are no arguments to this option. ^This option sets the
  1555. ** [threading mode] to Single-thread. In other words, it disables
  1556. ** all mutexing and puts SQLite into a mode where it can only be used
  1557. ** by a single thread. ^If SQLite is compiled with
  1558. ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
  1559. ** it is not possible to change the [threading mode] from its default
  1560. ** value of Single-thread and so [sqlite3_config()] will return
  1561. ** [SQLITE_ERROR] if called with the SQLITE_CONFIG_SINGLETHREAD
  1562. ** configuration option.</dd>
  1563. **
  1564. ** [[SQLITE_CONFIG_MULTITHREAD]] <dt>SQLITE_CONFIG_MULTITHREAD</dt>
  1565. ** <dd>There are no arguments to this option. ^This option sets the
  1566. ** [threading mode] to Multi-thread. In other words, it disables
  1567. ** mutexing on [database connection] and [prepared statement] objects.
  1568. ** The application is responsible for serializing access to
  1569. ** [database connections] and [prepared statements]. But other mutexes
  1570. ** are enabled so that SQLite will be safe to use in a multi-threaded
  1571. ** environment as long as no two threads attempt to use the same
  1572. ** [database connection] at the same time. ^If SQLite is compiled with
  1573. ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
  1574. ** it is not possible to set the Multi-thread [threading mode] and
  1575. ** [sqlite3_config()] will return [SQLITE_ERROR] if called with the
  1576. ** SQLITE_CONFIG_MULTITHREAD configuration option.</dd>
  1577. **
  1578. ** [[SQLITE_CONFIG_SERIALIZED]] <dt>SQLITE_CONFIG_SERIALIZED</dt>
  1579. ** <dd>There are no arguments to this option. ^This option sets the
  1580. ** [threading mode] to Serialized. In other words, this option enables
  1581. ** all mutexes including the recursive
  1582. ** mutexes on [database connection] and [prepared statement] objects.
  1583. ** In this mode (which is the default when SQLite is compiled with
  1584. ** [SQLITE_THREADSAFE=1]) the SQLite library will itself serialize access
  1585. ** to [database connections] and [prepared statements] so that the
  1586. ** application is free to use the same [database connection] or the
  1587. ** same [prepared statement] in different threads at the same time.
  1588. ** ^If SQLite is compiled with
  1589. ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
  1590. ** it is not possible to set the Serialized [threading mode] and
  1591. ** [sqlite3_config()] will return [SQLITE_ERROR] if called with the
  1592. ** SQLITE_CONFIG_SERIALIZED configuration option.</dd>
  1593. **
  1594. ** [[SQLITE_CONFIG_MALLOC]] <dt>SQLITE_CONFIG_MALLOC</dt>
  1595. ** <dd> ^(This option takes a single argument which is a pointer to an
  1596. ** instance of the [sqlite3_mem_methods] structure. The argument specifies
  1597. ** alternative low-level memory allocation routines to be used in place of
  1598. ** the memory allocation routines built into SQLite.)^ ^SQLite makes
  1599. ** its own private copy of the content of the [sqlite3_mem_methods] structure
  1600. ** before the [sqlite3_config()] call returns.</dd>
  1601. **
  1602. ** [[SQLITE_CONFIG_GETMALLOC]] <dt>SQLITE_CONFIG_GETMALLOC</dt>
  1603. ** <dd> ^(This option takes a single argument which is a pointer to an
  1604. ** instance of the [sqlite3_mem_methods] structure. The [sqlite3_mem_methods]
  1605. ** structure is filled with the currently defined memory allocation routines.)^
  1606. ** This option can be used to overload the default memory allocation
  1607. ** routines with a wrapper that simulations memory allocation failure or
  1608. ** tracks memory usage, for example. </dd>
  1609. **
  1610. ** [[SQLITE_CONFIG_MEMSTATUS]] <dt>SQLITE_CONFIG_MEMSTATUS</dt>
  1611. ** <dd> ^This option takes single argument of type int, interpreted as a
  1612. ** boolean, which enables or disables the collection of memory allocation
  1613. ** statistics. ^(When memory allocation statistics are disabled, the
  1614. ** following SQLite interfaces become non-operational:
  1615. ** <ul>
  1616. ** <li> [sqlite3_memory_used()]
  1617. ** <li> [sqlite3_memory_highwater()]
  1618. ** <li> [sqlite3_soft_heap_limit64()]
  1619. ** <li> [sqlite3_status()]
  1620. ** </ul>)^
  1621. ** ^Memory allocation statistics are enabled by default unless SQLite is
  1622. ** compiled with [SQLITE_DEFAULT_MEMSTATUS]=0 in which case memory
  1623. ** allocation statistics are disabled by default.
  1624. ** </dd>
  1625. **
  1626. ** [[SQLITE_CONFIG_SCRATCH]] <dt>SQLITE_CONFIG_SCRATCH</dt>
  1627. ** <dd> ^This option specifies a static memory buffer that SQLite can use for
  1628. ** scratch memory. There are three arguments: A pointer an 8-byte
  1629. ** aligned memory buffer from which the scratch allocations will be
  1630. ** drawn, the size of each scratch allocation (sz),
  1631. ** and the maximum number of scratch allocations (N). The sz
  1632. ** argument must be a multiple of 16.
  1633. ** The first argument must be a pointer to an 8-byte aligned buffer
  1634. ** of at least sz*N bytes of memory.
  1635. ** ^SQLite will use no more than two scratch buffers per thread. So
  1636. ** N should be set to twice the expected maximum number of threads.
  1637. ** ^SQLite will never require a scratch buffer that is more than 6
  1638. ** times the database page size. ^If SQLite needs needs additional
  1639. ** scratch memory beyond what is provided by this configuration option, then
  1640. ** [sqlite3_malloc()] will be used to obtain the memory needed.</dd>
  1641. **
  1642. ** [[SQLITE_CONFIG_PAGECACHE]] <dt>SQLITE_CONFIG_PAGECACHE</dt>
  1643. ** <dd> ^This option specifies a static memory buffer that SQLite can use for
  1644. ** the database page cache with the default page cache implementation.
  1645. ** This configuration should not be used if an application-define page
  1646. ** cache implementation is loaded using the SQLITE_CONFIG_PCACHE option.
  1647. ** There are three arguments to this option: A pointer to 8-byte aligned
  1648. ** memory, the size of each page buffer (sz), and the number of pages (N).
  1649. ** The sz argument should be the size of the largest database page
  1650. ** (a power of two between 512 and 32768) plus a little extra for each
  1651. ** page header. ^The page header size is 20 to 40 bytes depending on
  1652. ** the host architecture. ^It is harmless, apart from the wasted memory,
  1653. ** to make sz a little too large. The first
  1654. ** argument should point to an allocation of at least sz*N bytes of memory.
  1655. ** ^SQLite will use the memory provided by the first argument to satisfy its
  1656. ** memory needs for the first N pages that it adds to cache. ^If additional
  1657. ** page cache memory is needed beyond what is provided by this option, then
  1658. ** SQLite goes to [sqlite3_malloc()] for the additional storage space.
  1659. ** The pointer in the first argument must
  1660. ** be aligned to an 8-byte boundary or subsequent behavior of SQLite
  1661. ** will be undefined.</dd>
  1662. **
  1663. ** [[SQLITE_CONFIG_HEAP]] <dt>SQLITE_CONFIG_HEAP</dt>
  1664. ** <dd> ^This option specifies a static memory buffer that SQLite will use
  1665. ** for all of its dynamic memory allocation needs beyond those provided
  1666. ** for by [SQLITE_CONFIG_SCRATCH] and [SQLITE_CONFIG_PAGECACHE].
  1667. ** There are three arguments: An 8-byte aligned pointer to the memory,
  1668. ** the number of bytes in the memory buffer, and the minimum allocation size.
  1669. ** ^If the first pointer (the memory pointer) is NULL, then SQLite reverts
  1670. ** to using its default memory allocator (the system malloc() implementation),
  1671. ** undoing any prior invocation of [SQLITE_CONFIG_MALLOC]. ^If the
  1672. ** memory pointer is not NULL and either [SQLITE_ENABLE_MEMSYS3] or
  1673. ** [SQLITE_ENABLE_MEMSYS5] are defined, then the alternative memory
  1674. ** allocator is engaged to handle all of SQLites memory allocation needs.
  1675. ** The first pointer (the memory pointer) must be aligned to an 8-byte
  1676. ** boundary or subsequent behavior of SQLite will be undefined.
  1677. ** The minimum allocation size is capped at 2^12. Reasonable values
  1678. ** for the minimum allocation size are 2^5 through 2^8.</dd>
  1679. **
  1680. ** [[SQLITE_CONFIG_MUTEX]] <dt>SQLITE_CONFIG_MUTEX</dt>
  1681. ** <dd> ^(This option takes a single argument which is a pointer to an
  1682. ** instance of the [sqlite3_mutex_methods] structure. The argument specifies
  1683. ** alternative low-level mutex routines to be used in place
  1684. ** the mutex routines built into SQLite.)^ ^SQLite makes a copy of the
  1685. ** content of the [sqlite3_mutex_methods] structure before the call to
  1686. ** [sqlite3_config()] returns. ^If SQLite is compiled with
  1687. ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
  1688. ** the entire mutexing subsystem is omitted from the build and hence calls to
  1689. ** [sqlite3_config()] with the SQLITE_CONFIG_MUTEX configuration option will
  1690. ** return [SQLITE_ERROR].</dd>
  1691. **
  1692. ** [[SQLITE_CONFIG_GETMUTEX]] <dt>SQLITE_CONFIG_GETMUTEX</dt>
  1693. ** <dd> ^(This option takes a single argument which is a pointer to an
  1694. ** instance of the [sqlite3_mutex_methods] structure. The
  1695. ** [sqlite3_mutex_methods]
  1696. ** structure is filled with the currently defined mutex routines.)^
  1697. ** This option can be used to overload the default mutex allocation
  1698. ** routines with a wrapper used to track mutex usage for performance
  1699. ** profiling or testing, for example. ^If SQLite is compiled with
  1700. ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
  1701. ** the entire mutexing subsystem is omitted from the build and hence calls to
  1702. ** [sqlite3_config()] with the SQLITE_CONFIG_GETMUTEX configuration option will
  1703. ** return [SQLITE_ERROR].</dd>
  1704. **
  1705. ** [[SQLITE_CONFIG_LOOKASIDE]] <dt>SQLITE_CONFIG_LOOKASIDE</dt>
  1706. ** <dd> ^(This option takes two arguments that determine the default
  1707. ** memory allocation for the lookaside memory allocator on each
  1708. ** [database connection]. The first argument is the
  1709. ** size of each lookaside buffer slot and the second is the number of
  1710. ** slots allocated to each database connection.)^ ^(This option sets the
  1711. ** <i>default</i> lookaside size. The [SQLITE_DBCONFIG_LOOKASIDE]
  1712. ** verb to [sqlite3_db_config()] can be used to change the lookaside
  1713. ** configuration on individual connections.)^ </dd>
  1714. **
  1715. ** [[SQLITE_CONFIG_PCACHE]] <dt>SQLITE_CONFIG_PCACHE</dt>
  1716. ** <dd> ^(This option takes a single argument which is a pointer to
  1717. ** an [sqlite3_pcache_methods] object. This object specifies the interface
  1718. ** to a custom page cache implementation.)^ ^SQLite makes a copy of the
  1719. ** object and uses it for page cache memory allocations.</dd>
  1720. **
  1721. ** [[SQLITE_CONFIG_GETPCACHE]] <dt>SQLITE_CONFIG_GETPCACHE</dt>
  1722. ** <dd> ^(This option takes a single argument which is a pointer to an
  1723. ** [sqlite3_pcache_methods] object. SQLite copies of the current
  1724. ** page cache implementation into that object.)^ </dd>
  1725. **
  1726. ** [[SQLITE_CONFIG_LOG]] <dt>SQLITE_CONFIG_LOG</dt>
  1727. ** <dd> ^The SQLITE_CONFIG_LOG option takes two arguments: a pointer to a
  1728. ** function with a call signature of void()(void*,int,const char),
  1729. ** and a pointer to void. ^If the function pointer is not NULL, it is
  1730. ** invoked by [sqlite3_log()] to process each logging event. ^If the
  1731. ** function pointer is NULL, the [sqlite3_log()] interface becomes a no-op.
  1732. ** ^The void pointer that is the second argument to SQLITE_CONFIG_LOG is
  1733. ** passed through as the first parameter to the application-defined logger
  1734. ** function whenever that function is invoked. ^The second parameter to
  1735. ** the logger function is a copy of the first parameter to the corresponding
  1736. ** [sqlite3_log()] call and is intended to be a [result code] or an
  1737. ** [extended result code]. ^The third parameter passed to the logger is
  1738. ** log message after formatting via [sqlite3_snprintf()].
  1739. ** The SQLite logging interface is not reentrant; the logger function
  1740. ** supplied by the application must not invoke any SQLite interface.
  1741. ** In a multi-threaded application, the application-defined logger
  1742. ** function must be threadsafe. </dd>
  1743. **
  1744. ** [[SQLITE_CONFIG_URI]] <dt>SQLITE_CONFIG_URI
  1745. ** <dd> This option takes a single argument of type int. If non-zero, then
  1746. ** URI handling is globally enabled. If the parameter is zero, then URI handling
  1747. ** is globally disabled. If URI handling is globally enabled, all filenames
  1748. ** passed to [sqlite3_open()], [sqlite3_open_v2()], [sqlite3_open16()] or
  1749. ** specified as part of [ATTACH] commands are interpreted as URIs, regardless
  1750. ** of whether or not the [SQLITE_OPEN_URI] flag is set when the database
  1751. ** connection is opened. If it is globally disabled, filenames are
  1752. ** only interpreted as URIs if the SQLITE_OPEN_URI flag is set when the
  1753. ** database connection is opened. By default, URI handling is globally
  1754. ** disabled. The default value may be changed by compiling with the
  1755. ** [SQLITE_USE_URI] symbol defined.
  1756. ** </dl>
  1757. */
  1758. //#define SQLITE_CONFIG_SINGLETHREAD 1 /* nil */
  1759. //#define SQLITE_CONFIG_MULTITHREAD 2 /* nil */
  1760. //#define SQLITE_CONFIG_SERIALIZED 3 /* nil */
  1761. //#define SQLITE_CONFIG_MALLOC 4 /* sqlite3_mem_methods* */
  1762. //#define SQLITE_CONFIG_GETMALLOC 5 /* sqlite3_mem_methods* */
  1763. //#define SQLITE_CONFIG_SCRATCH 6 /* void*, int sz, int N */
  1764. //#define SQLITE_CONFIG_PAGECACHE 7 /* void*, int sz, int N */
  1765. //#define SQLITE_CONFIG_HEAP 8 /* void*, int nByte, int min */
  1766. //#define SQLITE_CONFIG_MEMSTATUS 9 /* boolean */
  1767. //#define SQLITE_CONFIG_MUTEX 10 /* sqlite3_mutex_methods* */
  1768. //#define SQLITE_CONFIG_GETMUTEX 11 /* sqlite3_mutex_methods* */
  1769. ///* previously SQLITE_CONFIG_CHUNKALLOC 12 which is now unused. */
  1770. //#define SQLITE_CONFIG_LOOKASIDE 13 /* int int */
  1771. //#define SQLITE_CONFIG_PCACHE 14 /* sqlite3_pcache_methods* */
  1772. //#define SQLITE_CONFIG_GETPCACHE 15 /* sqlite3_pcache_methods* */
  1773. //#define SQLITE_CONFIG_LOG 16 /* xFunc, void* */
  1774. //#define SQLITE_CONFIG_URI 17 /* int */
  1775. public const int SQLITE_CONFIG_SINGLETHREAD = 1;
  1776. public const int SQLITE_CONFIG_MULTITHREAD = 2;
  1777. public const int SQLITE_CONFIG_SERIALIZED = 3;
  1778. public const int SQLITE_CONFIG_MALLOC = 4;
  1779. public const int SQLITE_CONFIG_GETMALLOC = 5;
  1780. public const int SQLITE_CONFIG_SCRATCH = 6;
  1781. public const int SQLITE_CONFIG_PAGECACHE = 7;
  1782. public const int SQLITE_CONFIG_HEAP = 8;
  1783. public const int SQLITE_CONFIG_MEMSTATUS = 9;
  1784. public const int SQLITE_CONFIG_MUTEX = 10;
  1785. public const int SQLITE_CONFIG_GETMUTEX = 11;
  1786. public const int SQLITE_CONFIG_LOOKASIDE = 13;
  1787. public const int SQLITE_CONFIG_PCACHE = 14;
  1788. public const int SQLITE_CONFIG_GETPCACHE = 15;
  1789. public const int SQLITE_CONFIG_LOG = 16;
  1790. public const int SQLITE_CONFIG_URI = 17;
  1791. /*
  1792. ** CAPI3REF: Database Connection Configuration Options
  1793. **
  1794. ** These constants are the available integer configuration options that
  1795. ** can be passed as the second argument to the [sqlite3_db_config()] interface.
  1796. **
  1797. ** New configuration options may be added in future releases of SQLite.
  1798. ** Existing configuration options might be discontinued. Applications
  1799. ** should check the return code from [sqlite3_db_config()] to make sure that
  1800. ** the call worked. ^The [sqlite3_db_config()] interface will return a
  1801. ** non-zero [error code] if a discontinued or unsupported configuration option
  1802. ** is invoked.
  1803. **
  1804. ** <dl>
  1805. ** <dt>SQLITE_DBCONFIG_LOOKASIDE</dt>
  1806. ** <dd> ^This option takes three additional arguments that determine the
  1807. ** [lookaside memory allocator] configuration for the [database connection].
  1808. ** ^The first argument (the third parameter to [sqlite3_db_config()] is a
  1809. ** pointer to a memory buffer to use for lookaside memory.
  1810. ** ^The first argument after the SQLITE_DBCONFIG_LOOKASIDE verb
  1811. ** may be NULL in which case SQLite will allocate the
  1812. ** lookaside buffer itself using [sqlite3_malloc()]. ^The second argument is the
  1813. ** size of each lookaside buffer slot. ^The third argument is the number of
  1814. ** slots. The size of the buffer in the first argument must be greater than
  1815. ** or equal to the product of the second and third arguments. The buffer
  1816. ** must be aligned to an 8-byte boundary. ^If the second argument to
  1817. ** SQLITE_DBCONFIG_LOOKASIDE is not a multiple of 8, it is internally
  1818. ** rounded down to the next smaller multiple of 8. ^(The lookaside memory
  1819. ** configuration for a database connection can only be changed when that
  1820. ** connection is not currently using lookaside memory, or in other words
  1821. ** when the "current value" returned by
  1822. ** [sqlite3_db_status](D,[SQLITE_CONFIG_LOOKASIDE],...) is zero.
  1823. ** Any attempt to change the lookaside memory configuration when lookaside
  1824. ** memory is in use leaves the configuration unchanged and returns
  1825. ** [SQLITE_BUSY].)^</dd>
  1826. **
  1827. ** <dt>SQLITE_DBCONFIG_ENABLE_FKEY</dt>
  1828. ** <dd> ^This option is used to enable or disable the enforcement of
  1829. ** [foreign key constraints]. There should be two additional arguments.
  1830. ** The first argument is an integer which is 0 to disable FK enforcement,
  1831. ** positive to enable FK enforcement or negative to leave FK enforcement
  1832. ** unchanged. The second parameter is a pointer to an integer into which
  1833. ** is written 0 or 1 to indicate whether FK enforcement is off or on
  1834. ** following this call. The second parameter may be a NULL pointer, in
  1835. ** which case the FK enforcement setting is not reported back. </dd>
  1836. **
  1837. ** <dt>SQLITE_DBCONFIG_ENABLE_TRIGGER</dt>
  1838. ** <dd> ^This option is used to enable or disable [CREATE TRIGGER | triggers].
  1839. ** There should be two additional arguments.
  1840. ** The first argument is an integer which is 0 to disable triggers,
  1841. ** positive to enable triggers or negative to leave the setting unchanged.
  1842. ** The second parameter is a pointer to an integer into which
  1843. ** is written 0 or 1 to indicate whether triggers are disabled or enabled
  1844. ** following this call. The second parameter may be a NULL pointer, in
  1845. ** which case the trigger setting is not reported back. </dd>
  1846. **
  1847. ** </dl>
  1848. */
  1849. //#define SQLITE_DBCONFIG_LOOKASIDE 1001 /* void* int int */
  1850. //#define SQLITE_DBCONFIG_ENABLE_FKEY 1002 /* int int* */
  1851. //#define SQLITE_DBCONFIG_ENABLE_TRIGGER 1003 /* int int* */
  1852. const int SQLITE_DBCONFIG_LOOKASIDE = 1001;
  1853. const int SQLITE_DBCONFIG_ENABLE_FKEY = 1002;
  1854. const int SQLITE_DBCONFIG_ENABLE_TRIGGER = 1003;
  1855. /*
  1856. ** CAPI3REF: Enable Or Disable Extended Result Codes
  1857. **
  1858. ** ^The sqlite3_extended_result_codes() routine enables or disables the
  1859. ** [extended result codes] feature of SQLite. ^The extended result
  1860. ** codes are disabled by default for historical compatibility.
  1861. */
  1862. //SQLITE_API int sqlite3_extended_result_codes(sqlite3*, int onoff);
  1863. /*
  1864. ** CAPI3REF: Last Insert Rowid
  1865. **
  1866. ** ^Each entry in an SQLite table has a unique 64-bit signed
  1867. ** integer key called the [ROWID | "rowid"]. ^The rowid is always available
  1868. ** as an undeclared column named ROWID, OID, or _ROWID_ as long as those
  1869. ** names are not also used by explicitly declared columns. ^If
  1870. ** the table has a column of type [INTEGER PRIMARY KEY] then that column
  1871. ** is another alias for the rowid.
  1872. **
  1873. ** ^This routine returns the [rowid] of the most recent
  1874. ** successful [INSERT] into the database from the [database connection]
  1875. ** in the first argument. ^As of SQLite version 3.7.7, this routines
  1876. ** records the last insert rowid of both ordinary tables and [virtual tables].
  1877. ** ^If no successful [INSERT]s
  1878. ** have ever occurred on that database connection, zero is returned.
  1879. **
  1880. ** ^(If an [INSERT] occurs within a trigger or within a [virtual table]
  1881. ** method, then this routine will return the [rowid] of the inserted
  1882. ** row as long as the trigger or virtual table method is running.
  1883. ** But once the trigger or virtual table method ends, the value returned
  1884. ** by this routine reverts to what it was before the trigger or virtual
  1885. ** table method began.)^
  1886. **
  1887. ** ^An [INSERT] that fails due to a constraint violation is not a
  1888. ** successful [INSERT] and does not change the value returned by this
  1889. ** routine. ^Thus INSERT OR FAIL, INSERT OR IGNORE, INSERT OR ROLLBACK,
  1890. ** and INSERT OR ABORT make no changes to the return value of this
  1891. ** routine when their insertion fails. ^(When INSERT OR REPLACE
  1892. ** encounters a constraint violation, it does not fail. The
  1893. ** INSERT continues to completion after deleting rows that caused
  1894. ** the constraint problem so INSERT OR REPLACE will always change
  1895. ** the return value of this interface.)^
  1896. **
  1897. ** ^For the purposes of this routine, an [INSERT] is considered to
  1898. ** be successful even if it is subsequently rolled back.
  1899. **
  1900. ** This function is accessible to SQL statements via the
  1901. ** [last_insert_rowid() SQL function].
  1902. **
  1903. ** If a separate thread performs a new [INSERT] on the same
  1904. ** database connection while the [sqlite3_last_insert_rowid()]
  1905. ** function is running and thus changes the last insert [rowid],
  1906. ** then the value returned by [sqlite3_last_insert_rowid()] is
  1907. ** unpredictable and might not equal either the old or the new
  1908. ** last insert [rowid].
  1909. */
  1910. //SQLITE_API sqlite3_int64 sqlite3_last_insert_rowid(sqlite3);
  1911. /*
  1912. ** CAPI3REF: Count The Number Of Rows Modified
  1913. **
  1914. ** ^This function returns the number of database rows that were changed
  1915. ** or inserted or deleted by the most recently completed SQL statement
  1916. ** on the [database connection] specified by the first parameter.
  1917. ** ^(Only changes that are directly specified by the [INSERT], [UPDATE],
  1918. ** or [DELETE] statement are counted. Auxiliary changes caused by
  1919. ** triggers or [foreign key actions] are not counted.)^ Use the
  1920. ** [sqlite3_total_changes()] function to find the total number of changes
  1921. ** including changes caused by triggers and foreign key actions.
  1922. **
  1923. ** ^Changes to a view that are simulated by an [INSTEAD OF trigger]
  1924. ** are not counted. Only real table changes are counted.
  1925. **
  1926. ** ^(A "row change" is a change to a single row of a single table
  1927. ** caused by an INSERT, DELETE, or UPDATE statement. Rows that
  1928. ** are changed as side effects of [REPLACE] constraint resolution,
  1929. ** rollback, ABORT processing, [DROP TABLE], or by any other
  1930. ** mechanisms do not count as direct row changes.)^
  1931. **
  1932. ** A "trigger context" is a scope of execution that begins and
  1933. ** ends with the script of a [CREATE TRIGGER | trigger].
  1934. ** Most SQL statements are
  1935. ** evaluated outside of any trigger. This is the "top level"
  1936. ** trigger context. If a trigger fires from the top level, a
  1937. ** new trigger context is entered for the duration of that one
  1938. ** trigger. Subtriggers create subcontexts for their duration.
  1939. **
  1940. ** ^Calling [sqlite3_exec()] or [sqlite3_step()] recursively does
  1941. ** not create a new trigger context.
  1942. **
  1943. ** ^This function returns the number of direct row changes in the
  1944. ** most recent INSERT, UPDATE, or DELETE statement within the same
  1945. ** trigger context.
  1946. **
  1947. ** ^Thus, when called from the top level, this function returns the
  1948. ** number of changes in the most recent INSERT, UPDATE, or DELETE
  1949. ** that also occurred at the top level. ^(Within the body of a trigger,
  1950. ** the sqlite3_changes() interface can be called to find the number of
  1951. ** changes in the most recently completed INSERT, UPDATE, or DELETE
  1952. ** statement within the body of the same trigger.
  1953. ** However, the number returned does not include changes
  1954. ** caused by subtriggers since those have their own context.)^
  1955. **
  1956. ** See also the [sqlite3_total_changes()] interface, the
  1957. ** [count_changes pragma], and the [changes() SQL function].
  1958. **
  1959. ** If a separate thread makes changes on the same database connection
  1960. ** while [sqlite3_changes()] is running then the value returned
  1961. ** is unpredictable and not meaningful.
  1962. */
  1963. //SQLITE_API int sqlite3_changes(sqlite3);
  1964. /*
  1965. ** CAPI3REF: Total Number Of Rows Modified
  1966. **
  1967. ** ^This function returns the number of row changes caused by [INSERT],
  1968. ** [UPDATE] or [DELETE] statements since the [database connection] was opened.
  1969. ** ^(The count returned by sqlite3_total_changes() includes all changes
  1970. ** from all [CREATE TRIGGER | trigger] contexts and changes made by
  1971. ** [foreign key actions]. However,
  1972. ** the count does not include changes used to implement [REPLACE] constraints,
  1973. ** do rollbacks or ABORT processing, or [DROP TABLE] processing. The
  1974. ** count does not include rows of views that fire an [INSTEAD OF trigger],
  1975. ** though if the INSTEAD OF trigger makes changes of its own, those changes
  1976. ** are counted.)^
  1977. ** ^The sqlite3_total_changes() function counts the changes as soon as
  1978. ** the statement that makes them is completed (when the statement handle
  1979. ** is passed to [sqlite3_reset()] or [sqlite3_finalize()]).
  1980. **
  1981. ** See also the [sqlite3_changes()] interface, the
  1982. ** [count_changes pragma], and the [total_changes() SQL function].
  1983. **
  1984. ** If a separate thread makes changes on the same database connection
  1985. ** while [sqlite3_total_changes()] is running then the value
  1986. ** returned is unpredictable and not meaningful.
  1987. */
  1988. //SQLITE_API int sqlite3_total_changes(sqlite3);
  1989. /*
  1990. ** CAPI3REF: Interrupt A Long-Running Query
  1991. **
  1992. ** ^This function causes any pending database operation to abort and
  1993. ** return at its earliest opportunity. This routine is typically
  1994. ** called in response to a user action such as pressing "Cancel"
  1995. ** or Ctrl-C where the user wants a long query operation to halt
  1996. ** immediately.
  1997. **
  1998. ** ^It is safe to call this routine from a thread different from the
  1999. ** thread that is currently running the database operation. But it
  2000. ** is not safe to call this routine with a [database connection] that
  2001. ** is closed or might close before sqlite3_interrupt() returns.
  2002. **
  2003. ** ^If an SQL operation is very nearly finished at the time when
  2004. ** sqlite3_interrupt() is called, then it might not have an opportunity
  2005. ** to be interrupted and might continue to completion.
  2006. **
  2007. ** ^An SQL operation that is interrupted will return [SQLITE_INTERRUPT].
  2008. ** ^If the interrupted SQL operation is an INSERT, UPDATE, or DELETE
  2009. ** that is inside an explicit transaction, then the entire transaction
  2010. ** will be rolled back automatically.
  2011. **
  2012. ** ^The sqlite3_interrupt(D) call is in effect until all currently running
  2013. ** SQL statements on [database connection] D complete. ^Any new SQL statements
  2014. ** that are started after the sqlite3_interrupt() call and before the
  2015. ** running statements reaches zero are interrupted as if they had been
  2016. ** running prior to the sqlite3_interrupt() call. ^New SQL statements
  2017. ** that are started after the running statement count reaches zero are
  2018. ** not effected by the sqlite3_interrupt().
  2019. ** ^A call to sqlite3_interrupt(D) that occurs when there are no running
  2020. ** SQL statements is a no-op and has no effect on SQL statements
  2021. ** that are started after the sqlite3_interrupt() call returns.
  2022. **
  2023. ** If the database connection closes while [sqlite3_interrupt()]
  2024. ** is running then bad things will likely happen.
  2025. */
  2026. //SQLITE_API void sqlite3_interrupt(sqlite3);
  2027. /*
  2028. ** CAPI3REF: Determine If An SQL Statement Is Complete
  2029. **
  2030. ** These routines are useful during command-line input to determine if the
  2031. ** currently entered text seems to form a complete SQL statement or
  2032. ** if additional input is needed before sending the text into
  2033. ** SQLite for parsing. ^These routines return 1 if the input string
  2034. ** appears to be a complete SQL statement. ^A statement is judged to be
  2035. ** complete if it ends with a semicolon token and is not a prefix of a
  2036. ** well-formed CREATE TRIGGER statement. ^Semicolons that are embedded within
  2037. ** string literals or quoted identifier names or comments are not
  2038. ** independent tokens (they are part of the token in which they are
  2039. ** embedded) and thus do not count as a statement terminator. ^Whitespace
  2040. ** and comments that follow the final semicolon are ignored.
  2041. **
  2042. ** ^These routines return 0 if the statement is incomplete. ^If a
  2043. ** memory allocation fails, then SQLITE_NOMEM is returned.
  2044. **
  2045. ** ^These routines do not parse the SQL statements thus
  2046. ** will not detect syntactically incorrect SQL.
  2047. **
  2048. ** ^(If SQLite has not been initialized using [sqlite3_initialize()] prior
  2049. ** to invoking sqlite3_complete16() then sqlite3_initialize() is invoked
  2050. ** automatically by sqlite3_complete16(). If that initialization fails,
  2051. ** then the return value from sqlite3_complete16() will be non-zero
  2052. ** regardless of whether or not the input SQL is complete.)^
  2053. **
  2054. ** The input to [sqlite3_complete()] must be a zero-terminated
  2055. ** UTF-8 string.
  2056. **
  2057. ** The input to [sqlite3_complete16()] must be a zero-terminated
  2058. ** UTF-16 string in native byte order.
  2059. */
  2060. //SQLITE_API int sqlite3_complete(string sql);
  2061. //SQLITE_API int sqlite3_complete16(const void *sql);
  2062. /*
  2063. ** CAPI3REF: Register A Callback To Handle SQLITE_BUSY Errors
  2064. **
  2065. ** ^This routine sets a callback function that might be invoked whenever
  2066. ** an attempt is made to open a database table that another thread
  2067. ** or process has locked.
  2068. **
  2069. ** ^If the busy callback is NULL, then [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED]
  2070. ** is returned immediately upon encountering the lock. ^If the busy callback
  2071. ** is not NULL, then the callback might be invoked with two arguments.
  2072. **
  2073. ** ^The first argument to the busy handler is a copy of the void* pointer which
  2074. ** is the third argument to sqlite3_busy_handler(). ^The second argument to
  2075. ** the busy handler callback is the number of times that the busy handler has
  2076. ** been invoked for this locking event. ^If the
  2077. ** busy callback returns 0, then no additional attempts are made to
  2078. ** access the database and [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED] is returned.
  2079. ** ^If the callback returns non-zero, then another attempt
  2080. ** is made to open the database for reading and the cycle repeats.
  2081. **
  2082. ** The presence of a busy handler does not guarantee that it will be invoked
  2083. ** when there is lock contention. ^If SQLite determines that invoking the busy
  2084. ** handler could result in a deadlock, it will go ahead and return [SQLITE_BUSY]
  2085. ** or [SQLITE_IOERR_BLOCKED] instead of invoking the busy handler.
  2086. ** Consider a scenario where one process is holding a read lock that
  2087. ** it is trying to promote to a reserved lock and
  2088. ** a second process is holding a reserved lock that it is trying
  2089. ** to promote to an exclusive lock. The first process cannot proceed
  2090. ** because it is blocked by the second and the second process cannot
  2091. ** proceed because it is blocked by the first. If both processes
  2092. ** invoke the busy handlers, neither will make any progress. Therefore,
  2093. ** SQLite returns [SQLITE_BUSY] for the first process, hoping that this
  2094. ** will induce the first process to release its read lock and allow
  2095. ** the second process to proceed.
  2096. **
  2097. ** ^The default busy callback is NULL.
  2098. **
  2099. ** ^The [SQLITE_BUSY] error is converted to [SQLITE_IOERR_BLOCKED]
  2100. ** when SQLite is in the middle of a large transaction where all the
  2101. ** changes will not fit into the in-memory cache. SQLite will
  2102. ** already hold a RESERVED lock on the database file, but it needs
  2103. ** to promote this lock to EXCLUSIVE so that it can spill cache
  2104. ** pages into the database file without harm to concurrent
  2105. ** readers. ^If it is unable to promote the lock, then the in-memory
  2106. ** cache will be left in an inconsistent state and so the error
  2107. ** code is promoted from the relatively benign [SQLITE_BUSY] to
  2108. ** the more severe [SQLITE_IOERR_BLOCKED]. ^This error code promotion
  2109. ** forces an automatic rollback of the changes. See the
  2110. ** <a href="/cvstrac/wiki?p=CorruptionFollowingBusyError">
  2111. ** CorruptionFollowingBusyError</a> wiki page for a discussion of why
  2112. ** this is important.
  2113. **
  2114. ** ^(There can only be a single busy handler defined for each
  2115. ** [database connection]. Setting a new busy handler clears any
  2116. ** previously set handler.)^ ^Note that calling [sqlite3_busy_timeout()]
  2117. ** will also set or clear the busy handler.
  2118. **
  2119. ** The busy callback should not take any actions which modify the
  2120. ** database connection that invoked the busy handler. Any such actions
  2121. ** result in undefined behavior.
  2122. **
  2123. ** A busy handler must not close the database connection
  2124. ** or [prepared statement] that invoked the busy handler.
  2125. */
  2126. //SQLITE_API int sqlite3_busy_handler(sqlite3*, int()(void*,int), void);
  2127. /*
  2128. ** CAPI3REF: Set A Busy Timeout
  2129. **
  2130. ** ^This routine sets a [sqlite3_busy_handler | busy handler] that sleeps
  2131. ** for a specified amount of time when a table is locked. ^The handler
  2132. ** will sleep multiple times until at least "ms" milliseconds of sleeping
  2133. ** have accumulated. ^After at least "ms" milliseconds of sleeping,
  2134. ** the handler returns 0 which causes [sqlite3_step()] to return
  2135. ** [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED].
  2136. **
  2137. ** ^Calling this routine with an argument less than or equal to zero
  2138. ** turns off all busy handlers.
  2139. **
  2140. ** ^(There can only be a single busy handler for a particular
  2141. ** [database connection] any any given moment. If another busy handler
  2142. ** was defined (using [sqlite3_busy_handler()]) prior to calling
  2143. ** this routine, that other busy handler is cleared.)^
  2144. */
  2145. //SQLITE_API int sqlite3_busy_timeout(sqlite3*, int ms);
  2146. /*
  2147. ** CAPI3REF: Convenience Routines For Running Queries
  2148. **
  2149. ** This is a legacy interface that is preserved for backwards compatibility.
  2150. ** Use of this interface is not recommended.
  2151. **
  2152. ** Definition: A <b>result table</b> is memory data structure created by the
  2153. ** [sqlite3_get_table()] interface. A result table records the
  2154. ** complete query results from one or more queries.
  2155. **
  2156. ** The table conceptually has a number of rows and columns. But
  2157. ** these numbers are not part of the result table itself. These
  2158. ** numbers are obtained separately. Let N be the number of rows
  2159. ** and M be the number of columns.
  2160. **
  2161. ** A result table is an array of pointers to zero-terminated UTF-8 strings.
  2162. ** There are (N+1)*M elements in the array. The first M pointers point
  2163. ** to zero-terminated strings that contain the names of the columns.
  2164. ** The remaining entries all point to query results. NULL values result
  2165. ** in NULL pointers. All other values are in their UTF-8 zero-terminated
  2166. ** string representation as returned by [sqlite3_column_text()].
  2167. **
  2168. ** A result table might consist of one or more memory allocations.
  2169. ** It is not safe to pass a result table directly to [sqlite3_free()].
  2170. ** A result table should be deallocated using [sqlite3_free_table()].
  2171. **
  2172. ** ^(As an example of the result table format, suppose a query result
  2173. ** is as follows:
  2174. **
  2175. ** <blockquote><pre>
  2176. ** Name | Age
  2177. ** -----------------------
  2178. ** Alice | 43
  2179. ** Bob | 28
  2180. ** Cindy | 21
  2181. ** </pre></blockquote>
  2182. **
  2183. ** There are two column (M==2) and three rows (N==3). Thus the
  2184. ** result table has 8 entries. Suppose the result table is stored
  2185. ** in an array names azResult. Then azResult holds this content:
  2186. **
  2187. ** <blockquote><pre>
  2188. ** azResult&#91;0] = "Name";
  2189. ** azResult&#91;1] = "Age";
  2190. ** azResult&#91;2] = "Alice";
  2191. ** azResult&#91;3] = "43";
  2192. ** azResult&#91;4] = "Bob";
  2193. ** azResult&#91;5] = "28";
  2194. ** azResult&#91;6] = "Cindy";
  2195. ** azResult&#91;7] = "21";
  2196. ** </pre></blockquote>)^
  2197. **
  2198. ** ^The sqlite3_get_table() function evaluates one or more
  2199. ** semicolon-separated SQL statements in the zero-terminated UTF-8
  2200. ** string of its 2nd parameter and returns a result table to the
  2201. ** pointer given in its 3rd parameter.
  2202. **
  2203. ** After the application has finished with the result from sqlite3_get_table(),
  2204. ** it must pass the result table pointer to sqlite3_free_table() in order to
  2205. ** release the memory that was malloced. Because of the way the
  2206. ** [sqlite3_malloc()] happens within sqlite3_get_table(), the calling
  2207. ** function must not try to call [sqlite3_free()] directly. Only
  2208. ** [sqlite3_free_table()] is able to release the memory properly and safely.
  2209. **
  2210. ** The sqlite3_get_table() interface is implemented as a wrapper around
  2211. ** [sqlite3_exec()]. The sqlite3_get_table() routine does not have access
  2212. ** to any internal data structures of SQLite. It uses only the public
  2213. ** interface defined here. As a consequence, errors that occur in the
  2214. ** wrapper layer outside of the internal [sqlite3_exec()] call are not
  2215. ** reflected in subsequent calls to [sqlite3_errcode()] or
  2216. ** [sqlite3_errmsg()].
  2217. */
  2218. //SQLITE_API int sqlite3_get_table(
  2219. // sqlite3 db, /* An open database */
  2220. // string zSql, /* SQL to be evaluated */
  2221. // char ***pazResult, /* Results of the query */
  2222. // int *pnRow, /* Number of result rows written here */
  2223. // int *pnColumn, /* Number of result columns written here */
  2224. // char **pzErrmsg /* Error msg written here */
  2225. //);
  2226. //SQLITE_API void sqlite3_free_table(char **result);
  2227. /*
  2228. ** CAPI3REF: Formatted String Printing Functions
  2229. **
  2230. ** These routines are work-alikes of the "printf()" family of functions
  2231. ** from the standard C library.
  2232. **
  2233. ** ^The sqlite3_mprintf() and sqlite3_vmprintf() routines write their
  2234. ** results into memory obtained from [sqlite3_malloc()].
  2235. ** The strings returned by these two routines should be
  2236. ** released by [sqlite3_free()]. ^Both routines return a
  2237. ** NULL pointer if [sqlite3_malloc()] is unable to allocate enough
  2238. ** memory to hold the resulting string.
  2239. **
  2240. ** ^(The sqlite3_snprintf() routine is similar to "snprintf()" from
  2241. ** the standard C library. The result is written into the
  2242. ** buffer supplied as the second parameter whose size is given by
  2243. ** the first parameter. Note that the order of the
  2244. ** first two parameters is reversed from snprintf().)^ This is an
  2245. ** historical accident that cannot be fixed without breaking
  2246. ** backwards compatibility. ^(Note also that sqlite3_snprintf()
  2247. ** returns a pointer to its buffer instead of the number of
  2248. ** characters actually written into the buffer.)^ We admit that
  2249. ** the number of characters written would be a more useful return
  2250. ** value but we cannot change the implementation of sqlite3_snprintf()
  2251. ** now without breaking compatibility.
  2252. **
  2253. ** ^As long as the buffer size is greater than zero, sqlite3_snprintf()
  2254. ** guarantees that the buffer is always zero-terminated. ^The first
  2255. ** parameter "n" is the total size of the buffer, including space for
  2256. ** the zero terminator. So the longest string that can be completely
  2257. ** written will be n-1 characters.
  2258. **
  2259. ** ^The sqlite3_vsnprintf() routine is a varargs version of sqlite3_snprintf().
  2260. **
  2261. ** These routines all implement some additional formatting
  2262. ** options that are useful for constructing SQL statements.
  2263. ** All of the usual printf() formatting options apply. In addition, there
  2264. ** is are "%q", "%Q", and "%z" options.
  2265. **
  2266. ** ^(The %q option works like %s in that it substitutes a null-terminated
  2267. ** string from the argument list. But %q also doubles every '\'' character.
  2268. ** %q is designed for use inside a string literal.)^ By doubling each '\''
  2269. ** character it escapes that character and allows it to be inserted into
  2270. ** the string.
  2271. **
  2272. ** For example, assume the string variable zText contains text as follows:
  2273. **
  2274. ** <blockquote><pre>
  2275. ** string zText = "It's a happy day!";
  2276. ** </pre></blockquote>
  2277. **
  2278. ** One can use this text in an SQL statement as follows:
  2279. **
  2280. ** <blockquote><pre>
  2281. ** string zSQL = sqlite3_mprintf("INSERT INTO table VALUES('%q')", zText);
  2282. ** sqlite3_exec(db, zSQL, 0, 0, 0);
  2283. ** sqlite3_free(zSQL);
  2284. ** </pre></blockquote>
  2285. **
  2286. ** Because the %q format string is used, the '\'' character in zText
  2287. ** is escaped and the SQL generated is as follows:
  2288. **
  2289. ** <blockquote><pre>
  2290. ** INSERT INTO table1 VALUES('It''s a happy day!')
  2291. ** </pre></blockquote>
  2292. **
  2293. ** This is correct. Had we used %s instead of %q, the generated SQL
  2294. ** would have looked like this:
  2295. **
  2296. ** <blockquote><pre>
  2297. ** INSERT INTO table1 VALUES('It's a happy day!');
  2298. ** </pre></blockquote>
  2299. **
  2300. ** This second example is an SQL syntax error. As a general rule you should
  2301. ** always use %q instead of %s when inserting text into a string literal.
  2302. **
  2303. ** ^(The %Q option works like %q except it also adds single quotes around
  2304. ** the outside of the total string. Additionally, if the parameter in the
  2305. ** argument list is a NULL pointer, %Q substitutes the text "NULL" (without
  2306. ** single quotes).)^ So, for example, one could say:
  2307. **
  2308. ** <blockquote><pre>
  2309. ** string zSQL = sqlite3_mprintf("INSERT INTO table VALUES(%Q)", zText);
  2310. ** sqlite3_exec(db, zSQL, 0, 0, 0);
  2311. ** sqlite3_free(zSQL);
  2312. ** </pre></blockquote>
  2313. **
  2314. ** The code above will render a correct SQL statement in the zSQL
  2315. ** variable even if the zText variable is a NULL pointer.
  2316. **
  2317. ** ^(The "%z" formatting option works like "%s" but with the
  2318. ** addition that after the string has been read and copied into
  2319. ** the result, [sqlite3_free()] is called on the input string.)^
  2320. */
  2321. //SQLITE_API char *sqlite3_mprintf(const char*,...);
  2322. //SQLITE_API char *sqlite3_vmprintf(const char*, va_list);
  2323. //SQLITE_API char *sqlite3_snprintf(int,char*,const char*, ...);
  2324. //SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list);
  2325. /*
  2326. ** CAPI3REF: Memory Allocation Subsystem
  2327. **
  2328. ** The SQLite core uses these three routines for all of its own
  2329. ** internal memory allocation needs. "Core" in the previous sentence
  2330. ** does not include operating-system specific VFS implementation. The
  2331. ** Windows VFS uses native malloc() and free() for some operations.
  2332. **
  2333. ** ^The sqlite3_malloc() routine returns a pointer to a block
  2334. ** of memory at least N bytes in length, where N is the parameter.
  2335. ** ^If sqlite3_malloc() is unable to obtain sufficient free
  2336. ** memory, it returns a NULL pointer. ^If the parameter N to
  2337. ** sqlite3_malloc() is zero or negative then sqlite3_malloc() returns
  2338. ** a NULL pointer.
  2339. **
  2340. ** ^Calling sqlite3_free() with a pointer previously returned
  2341. ** by sqlite3_malloc() or sqlite3_realloc() releases that memory so
  2342. ** that it might be reused. ^The sqlite3_free() routine is
  2343. ** a no-op if is called with a NULL pointer. Passing a NULL pointer
  2344. ** to sqlite3_free() is harmless. After being freed, memory
  2345. ** should neither be read nor written. Even reading previously freed
  2346. ** memory might result in a segmentation fault or other severe error.
  2347. ** Memory corruption, a segmentation fault, or other severe error
  2348. ** might result if sqlite3_free() is called with a non-NULL pointer that
  2349. ** was not obtained from sqlite3_malloc() or sqlite3_realloc().
  2350. **
  2351. ** ^(The sqlite3_realloc() interface attempts to resize a
  2352. ** prior memory allocation to be at least N bytes, where N is the
  2353. ** second parameter. The memory allocation to be resized is the first
  2354. ** parameter.)^ ^ If the first parameter to sqlite3_realloc()
  2355. ** is a NULL pointer then its behavior is identical to calling
  2356. ** sqlite3_malloc(N) where N is the second parameter to sqlite3_realloc().
  2357. ** ^If the second parameter to sqlite3_realloc() is zero or
  2358. ** negative then the behavior is exactly the same as calling
  2359. ** sqlite3_free(P) where P is the first parameter to sqlite3_realloc().
  2360. ** ^sqlite3_realloc() returns a pointer to a memory allocation
  2361. ** of at least N bytes in size or NULL if sufficient memory is unavailable.
  2362. ** ^If M is the size of the prior allocation, then min(N,M) bytes
  2363. ** of the prior allocation are copied into the beginning of buffer returned
  2364. ** by sqlite3_realloc() and the prior allocation is freed.
  2365. ** ^If sqlite3_realloc() returns NULL, then the prior allocation
  2366. ** is not freed.
  2367. **
  2368. ** ^The memory returned by sqlite3_malloc() and sqlite3_realloc()
  2369. ** is always aligned to at least an 8 byte boundary, or to a
  2370. ** 4 byte boundary if the [SQLITE_4_BYTE_ALIGNED_MALLOC] compile-time
  2371. ** option is used.
  2372. **
  2373. ** In SQLite version 3.5.0 and 3.5.1, it was possible to define
  2374. ** the SQLITE_OMIT_MEMORY_ALLOCATION which would cause the built-in
  2375. ** implementation of these routines to be omitted. That capability
  2376. ** is no longer provided. Only built-in memory allocators can be used.
  2377. **
  2378. ** The Windows OS interface layer calls
  2379. ** the system malloc() and free() directly when converting
  2380. ** filenames between the UTF-8 encoding used by SQLite
  2381. ** and whatever filename encoding is used by the particular Windows
  2382. ** installation. Memory allocation errors are detected, but
  2383. ** they are reported back as [SQLITE_CANTOPEN] or
  2384. ** [SQLITE_IOERR] rather than [SQLITE_NOMEM].
  2385. **
  2386. ** The pointer arguments to [sqlite3_free()] and [sqlite3_realloc()]
  2387. ** must be either NULL or else pointers obtained from a prior
  2388. ** invocation of [sqlite3_malloc()] or [sqlite3_realloc()] that have
  2389. ** not yet been released.
  2390. **
  2391. ** The application must not read or write any part of
  2392. ** a block of memory after it has been released using
  2393. ** [sqlite3_free()] or [sqlite3_realloc()].
  2394. */
  2395. //SQLITE_API void *sqlite3_malloc(int);
  2396. //SQLITE_API void *sqlite3_realloc(void*, int);
  2397. //SQLITE_API void sqlite3_free(void);
  2398. /*
  2399. ** CAPI3REF: Memory Allocator Statistics
  2400. **
  2401. ** SQLite provides these two interfaces for reporting on the status
  2402. ** of the [sqlite3_malloc()], [sqlite3_free()], and [sqlite3_realloc()]
  2403. ** routines, which form the built-in memory allocation subsystem.
  2404. **
  2405. ** ^The [sqlite3_memory_used()] routine returns the number of bytes
  2406. ** of memory currently outstanding (malloced but not freed).
  2407. ** ^The [sqlite3_memory_highwater()] routine returns the maximum
  2408. ** value of [sqlite3_memory_used()] since the high-water mark
  2409. ** was last reset. ^The values returned by [sqlite3_memory_used()] and
  2410. ** [sqlite3_memory_highwater()] include any overhead
  2411. ** added by SQLite in its implementation of [sqlite3_malloc()],
  2412. ** but not overhead added by the any underlying system library
  2413. ** routines that [sqlite3_malloc()] may call.
  2414. **
  2415. ** ^The memory high-water mark is reset to the current value of
  2416. ** [sqlite3_memory_used()] if and only if the parameter to
  2417. ** [sqlite3_memory_highwater()] is true. ^The value returned
  2418. ** by [sqlite3_memory_highwater(1)] is the high-water mark
  2419. ** prior to the reset.
  2420. */
  2421. //SQLITE_API sqlite3_int64 sqlite3_memory_used(void);
  2422. //SQLITE_API sqlite3_int64 sqlite3_memory_highwater(int resetFlag);
  2423. /*
  2424. ** CAPI3REF: Pseudo-Random Number Generator
  2425. **
  2426. ** SQLite contains a high-quality pseudo-random number generator (PRNG) used to
  2427. ** select random [ROWID | ROWIDs] when inserting new records into a table that
  2428. ** already uses the largest possible [ROWID]. The PRNG is also used for
  2429. ** the build-in random() and randomblob() SQL functions. This interface allows
  2430. ** applications to access the same PRNG for other purposes.
  2431. **
  2432. ** ^A call to this routine stores N bytes of randomness into buffer P.
  2433. **
  2434. ** ^The first time this routine is invoked (either internally or by
  2435. ** the application) the PRNG is seeded using randomness obtained
  2436. ** from the xRandomness method of the default [sqlite3_vfs] object.
  2437. ** ^On all subsequent invocations, the pseudo-randomness is generated
  2438. ** internally and without recourse to the [sqlite3_vfs] xRandomness
  2439. ** method.
  2440. */
  2441. //SQLITE_API void sqlite3_randomness(int N, object *P);
  2442. /*
  2443. ** CAPI3REF: Compile-Time Authorization Callbacks
  2444. **
  2445. ** ^This routine registers an authorizer callback with a particular
  2446. ** [database connection], supplied in the first argument.
  2447. ** ^The authorizer callback is invoked as SQL statements are being compiled
  2448. ** by [sqlite3_prepare()] or its variants [sqlite3_prepare_v2()],
  2449. ** [sqlite3_prepare16()] and [sqlite3_prepare16_v2()]. ^At various
  2450. ** points during the compilation process, as logic is being created
  2451. ** to perform various actions, the authorizer callback is invoked to
  2452. ** see if those actions are allowed. ^The authorizer callback should
  2453. ** return [SQLITE_OK] to allow the action, [SQLITE_IGNORE] to disallow the
  2454. ** specific action but allow the SQL statement to continue to be
  2455. ** compiled, or [SQLITE_DENY] to cause the entire SQL statement to be
  2456. ** rejected with an error. ^If the authorizer callback returns
  2457. ** any value other than [SQLITE_IGNORE], [SQLITE_OK], or [SQLITE_DENY]
  2458. ** then the [sqlite3_prepare_v2()] or equivalent call that triggered
  2459. ** the authorizer will fail with an error message.
  2460. **
  2461. ** When the callback returns [SQLITE_OK], that means the operation
  2462. ** requested is ok. ^When the callback returns [SQLITE_DENY], the
  2463. ** [sqlite3_prepare_v2()] or equivalent call that triggered the
  2464. ** authorizer will fail with an error message explaining that
  2465. ** access is denied.
  2466. **
  2467. ** ^The first parameter to the authorizer callback is a copy of the third
  2468. ** parameter to the sqlite3_set_authorizer() interface. ^The second parameter
  2469. ** to the callback is an integer [SQLITE_COPY | action code] that specifies
  2470. ** the particular action to be authorized. ^The third through sixth parameters
  2471. ** to the callback are zero-terminated strings that contain additional
  2472. ** details about the action to be authorized.
  2473. **
  2474. ** ^If the action code is [SQLITE_READ]
  2475. ** and the callback returns [SQLITE_IGNORE] then the
  2476. ** [prepared statement] statement is constructed to substitute
  2477. ** a NULL value in place of the table column that would have
  2478. ** been read if [SQLITE_OK] had been returned. The [SQLITE_IGNORE]
  2479. ** return can be used to deny an untrusted user access to individual
  2480. ** columns of a table.
  2481. ** ^If the action code is [SQLITE_DELETE] and the callback returns
  2482. ** [SQLITE_IGNORE] then the [DELETE] operation proceeds but the
  2483. ** [truncate optimization] is disabled and all rows are deleted individually.
  2484. **
  2485. ** An authorizer is used when [sqlite3_prepare | preparing]
  2486. ** SQL statements from an untrusted source, to ensure that the SQL statements
  2487. ** do not try to access data they are not allowed to see, or that they do not
  2488. ** try to execute malicious statements that damage the database. For
  2489. ** example, an application may allow a user to enter arbitrary
  2490. ** SQL queries for evaluation by a database. But the application does
  2491. ** not want the user to be able to make arbitrary changes to the
  2492. ** database. An authorizer could then be put in place while the
  2493. ** user-entered SQL is being [sqlite3_prepare | prepared] that
  2494. ** disallows everything except [SELECT] statements.
  2495. **
  2496. ** Applications that need to process SQL from untrusted sources
  2497. ** might also consider lowering resource limits using [sqlite3_limit()]
  2498. ** and limiting database size using the [max_page_count] [PRAGMA]
  2499. ** in addition to using an authorizer.
  2500. **
  2501. ** ^(Only a single authorizer can be in place on a database connection
  2502. ** at a time. Each call to sqlite3_set_authorizer overrides the
  2503. ** previous call.)^ ^Disable the authorizer by installing a NULL callback.
  2504. ** The authorizer is disabled by default.
  2505. **
  2506. ** The authorizer callback must not do anything that will modify
  2507. ** the database connection that invoked the authorizer callback.
  2508. ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their
  2509. ** database connections for the meaning of "modify" in this paragraph.
  2510. **
  2511. ** ^When [sqlite3_prepare_v2()] is used to prepare a statement, the
  2512. ** statement might be re-prepared during [sqlite3_step()] due to a
  2513. ** schema change. Hence, the application should ensure that the
  2514. ** correct authorizer callback remains in place during the [sqlite3_step()].
  2515. **
  2516. ** ^Note that the authorizer callback is invoked only during
  2517. ** [sqlite3_prepare()] or its variants. Authorization is not
  2518. ** performed during statement evaluation in [sqlite3_step()], unless
  2519. ** as stated in the previous paragraph, sqlite3_step() invokes
  2520. ** sqlite3_prepare_v2() to reprepare a statement after a schema change.
  2521. */
  2522. //SQLITE_API int sqlite3_set_authorizer(
  2523. // sqlite3*,
  2524. // int (*xAuth)(void*,int,const char*,const char*,const char*,const char),
  2525. // void *pUserData
  2526. //);
  2527. /*
  2528. ** CAPI3REF: Authorizer Return Codes
  2529. **
  2530. ** The [sqlite3_set_authorizer | authorizer callback function] must
  2531. ** return either [SQLITE_OK] or one of these two constants in order
  2532. ** to signal SQLite whether or not the action is permitted. See the
  2533. ** [sqlite3_set_authorizer | authorizer documentation] for additional
  2534. ** information.
  2535. **
  2536. ** Note that SQLITE_IGNORE is also used as a [SQLITE_ROLLBACK | return code]
  2537. ** from the [sqlite3_vtab_on_conflict()] interface.
  2538. */
  2539. //#define SQLITE_DENY 1 /* Abort the SQL statement with an error */
  2540. //#define SQLITE_IGNORE 2 /* Don't allow access, but don't generate an error */
  2541. const int SQLITE_DENY = 1;
  2542. const int SQLITE_IGNORE = 2;
  2543. /*
  2544. ** CAPI3REF: Authorizer Action Codes
  2545. **
  2546. ** The [sqlite3_set_authorizer()] interface registers a callback function
  2547. ** that is invoked to authorize certain SQL statement actions. The
  2548. ** second parameter to the callback is an integer code that specifies
  2549. ** what action is being authorized. These are the integer action codes that
  2550. ** the authorizer callback may be passed.
  2551. **
  2552. ** These action code values signify what kind of operation is to be
  2553. ** authorized. The 3rd and 4th parameters to the authorization
  2554. ** callback function will be parameters or NULL depending on which of these
  2555. ** codes is used as the second parameter. ^(The 5th parameter to the
  2556. ** authorizer callback is the name of the database ("main", "temp",
  2557. ** etc.) if applicable.)^ ^The 6th parameter to the authorizer callback
  2558. ** is the name of the inner-most trigger or view that is responsible for
  2559. ** the access attempt or NULL if this access attempt is directly from
  2560. ** top-level SQL code.
  2561. */
  2562. /******************************************* 3rd ************ 4th ***********/
  2563. //#define SQLITE_CREATE_INDEX 1 /* Index Name Table Name */
  2564. //#define SQLITE_CREATE_TABLE 2 /* Table Name NULL */
  2565. //#define SQLITE_CREATE_TEMP_INDEX 3 /* Index Name Table Name */
  2566. //#define SQLITE_CREATE_TEMP_TABLE 4 /* Table Name NULL */
  2567. //#define SQLITE_CREATE_TEMP_TRIGGER 5 /* Trigger Name Table Name */
  2568. //#define SQLITE_CREATE_TEMP_VIEW 6 /* View Name NULL */
  2569. //#define SQLITE_CREATE_TRIGGER 7 /* Trigger Name Table Name */
  2570. //#define SQLITE_CREATE_VIEW 8 /* View Name NULL */
  2571. //#define SQLITE_DELETE 9 /* Table Name NULL */
  2572. //#define SQLITE_DROP_INDEX 10 /* Index Name Table Name */
  2573. //#define SQLITE_DROP_TABLE 11 /* Table Name NULL */
  2574. //#define SQLITE_DROP_TEMP_INDEX 12 /* Index Name Table Name */
  2575. //#define SQLITE_DROP_TEMP_TABLE 13 /* Table Name NULL */
  2576. //#define SQLITE_DROP_TEMP_TRIGGER 14 /* Trigger Name Table Name */
  2577. //#define SQLITE_DROP_TEMP_VIEW 15 /* View Name NULL */
  2578. //#define SQLITE_DROP_TRIGGER 16 /* Trigger Name Table Name */
  2579. //#define SQLITE_DROP_VIEW 17 /* View Name NULL */
  2580. //#define SQLITE_INSERT 18 /* Table Name NULL */
  2581. //#define SQLITE_PRAGMA 19 /* Pragma Name 1st arg or NULL */
  2582. //#define SQLITE_READ 20 /* Table Name Column Name */
  2583. //#define SQLITE_SELECT 21 /* NULL NULL */
  2584. //#define SQLITE_TRANSACTION 22 /* Operation NULL */
  2585. //#define SQLITE_UPDATE 23 /* Table Name Column Name */
  2586. //#define SQLITE_ATTACH 24 /* Filename NULL */
  2587. //#define SQLITE_DETACH 25 /* Database Name NULL */
  2588. //#define SQLITE_ALTER_TABLE 26 /* Database Name Table Name */
  2589. //#define SQLITE_REINDEX 27 /* Index Name NULL */
  2590. //#define SQLITE_ANALYZE 28 /* Table Name NULL */
  2591. //#define SQLITE_CREATE_VTABLE 29 /* Table Name Module Name */
  2592. //#define SQLITE_DROP_VTABLE 30 /* Table Name Module Name */
  2593. //#define SQLITE_FUNCTION 31 /* NULL Function Name */
  2594. //#define SQLITE_SAVEPOINT 32 /* Operation Savepoint Name */
  2595. //#define SQLITE_COPY 0 /* No longer used */
  2596. const int SQLITE_CREATE_INDEX = 1;
  2597. const int SQLITE_CREATE_TABLE = 2;
  2598. const int SQLITE_CREATE_TEMP_INDEX = 3;
  2599. const int SQLITE_CREATE_TEMP_TABLE = 4;
  2600. const int SQLITE_CREATE_TEMP_TRIGGER = 5;
  2601. const int SQLITE_CREATE_TEMP_VIEW = 6;
  2602. const int SQLITE_CREATE_TRIGGER = 7;
  2603. const int SQLITE_CREATE_VIEW = 8;
  2604. const int SQLITE_DELETE = 9;
  2605. const int SQLITE_DROP_INDEX = 10;
  2606. const int SQLITE_DROP_TABLE = 11;
  2607. const int SQLITE_DROP_TEMP_INDEX = 12;
  2608. const int SQLITE_DROP_TEMP_TABLE = 13;
  2609. const int SQLITE_DROP_TEMP_TRIGGER = 14;
  2610. const int SQLITE_DROP_TEMP_VIEW = 15;
  2611. const int SQLITE_DROP_TRIGGER = 16;
  2612. const int SQLITE_DROP_VIEW = 17;
  2613. const int SQLITE_INSERT = 18;
  2614. const int SQLITE_PRAGMA = 19;
  2615. const int SQLITE_READ = 20;
  2616. const int SQLITE_SELECT = 21;
  2617. const int SQLITE_TRANSACTION = 22;
  2618. const int SQLITE_UPDATE = 23;
  2619. const int SQLITE_ATTACH = 24;
  2620. const int SQLITE_DETACH = 25;
  2621. const int SQLITE_ALTER_TABLE = 26;
  2622. const int SQLITE_REINDEX = 27;
  2623. const int SQLITE_ANALYZE = 28;
  2624. const int SQLITE_CREATE_VTABLE = 29;
  2625. const int SQLITE_DROP_VTABLE = 30;
  2626. const int SQLITE_FUNCTION = 31;
  2627. const int SQLITE_SAVEPOINT = 32;
  2628. const int SQLITE_COPY = 0;
  2629. /*
  2630. ** CAPI3REF: Tracing And Profiling Functions
  2631. **
  2632. ** These routines register callback functions that can be used for
  2633. ** tracing and profiling the execution of SQL statements.
  2634. **
  2635. ** ^The callback function registered by sqlite3_trace() is invoked at
  2636. ** various times when an SQL statement is being run by [sqlite3_step()].
  2637. ** ^The sqlite3_trace() callback is invoked with a UTF-8 rendering of the
  2638. ** SQL statement text as the statement first begins executing.
  2639. ** ^(Additional sqlite3_trace() callbacks might occur
  2640. ** as each triggered subprogram is entered. The callbacks for triggers
  2641. ** contain a UTF-8 SQL comment that identifies the trigger.)^
  2642. **
  2643. ** ^The callback function registered by sqlite3_profile() is invoked
  2644. ** as each SQL statement finishes. ^The profile callback contains
  2645. ** the original statement text and an estimate of wall-clock time
  2646. ** of how long that statement took to run. ^The profile callback
  2647. ** time is in units of nanoseconds, however the current implementation
  2648. ** is only capable of millisecond resolution so the six least significant
  2649. ** digits in the time are meaningless. Future versions of SQLite
  2650. ** might provide greater resolution on the profiler callback. The
  2651. ** sqlite3_profile() function is considered experimental and is
  2652. ** subject to change in future versions of SQLite.
  2653. */
  2654. //SQLITE_API void *sqlite3_trace(sqlite3*, void(*xTrace)(void*,const char), void);
  2655. //SQLITE_API SQLITE_EXPERIMENTAL void *sqlite3_profile(sqlite3*,
  2656. // void(*xProfile)(void*,const char*,sqlite3_uint64), void);
  2657. /*
  2658. ** CAPI3REF: Query Progress Callbacks
  2659. **
  2660. ** ^The sqlite3_progress_handler(D,N,X,P) interface causes the callback
  2661. ** function X to be invoked periodically during long running calls to
  2662. ** [sqlite3_exec()], [sqlite3_step()] and [sqlite3_get_table()] for
  2663. ** database connection D. An example use for this
  2664. ** interface is to keep a GUI updated during a large query.
  2665. **
  2666. ** ^The parameter P is passed through as the only parameter to the
  2667. ** callback function X. ^The parameter N is the number of
  2668. ** [virtual machine instructions] that are evaluated between successive
  2669. ** invocations of the callback X.
  2670. **
  2671. ** ^Only a single progress handler may be defined at one time per
  2672. ** [database connection]; setting a new progress handler cancels the
  2673. ** old one. ^Setting parameter X to NULL disables the progress handler.
  2674. ** ^The progress handler is also disabled by setting N to a value less
  2675. ** than 1.
  2676. **
  2677. ** ^If the progress callback returns non-zero, the operation is
  2678. ** interrupted. This feature can be used to implement a
  2679. ** "Cancel" button on a GUI progress dialog box.
  2680. **
  2681. ** The progress handler callback must not do anything that will modify
  2682. ** the database connection that invoked the progress handler.
  2683. ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their
  2684. ** database connections for the meaning of "modify" in this paragraph.
  2685. **
  2686. */
  2687. //SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int()(void), void);
  2688. /*
  2689. ** CAPI3REF: Opening A New Database Connection
  2690. **
  2691. ** ^These routines open an SQLite database file as specified by the
  2692. ** filename argument. ^The filename argument is interpreted as UTF-8 for
  2693. ** sqlite3_open() and sqlite3_open_v2() and as UTF-16 in the native byte
  2694. ** order for sqlite3_open16(). ^(A [database connection] handle is usually
  2695. ** returned in *ppDb, even if an error occurs. The only exception is that
  2696. ** if SQLite is unable to allocate memory to hold the [sqlite3] object,
  2697. ** a NULL will be written into *ppDb instead of a pointer to the [sqlite3]
  2698. ** object.)^ ^(If the database is opened (and/or created) successfully, then
  2699. ** [SQLITE_OK] is returned. Otherwise an [error code] is returned.)^ ^The
  2700. ** [sqlite3_errmsg()] or [sqlite3_errmsg16()] routines can be used to obtain
  2701. ** an English language description of the error following a failure of any
  2702. ** of the sqlite3_open() routines.
  2703. **
  2704. ** ^The default encoding for the database will be UTF-8 if
  2705. ** sqlite3_open() or sqlite3_open_v2() is called and
  2706. ** UTF-16 in the native byte order if sqlite3_open16() is used.
  2707. **
  2708. ** Whether or not an error occurs when it is opened, resources
  2709. ** associated with the [database connection] handle should be released by
  2710. ** passing it to [sqlite3_close()] when it is no longer required.
  2711. **
  2712. ** The sqlite3_open_v2() interface works like sqlite3_open()
  2713. ** except that it accepts two additional parameters for additional control
  2714. ** over the new database connection. ^(The flags parameter to
  2715. ** sqlite3_open_v2() can take one of
  2716. ** the following three values, optionally combined with the
  2717. ** [SQLITE_OPEN_NOMUTEX], [SQLITE_OPEN_FULLMUTEX], [SQLITE_OPEN_SHAREDCACHE],
  2718. ** [SQLITE_OPEN_PRIVATECACHE], and/or [SQLITE_OPEN_URI] flags:)^
  2719. **
  2720. ** <dl>
  2721. ** ^(<dt>[SQLITE_OPEN_READONLY]</dt>
  2722. ** <dd>The database is opened in read-only mode. If the database does not
  2723. ** already exist, an error is returned.</dd>)^
  2724. **
  2725. ** ^(<dt>[SQLITE_OPEN_READWRITE]</dt>
  2726. ** <dd>The database is opened for reading and writing if possible, or reading
  2727. ** only if the file is write protected by the operating system. In either
  2728. ** case the database must already exist, otherwise an error is returned.</dd>)^
  2729. **
  2730. ** ^(<dt>[SQLITE_OPEN_READWRITE] | [SQLITE_OPEN_CREATE]</dt>
  2731. ** <dd>The database is opened for reading and writing, and is created if
  2732. ** it does not already exist. This is the behavior that is always used for
  2733. ** sqlite3_open() and sqlite3_open16().</dd>)^
  2734. ** </dl>
  2735. **
  2736. ** If the 3rd parameter to sqlite3_open_v2() is not one of the
  2737. ** combinations shown above optionally combined with other
  2738. ** [SQLITE_OPEN_READONLY | SQLITE_OPEN_* bits]
  2739. ** then the behavior is undefined.
  2740. **
  2741. ** ^If the [SQLITE_OPEN_NOMUTEX] flag is set, then the database connection
  2742. ** opens in the multi-thread [threading mode] as long as the single-thread
  2743. ** mode has not been set at compile-time or start-time. ^If the
  2744. ** [SQLITE_OPEN_FULLMUTEX] flag is set then the database connection opens
  2745. ** in the serialized [threading mode] unless single-thread was
  2746. ** previously selected at compile-time or start-time.
  2747. ** ^The [SQLITE_OPEN_SHAREDCACHE] flag causes the database connection to be
  2748. ** eligible to use [shared cache mode], regardless of whether or not shared
  2749. ** cache is enabled using [sqlite3_enable_shared_cache()]. ^The
  2750. ** [SQLITE_OPEN_PRIVATECACHE] flag causes the database connection to not
  2751. ** participate in [shared cache mode] even if it is enabled.
  2752. **
  2753. ** ^The fourth parameter to sqlite3_open_v2() is the name of the
  2754. ** [sqlite3_vfs] object that defines the operating system interface that
  2755. ** the new database connection should use. ^If the fourth parameter is
  2756. ** a NULL pointer then the default [sqlite3_vfs] object is used.
  2757. **
  2758. ** ^If the filename is ":memory:", then a private, temporary in-memory database
  2759. ** is created for the connection. ^This in-memory database will vanish when
  2760. ** the database connection is closed. Future versions of SQLite might
  2761. ** make use of additional special filenames that begin with the ":" character.
  2762. ** It is recommended that when a database filename actually does begin with
  2763. ** a ":" character you should prefix the filename with a pathname such as
  2764. ** "./" to avoid ambiguity.
  2765. **
  2766. ** ^If the filename is an empty string, then a private, temporary
  2767. ** on-disk database will be created. ^This private database will be
  2768. ** automatically deleted as soon as the database connection is closed.
  2769. **
  2770. ** [[URI filenames in sqlite3_open()]] <h3>URI Filenames</h3>
  2771. **
  2772. ** ^If [URI filename] interpretation is enabled, and the filename argument
  2773. ** begins with "file:", then the filename is interpreted as a URI. ^URI
  2774. ** filename interpretation is enabled if the [SQLITE_OPEN_URI] flag is
  2775. ** set in the fourth argument to sqlite3_open_v2(), or if it has
  2776. ** been enabled globally using the [SQLITE_CONFIG_URI] option with the
  2777. ** [sqlite3_config()] method or by the [SQLITE_USE_URI] compile-time option.
  2778. ** As of SQLite version 3.7.7, URI filename interpretation is turned off
  2779. ** by default, but future releases of SQLite might enable URI filename
  2780. ** interpretation by default. See "[URI filenames]" for additional
  2781. ** information.
  2782. **
  2783. ** URI filenames are parsed according to RFC 3986. ^If the URI contains an
  2784. ** authority, then it must be either an empty string or the string
  2785. ** "localhost". ^If the authority is not an empty string or "localhost", an
  2786. ** error is returned to the caller. ^The fragment component of a URI, if
  2787. ** present, is ignored.
  2788. **
  2789. ** ^SQLite uses the path component of the URI as the name of the disk file
  2790. ** which contains the database. ^If the path begins with a '/' character,
  2791. ** then it is interpreted as an absolute path. ^If the path does not begin
  2792. ** with a '/' (meaning that the authority section is omitted from the URI)
  2793. ** then the path is interpreted as a relative path.
  2794. ** ^On windows, the first component of an absolute path
  2795. ** is a drive specification (e.g. "C:").
  2796. **
  2797. ** [[core URI query parameters]]
  2798. ** The query component of a URI may contain parameters that are interpreted
  2799. ** either by SQLite itself, or by a [VFS | custom VFS implementation].
  2800. ** SQLite interprets the following three query parameters:
  2801. **
  2802. ** <ul>
  2803. ** <li> <b>vfs</b>: ^The "vfs" parameter may be used to specify the name of
  2804. ** a VFS object that provides the operating system interface that should
  2805. ** be used to access the database file on disk. ^If this option is set to
  2806. ** an empty string the default VFS object is used. ^Specifying an unknown
  2807. ** VFS is an error. ^If sqlite3_open_v2() is used and the vfs option is
  2808. ** present, then the VFS specified by the option takes precedence over
  2809. ** the value passed as the fourth parameter to sqlite3_open_v2().
  2810. **
  2811. ** <li> <b>mode</b>: ^(The mode parameter may be set to either "ro", "rw" or
  2812. ** "rwc". Attempting to set it to any other value is an error)^.
  2813. ** ^If "ro" is specified, then the database is opened for read-only
  2814. ** access, just as if the [SQLITE_OPEN_READONLY] flag had been set in the
  2815. ** third argument to sqlite3_prepare_v2(). ^If the mode option is set to
  2816. ** "rw", then the database is opened for read-write (but not create)
  2817. ** access, as if SQLITE_OPEN_READWRITE (but not SQLITE_OPEN_CREATE) had
  2818. ** been set. ^Value "rwc" is equivalent to setting both
  2819. ** SQLITE_OPEN_READWRITE and SQLITE_OPEN_CREATE. ^If sqlite3_open_v2() is
  2820. ** used, it is an error to specify a value for the mode parameter that is
  2821. ** less restrictive than that specified by the flags passed as the third
  2822. ** parameter.
  2823. **
  2824. ** <li> <b>cache</b>: ^The cache parameter may be set to either "shared" or
  2825. ** "private". ^Setting it to "shared" is equivalent to setting the
  2826. ** SQLITE_OPEN_SHAREDCACHE bit in the flags argument passed to
  2827. ** sqlite3_open_v2(). ^Setting the cache parameter to "private" is
  2828. ** equivalent to setting the SQLITE_OPEN_PRIVATECACHE bit.
  2829. ** ^If sqlite3_open_v2() is used and the "cache" parameter is present in
  2830. ** a URI filename, its value overrides any behaviour requested by setting
  2831. ** SQLITE_OPEN_PRIVATECACHE or SQLITE_OPEN_SHAREDCACHE flag.
  2832. ** </ul>
  2833. **
  2834. ** ^Specifying an unknown parameter in the query component of a URI is not an
  2835. ** error. Future versions of SQLite might understand additional query
  2836. ** parameters. See "[query parameters with special meaning to SQLite]" for
  2837. ** additional information.
  2838. **
  2839. ** [[URI filename examples]] <h3>URI filename examples</h3>
  2840. **
  2841. ** <table border="1" align=center cellpadding=5>
  2842. ** <tr><th> URI filenames <th> Results
  2843. ** <tr><td> file:data.db <td>
  2844. ** Open the file "data.db" in the current directory.
  2845. ** <tr><td> file:/home/fred/data.db<br>
  2846. ** file:///home/fred/data.db <br>
  2847. ** file://localhost/home/fred/data.db <br> <td>
  2848. ** Open the database file "/home/fred/data.db".
  2849. ** <tr><td> file://darkstar/home/fred/data.db <td>
  2850. ** An error. "darkstar" is not a recognized authority.
  2851. ** <tr><td style="white-space:nowrap">
  2852. ** file:///C:/Documents%20and%20Settings/fred/Desktop/data.db
  2853. ** <td> Windows only: Open the file "data.db" on fred's desktop on drive
  2854. ** C:. Note that the %20 escaping in this example is not strictly
  2855. ** necessary - space characters can be used literally
  2856. ** in URI filenames.
  2857. ** <tr><td> file:data.db?mode=ro&cache=private <td>
  2858. ** Open file "data.db" in the current directory for read-only access.
  2859. ** Regardless of whether or not shared-cache mode is enabled by
  2860. ** default, use a private cache.
  2861. ** <tr><td> file:/home/fred/data.db?vfs=unix-nolock <td>
  2862. ** Open file "/home/fred/data.db". Use the special VFS "unix-nolock".
  2863. ** <tr><td> file:data.db?mode=readonly <td>
  2864. ** An error. "readonly" is not a valid option for the "mode" parameter.
  2865. ** </table>
  2866. **
  2867. ** ^URI hexadecimal escape sequences (%HH) are supported within the path and
  2868. ** query components of a URI. A hexadecimal escape sequence consists of a
  2869. ** percent sign - "%" - followed by exactly two hexadecimal digits
  2870. ** specifying an octet value. ^Before the path or query components of a
  2871. ** URI filename are interpreted, they are encoded using UTF-8 and all
  2872. ** hexadecimal escape sequences replaced by a single byte containing the
  2873. ** corresponding octet. If this process generates an invalid UTF-8 encoding,
  2874. ** the results are undefined.
  2875. **
  2876. ** <b>Note to Windows users:</b> The encoding used for the filename argument
  2877. ** of sqlite3_open() and sqlite3_open_v2() must be UTF-8, not whatever
  2878. ** codepage is currently defined. Filenames containing international
  2879. ** characters must be converted to UTF-8 prior to passing them into
  2880. ** sqlite3_open() or sqlite3_open_v2().
  2881. */
  2882. //SQLITE_API int sqlite3_open(
  2883. // string filename, /* Database filename (UTF-8) */
  2884. // sqlite3 **ppDb /* OUT: SQLite db handle */
  2885. //);
  2886. //SQLITE_API int sqlite3_open16(
  2887. // const void *filename, /* Database filename (UTF-16) */
  2888. // sqlite3 **ppDb /* OUT: SQLite db handle */
  2889. //);
  2890. //SQLITE_API int sqlite3_open_v2(
  2891. // string filename, /* Database filename (UTF-8) */
  2892. // sqlite3 **ppDb, /* OUT: SQLite db handle */
  2893. // int flags, /* Flags */
  2894. // string zVfs /* Name of VFS module to use */
  2895. //);
  2896. /*
  2897. ** CAPI3REF: Obtain Values For URI Parameters
  2898. **
  2899. ** This is a utility routine, useful to VFS implementations, that checks
  2900. ** to see if a database file was a URI that contained a specific query
  2901. ** parameter, and if so obtains the value of the query parameter.
  2902. **
  2903. ** The zFilename argument is the filename pointer passed into the xOpen()
  2904. ** method of a VFS implementation. The zParam argument is the name of the
  2905. ** query parameter we seek. This routine returns the value of the zParam
  2906. ** parameter if it exists. If the parameter does not exist, this routine
  2907. ** returns a NULL pointer.
  2908. **
  2909. ** If the zFilename argument to this function is not a pointer that SQLite
  2910. ** passed into the xOpen VFS method, then the behavior of this routine
  2911. ** is undefined and probably undesirable.
  2912. */
  2913. //SQLITE_API string sqlite3_uri_parameter(string zFilename, string zParam);
  2914. /*
  2915. ** CAPI3REF: Error Codes And Messages
  2916. **
  2917. ** ^The sqlite3_errcode() interface returns the numeric [result code] or
  2918. ** [extended result code] for the most recent failed sqlite3_* API call
  2919. ** associated with a [database connection]. If a prior API call failed
  2920. ** but the most recent API call succeeded, the return value from
  2921. ** sqlite3_errcode() is undefined. ^The sqlite3_extended_errcode()
  2922. ** interface is the same except that it always returns the
  2923. ** [extended result code] even when extended result codes are
  2924. ** disabled.
  2925. **
  2926. ** ^The sqlite3_errmsg() and sqlite3_errmsg16() return English-language
  2927. ** text that describes the error, as either UTF-8 or UTF-16 respectively.
  2928. ** ^(Memory to hold the error message string is managed internally.
  2929. ** The application does not need to worry about freeing the result.
  2930. ** However, the error string might be overwritten or deallocated by
  2931. ** subsequent calls to other SQLite interface functions.)^
  2932. **
  2933. ** When the serialized [threading mode] is in use, it might be the
  2934. ** case that a second error occurs on a separate thread in between
  2935. ** the time of the first error and the call to these interfaces.
  2936. ** When that happens, the second error will be reported since these
  2937. ** interfaces always report the most recent result. To avoid
  2938. ** this, each thread can obtain exclusive use of the [database connection] D
  2939. ** by invoking [sqlite3_mutex_enter]([sqlite3_db_mutex](D)) before beginning
  2940. ** to use D and invoking [sqlite3_mutex_leave]([sqlite3_db_mutex](D)) after
  2941. ** all calls to the interfaces listed here are completed.
  2942. **
  2943. ** If an interface fails with SQLITE_MISUSE, that means the interface
  2944. ** was invoked incorrectly by the application. In that case, the
  2945. ** error code and message may or may not be set.
  2946. */
  2947. //SQLITE_API int sqlite3_errcode(sqlite3 db);
  2948. //SQLITE_API int sqlite3_extended_errcode(sqlite3 db);
  2949. //SQLITE_API string sqlite3_errmsg(sqlite3);
  2950. //SQLITE_API const void *sqlite3_errmsg16(sqlite3);
  2951. /*
  2952. ** CAPI3REF: SQL Statement Object
  2953. ** KEYWORDS: {prepared statement} {prepared statements}
  2954. **
  2955. ** An instance of this object represents a single SQL statement.
  2956. ** This object is variously known as a "prepared statement" or a
  2957. ** "compiled SQL statement" or simply as a "statement".
  2958. **
  2959. ** The life of a statement object goes something like this:
  2960. **
  2961. ** <ol>
  2962. ** <li> Create the object using [sqlite3_prepare_v2()] or a related
  2963. ** function.
  2964. ** <li> Bind values to [host parameters] using the sqlite3_bind_*()
  2965. ** interfaces.
  2966. ** <li> Run the SQL by calling [sqlite3_step()] one or more times.
  2967. ** <li> Reset the statement using [sqlite3_reset()] then go back
  2968. ** to step 2. Do this zero or more times.
  2969. ** <li> Destroy the object using [sqlite3_finalize()].
  2970. ** </ol>
  2971. **
  2972. ** Refer to documentation on individual methods above for additional
  2973. ** information.
  2974. */
  2975. //typedef struct sqlite3_stmt sqlite3_stmt;
  2976. /*
  2977. ** CAPI3REF: Run-time Limits
  2978. **
  2979. ** ^(This interface allows the size of various constructs to be limited
  2980. ** on a connection by connection basis. The first parameter is the
  2981. ** [database connection] whose limit is to be set or queried. The
  2982. ** second parameter is one of the [limit categories] that define a
  2983. ** class of constructs to be size limited. The third parameter is the
  2984. ** new limit for that construct.)^
  2985. **
  2986. ** ^If the new limit is a negative number, the limit is unchanged.
  2987. ** ^(For each limit category SQLITE_LIMIT_<i>NAME</i> there is a
  2988. ** [limits | hard upper bound]
  2989. ** set at compile-time by a C preprocessor macro called
  2990. ** [limits | SQLITE_MAX_<i>NAME</i>].
  2991. ** (The "_LIMIT_" in the name is changed to "_MAX_".))^
  2992. ** ^Attempts to increase a limit above its hard upper bound are
  2993. ** silently truncated to the hard upper bound.
  2994. **
  2995. ** ^Regardless of whether or not the limit was changed, the
  2996. ** [sqlite3_limit()] interface returns the prior value of the limit.
  2997. ** ^Hence, to find the current value of a limit without changing it,
  2998. ** simply invoke this interface with the third parameter set to -1.
  2999. **
  3000. ** Run-time limits are intended for use in applications that manage
  3001. ** both their own internal database and also databases that are controlled
  3002. ** by untrusted external sources. An example application might be a
  3003. ** web browser that has its own databases for storing history and
  3004. ** separate databases controlled by JavaScript applications downloaded
  3005. ** off the Internet. The internal databases can be given the
  3006. ** large, default limits. Databases managed by external sources can
  3007. ** be given much smaller limits designed to prevent a denial of service
  3008. ** attack. Developers might also want to use the [sqlite3_set_authorizer()]
  3009. ** interface to further control untrusted SQL. The size of the database
  3010. ** created by an untrusted script can be contained using the
  3011. ** [max_page_count] [PRAGMA].
  3012. **
  3013. ** New run-time limit categories may be added in future releases.
  3014. */
  3015. //SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal);
  3016. /*
  3017. ** CAPI3REF: Run-Time Limit Categories
  3018. ** KEYWORDS: {limit category} {*limit categories}
  3019. **
  3020. ** These constants define various performance limits
  3021. ** that can be lowered at run-time using [sqlite3_limit()].
  3022. ** The synopsis of the meanings of the various limits is shown below.
  3023. ** Additional information is available at [limits | Limits in SQLite].
  3024. **
  3025. ** <dl>
  3026. ** [[SQLITE_LIMIT_LENGTH]] ^(<dt>SQLITE_LIMIT_LENGTH</dt>
  3027. ** <dd>The maximum size of any string or BLOB or table row, in bytes.<dd>)^
  3028. **
  3029. ** [[SQLITE_LIMIT_SQL_LENGTH]] ^(<dt>SQLITE_LIMIT_SQL_LENGTH</dt>
  3030. ** <dd>The maximum length of an SQL statement, in bytes.</dd>)^
  3031. **
  3032. ** [[SQLITE_LIMIT_COLUMN]] ^(<dt>SQLITE_LIMIT_COLUMN</dt>
  3033. ** <dd>The maximum number of columns in a table definition or in the
  3034. ** result set of a [SELECT] or the maximum number of columns in an index
  3035. ** or in an ORDER BY or GROUP BY clause.</dd>)^
  3036. **
  3037. ** [[SQLITE_LIMIT_EXPR_DEPTH]] ^(<dt>SQLITE_LIMIT_EXPR_DEPTH</dt>
  3038. ** <dd>The maximum depth of the parse tree on any expression.</dd>)^
  3039. **
  3040. ** [[SQLITE_LIMIT_COMPOUND_SELECT]] ^(<dt>SQLITE_LIMIT_COMPOUND_SELECT</dt>
  3041. ** <dd>The maximum number of terms in a compound SELECT statement.</dd>)^
  3042. **
  3043. ** [[SQLITE_LIMIT_VDBE_OP]] ^(<dt>SQLITE_LIMIT_VDBE_OP</dt>
  3044. ** <dd>The maximum number of instructions in a virtual machine program
  3045. ** used to implement an SQL statement. This limit is not currently
  3046. ** enforced, though that might be added in some future release of
  3047. ** SQLite.</dd>)^
  3048. **
  3049. ** [[SQLITE_LIMIT_FUNCTION_ARG]] ^(<dt>SQLITE_LIMIT_FUNCTION_ARG</dt>
  3050. ** <dd>The maximum number of arguments on a function.</dd>)^
  3051. **
  3052. ** [[SQLITE_LIMIT_ATTACHED]] ^(<dt>SQLITE_LIMIT_ATTACHED</dt>
  3053. ** <dd>The maximum number of [ATTACH | attached databases].)^</dd>
  3054. **
  3055. ** [[SQLITE_LIMIT_LIKE_PATTERN_LENGTH]]
  3056. ** ^(<dt>SQLITE_LIMIT_LIKE_PATTERN_LENGTH</dt>
  3057. ** <dd>The maximum length of the pattern argument to the [LIKE] or
  3058. ** [GLOB] operators.</dd>)^
  3059. **
  3060. ** [[SQLITE_LIMIT_VARIABLE_NUMBER]]
  3061. ** ^(<dt>SQLITE_LIMIT_VARIABLE_NUMBER</dt>
  3062. ** <dd>The maximum index number of any [parameter] in an SQL statement.)^
  3063. **
  3064. ** [[SQLITE_LIMIT_TRIGGER_DEPTH]] ^(<dt>SQLITE_LIMIT_TRIGGER_DEPTH</dt>
  3065. ** <dd>The maximum depth of recursion for triggers.</dd>)^
  3066. ** </dl>
  3067. */
  3068. //#define SQLITE_LIMIT_LENGTH 0
  3069. //#define SQLITE_LIMIT_SQL_LENGTH 1
  3070. //#define SQLITE_LIMIT_COLUMN 2
  3071. //#define SQLITE_LIMIT_EXPR_DEPTH 3
  3072. //#define SQLITE_LIMIT_COMPOUND_SELECT 4
  3073. //#define SQLITE_LIMIT_VDBE_OP 5
  3074. //#define SQLITE_LIMIT_FUNCTION_ARG 6
  3075. //#define SQLITE_LIMIT_ATTACHED 7
  3076. //#define SQLITE_LIMIT_LIKE_PATTERN_LENGTH 8
  3077. //#define SQLITE_LIMIT_VARIABLE_NUMBER 9
  3078. //#define SQLITE_LIMIT_TRIGGER_DEPTH 10
  3079. const int SQLITE_LIMIT_LENGTH = 0;
  3080. const int SQLITE_LIMIT_SQL_LENGTH = 1;
  3081. const int SQLITE_LIMIT_COLUMN = 2;
  3082. const int SQLITE_LIMIT_EXPR_DEPTH = 3;
  3083. const int SQLITE_LIMIT_COMPOUND_SELECT = 4;
  3084. const int SQLITE_LIMIT_VDBE_OP = 5;
  3085. const int SQLITE_LIMIT_FUNCTION_ARG = 6;
  3086. const int SQLITE_LIMIT_ATTACHED = 7;
  3087. const int SQLITE_LIMIT_LIKE_PATTERN_LENGTH = 8;
  3088. const int SQLITE_LIMIT_VARIABLE_NUMBER = 9;
  3089. const int SQLITE_LIMIT_TRIGGER_DEPTH = 10;
  3090. /*
  3091. ** CAPI3REF: Compiling An SQL Statement
  3092. ** KEYWORDS: {SQL statement compiler}
  3093. **
  3094. ** To execute an SQL query, it must first be compiled into a byte-code
  3095. ** program using one of these routines.
  3096. **
  3097. ** The first argument, "db", is a [database connection] obtained from a
  3098. ** prior successful call to [sqlite3_open()], [sqlite3_open_v2()] or
  3099. ** [sqlite3_open16()]. The database connection must not have been closed.
  3100. **
  3101. ** The second argument, "zSql", is the statement to be compiled, encoded
  3102. ** as either UTF-8 or UTF-16. The sqlite3_prepare() and sqlite3_prepare_v2()
  3103. ** interfaces use UTF-8, and sqlite3_prepare16() and sqlite3_prepare16_v2()
  3104. ** use UTF-16.
  3105. **
  3106. ** ^If the nByte argument is less than zero, then zSql is read up to the
  3107. ** first zero terminator. ^If nByte is non-negative, then it is the maximum
  3108. ** number of bytes read from zSql. ^When nByte is non-negative, the
  3109. ** zSql string ends at either the first '\000' or '\u0000' character or
  3110. ** the nByte-th byte, whichever comes first. If the caller knows
  3111. ** that the supplied string is nul-terminated, then there is a small
  3112. ** performance advantage to be gained by passing an nByte parameter that
  3113. ** is equal to the number of bytes in the input string <i>including</i>
  3114. ** the nul-terminator bytes.
  3115. **
  3116. ** ^If pzTail is not NULL then *pzTail is made to point to the first byte
  3117. ** past the end of the first SQL statement in zSql. These routines only
  3118. ** compile the first statement in zSql, so *pzTail is left pointing to
  3119. ** what remains uncompiled.
  3120. **
  3121. ** ^*ppStmt is left pointing to a compiled [prepared statement] that can be
  3122. ** executed using [sqlite3_step()]. ^If there is an error, *ppStmt is set
  3123. ** to NULL. ^If the input text contains no SQL (if the input is an empty
  3124. ** string or a comment) then *ppStmt is set to NULL.
  3125. ** The calling procedure is responsible for deleting the compiled
  3126. ** SQL statement using [sqlite3_finalize()] after it has finished with it.
  3127. ** ppStmt may not be NULL.
  3128. **
  3129. ** ^On success, the sqlite3_prepare() family of routines return [SQLITE_OK];
  3130. ** otherwise an [error code] is returned.
  3131. **
  3132. ** The sqlite3_prepare_v2() and sqlite3_prepare16_v2() interfaces are
  3133. ** recommended for all new programs. The two older interfaces are retained
  3134. ** for backwards compatibility, but their use is discouraged.
  3135. ** ^In the "v2" interfaces, the prepared statement
  3136. ** that is returned (the [sqlite3_stmt] object) contains a copy of the
  3137. ** original SQL text. This causes the [sqlite3_step()] interface to
  3138. ** behave differently in three ways:
  3139. **
  3140. ** <ol>
  3141. ** <li>
  3142. ** ^If the database schema changes, instead of returning [SQLITE_SCHEMA] as it
  3143. ** always used to do, [sqlite3_step()] will automatically recompile the SQL
  3144. ** statement and try to run it again.
  3145. ** </li>
  3146. **
  3147. ** <li>
  3148. ** ^When an error occurs, [sqlite3_step()] will return one of the detailed
  3149. ** [error codes] or [extended error codes]. ^The legacy behavior was that
  3150. ** [sqlite3_step()] would only return a generic [SQLITE_ERROR] result code
  3151. ** and the application would have to make a second call to [sqlite3_reset()]
  3152. ** in order to find the underlying cause of the problem. With the "v2" prepare
  3153. ** interfaces, the underlying reason for the error is returned immediately.
  3154. ** </li>
  3155. **
  3156. ** <li>
  3157. ** ^If the specific value bound to [parameter | host parameter] in the
  3158. ** WHERE clause might influence the choice of query plan for a statement,
  3159. ** then the statement will be automatically recompiled, as if there had been
  3160. ** a schema change, on the first [sqlite3_step()] call following any change
  3161. ** to the [sqlite3_bind_text | bindings] of that [parameter].
  3162. ** ^The specific value of WHERE-clause [parameter] might influence the
  3163. ** choice of query plan if the parameter is the left-hand side of a [LIKE]
  3164. ** or [GLOB] operator or if the parameter is compared to an indexed column
  3165. ** and the [SQLITE_ENABLE_STAT2] compile-time option is enabled.
  3166. ** the
  3167. ** </li>
  3168. ** </ol>
  3169. */
  3170. //SQLITE_API int sqlite3_prepare(
  3171. // sqlite3 db, /* Database handle */
  3172. // string zSql, /* SQL statement, UTF-8 encoded */
  3173. // int nByte, /* Maximum length of zSql in bytes. */
  3174. // sqlite3_stmt **ppStmt, /* OUT: Statement handle */
  3175. // string *pzTail /* OUT: Pointer to unused portion of zSql */
  3176. //);
  3177. //SQLITE_API int sqlite3_prepare_v2(
  3178. // sqlite3 db, /* Database handle */
  3179. // string zSql, /* SQL statement, UTF-8 encoded */
  3180. // int nByte, /* Maximum length of zSql in bytes. */
  3181. // sqlite3_stmt **ppStmt, /* OUT: Statement handle */
  3182. // string *pzTail /* OUT: Pointer to unused portion of zSql */
  3183. //);
  3184. //SQLITE_API int sqlite3_prepare16(
  3185. // sqlite3 db, /* Database handle */
  3186. // string zSql, /* SQL statement, UTF-16 encoded */
  3187. // int nByte, /* Maximum length of zSql in bytes. */
  3188. // sqlite3_stmt **ppStmt, /* OUT: Statement handle */
  3189. // const void **pzTail /* OUT: Pointer to unused portion of zSql */
  3190. //);
  3191. //SQLITE_API int sqlite3_prepare16_v2(
  3192. // sqlite3 db, /* Database handle */
  3193. // string zSql, /* SQL statement, UTF-16 encoded */
  3194. // int nByte, /* Maximum length of zSql in bytes. */
  3195. // sqlite3_stmt **ppStmt, /* OUT: Statement handle */
  3196. // const void **pzTail /* OUT: Pointer to unused portion of zSql */
  3197. //);
  3198. /*
  3199. ** CAPI3REF: Retrieving Statement SQL
  3200. **
  3201. ** ^This interface can be used to retrieve a saved copy of the original
  3202. ** SQL text used to create a [prepared statement] if that statement was
  3203. ** compiled using either [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()].
  3204. */
  3205. //SQLITE_API string sqlite3_sql(sqlite3_stmt *pStmt);
  3206. /*
  3207. ** CAPI3REF: Determine If An SQL Statement Writes The Database
  3208. **
  3209. ** ^The sqlite3_stmt_readonly(X) interface returns true (non-zero) if
  3210. ** and only if the [prepared statement] X makes no direct changes to
  3211. ** the content of the database file.
  3212. **
  3213. ** Note that [application-defined SQL functions] or
  3214. ** [virtual tables] might change the database indirectly as a side effect.
  3215. ** ^(For example, if an application defines a function "eval()" that
  3216. ** calls [sqlite3_exec()], then the following SQL statement would
  3217. ** change the database file through side-effects:
  3218. **
  3219. ** <blockquote><pre>
  3220. ** SELECT eval('DELETE FROM t1') FROM t2;
  3221. ** </pre></blockquote>
  3222. **
  3223. ** But because the [SELECT] statement does not change the database file
  3224. ** directly, sqlite3_stmt_readonly() would still return true.)^
  3225. **
  3226. ** ^Transaction control statements such as [BEGIN], [COMMIT], [ROLLBACK],
  3227. ** [SAVEPOINT], and [RELEASE] cause sqlite3_stmt_readonly() to return true,
  3228. ** since the statements themselves do not actually modify the database but
  3229. ** rather they control the timing of when other statements modify the
  3230. ** database. ^The [ATTACH] and [DETACH] statements also cause
  3231. ** sqlite3_stmt_readonly() to return true since, while those statements
  3232. ** change the configuration of a database connection, they do not make
  3233. ** changes to the content of the database files on disk.
  3234. */
  3235. //SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
  3236. /*
  3237. ** CAPI3REF: Dynamically Typed Value Object
  3238. ** KEYWORDS: {protected sqlite3_value} {unprotected sqlite3_value}
  3239. **
  3240. ** SQLite uses the sqlite3_value object to represent all values
  3241. ** that can be stored in a database table. SQLite uses dynamic typing
  3242. ** for the values it stores. ^Values stored in sqlite3_value objects
  3243. ** can be integers, floating point values, strings, BLOBs, or NULL.
  3244. **
  3245. ** An sqlite3_value object may be either "protected" or "unprotected".
  3246. ** Some interfaces require a protected sqlite3_value. Other interfaces
  3247. ** will accept either a protected or an unprotected sqlite3_value.
  3248. ** Every interface that accepts sqlite3_value arguments specifies
  3249. ** whether or not it requires a protected sqlite3_value.
  3250. **
  3251. ** The terms "protected" and "unprotected" refer to whether or not
  3252. ** a mutex is held. An internal mutex is held for a protected
  3253. ** sqlite3_value object but no mutex is held for an unprotected
  3254. ** sqlite3_value object. If SQLite is compiled to be single-threaded
  3255. ** (with [SQLITE_THREADSAFE=0] and with [sqlite3_threadsafe()] returning 0)
  3256. ** or if SQLite is run in one of reduced mutex modes
  3257. ** [SQLITE_CONFIG_SINGLETHREAD] or [SQLITE_CONFIG_MULTITHREAD]
  3258. ** then there is no distinction between protected and unprotected
  3259. ** sqlite3_value objects and they can be used interchangeably. However,
  3260. ** for maximum code portability it is recommended that applications
  3261. ** still make the distinction between protected and unprotected
  3262. ** sqlite3_value objects even when not strictly required.
  3263. **
  3264. ** ^The sqlite3_value objects that are passed as parameters into the
  3265. ** implementation of [application-defined SQL functions] are protected.
  3266. ** ^The sqlite3_value object returned by
  3267. ** [sqlite3_column_value()] is unprotected.
  3268. ** Unprotected sqlite3_value objects may only be used with
  3269. ** [sqlite3_result_value()] and [sqlite3_bind_value()].
  3270. ** The [sqlite3_value_blob | sqlite3_value_type()] family of
  3271. ** interfaces require protected sqlite3_value objects.
  3272. */
  3273. //typedef struct Mem sqlite3_value;
  3274. /*
  3275. ** CAPI3REF: SQL Function Context Object
  3276. **
  3277. ** The context in which an SQL function executes is stored in an
  3278. ** sqlite3_context object. ^A pointer to an sqlite3_context object
  3279. ** is always first parameter to [application-defined SQL functions].
  3280. ** The application-defined SQL function implementation will pass this
  3281. ** pointer through into calls to [sqlite3_result_int | sqlite3_result()],
  3282. ** [sqlite3_aggregate_context()], [sqlite3_user_data()],
  3283. ** [sqlite3_context_db_handle()], [sqlite3_get_auxdata()],
  3284. ** and/or [sqlite3_set_auxdata()].
  3285. */
  3286. //typedef struct sqlite3_context sqlite3_context;
  3287. /*
  3288. ** CAPI3REF: Binding Values To Prepared Statements
  3289. ** KEYWORDS: {host parameter} {host parameters} {host parameter name}
  3290. ** KEYWORDS: {SQL parameter} {SQL parameters} {parameter binding}
  3291. **
  3292. ** ^(In the SQL statement text input to [sqlite3_prepare_v2()] and its variants,
  3293. ** literals may be replaced by a [parameter] that matches one of following
  3294. ** templates:
  3295. **
  3296. ** <ul>
  3297. ** <li> ?
  3298. ** <li> ?NNN
  3299. ** <li> :VVV
  3300. ** <li> @VVV
  3301. ** <li> $VVV
  3302. ** </ul>
  3303. **
  3304. ** In the templates above, NNN represents an integer literal,
  3305. ** and VVV represents an alphanumeric identifier.)^ ^The values of these
  3306. ** parameters (also called "host parameter names" or "SQL parameters")
  3307. ** can be set using the sqlite3_bind_*() routines defined here.
  3308. **
  3309. ** ^The first argument to the sqlite3_bind_*() routines is always
  3310. ** a pointer to the [sqlite3_stmt] object returned from
  3311. ** [sqlite3_prepare_v2()] or its variants.
  3312. **
  3313. ** ^The second argument is the index of the SQL parameter to be set.
  3314. ** ^The leftmost SQL parameter has an index of 1. ^When the same named
  3315. ** SQL parameter is used more than once, second and subsequent
  3316. ** occurrences have the same index as the first occurrence.
  3317. ** ^The index for named parameters can be looked up using the
  3318. ** [sqlite3_bind_parameter_index()] API if desired. ^The index
  3319. ** for "?NNN" parameters is the value of NNN.
  3320. ** ^The NNN value must be between 1 and the [sqlite3_limit()]
  3321. ** parameter [SQLITE_LIMIT_VARIABLE_NUMBER] (default value: 999).
  3322. **
  3323. ** ^The third argument is the value to bind to the parameter.
  3324. **
  3325. ** ^(In those routines that have a fourth argument, its value is the
  3326. ** number of bytes in the parameter. To be clear: the value is the
  3327. ** number of <u>bytes</u> in the value, not the number of characters.)^
  3328. ** ^If the fourth parameter is negative, the length of the string is
  3329. ** the number of bytes up to the first zero terminator.
  3330. **
  3331. ** ^The fifth argument to sqlite3_bind_blob(), sqlite3_bind_text(), and
  3332. ** sqlite3_bind_text16() is a destructor used to dispose of the BLOB or
  3333. ** string after SQLite has finished with it. ^The destructor is called
  3334. ** to dispose of the BLOB or string even if the call to sqlite3_bind_blob(),
  3335. ** sqlite3_bind_text(), or sqlite3_bind_text16() fails.
  3336. ** ^If the fifth argument is
  3337. ** the special value [SQLITE_STATIC], then SQLite assumes that the
  3338. ** information is in static, unmanaged space and does not need to be freed.
  3339. ** ^If the fifth argument has the value [SQLITE_TRANSIENT], then
  3340. ** SQLite makes its own private copy of the data immediately, before
  3341. ** the sqlite3_bind_*() routine returns.
  3342. **
  3343. ** ^The sqlite3_bind_zeroblob() routine binds a BLOB of length N that
  3344. ** is filled with zeroes. ^A zeroblob uses a fixed amount of memory
  3345. ** (just an integer to hold its size) while it is being processed.
  3346. ** Zeroblobs are intended to serve as placeholders for BLOBs whose
  3347. ** content is later written using
  3348. ** [sqlite3_blob_open | incremental BLOB I/O] routines.
  3349. ** ^A negative value for the zeroblob results in a zero-length BLOB.
  3350. **
  3351. ** ^If any of the sqlite3_bind_*() routines are called with a NULL pointer
  3352. ** for the [prepared statement] or with a prepared statement for which
  3353. ** [sqlite3_step()] has been called more recently than [sqlite3_reset()],
  3354. ** then the call will return [SQLITE_MISUSE]. If any sqlite3_bind_()
  3355. ** routine is passed a [prepared statement] that has been finalized, the
  3356. ** result is undefined and probably harmful.
  3357. **
  3358. ** ^Bindings are not cleared by the [sqlite3_reset()] routine.
  3359. ** ^Unbound parameters are interpreted as NULL.
  3360. **
  3361. ** ^The sqlite3_bind_* routines return [SQLITE_OK] on success or an
  3362. ** [error code] if anything goes wrong.
  3363. ** ^[SQLITE_RANGE] is returned if the parameter
  3364. ** index is out of range. ^[SQLITE_NOMEM] is returned if malloc() fails.
  3365. **
  3366. ** See also: [sqlite3_bind_parameter_count()],
  3367. ** [sqlite3_bind_parameter_name()], and [sqlite3_bind_parameter_index()].
  3368. */
  3369. //SQLITE_API int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void()(void));
  3370. //SQLITE_API int sqlite3_bind_double(sqlite3_stmt*, int, double);
  3371. //SQLITE_API int sqlite3_bind_int(sqlite3_stmt*, int, int);
  3372. //SQLITE_API int sqlite3_bind_int64(sqlite3_stmt*, int, sqlite3_int64);
  3373. //SQLITE_API int sqlite3_bind_null(sqlite3_stmt*, int);
  3374. //SQLITE_API int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int n, void()(void));
  3375. //SQLITE_API int sqlite3_bind_text16(sqlite3_stmt*, int, const void*, int, void()(void));
  3376. //SQLITE_API int sqlite3_bind_value(sqlite3_stmt*, int, const sqlite3_value);
  3377. //SQLITE_API int sqlite3_bind_zeroblob(sqlite3_stmt*, int, int n);
  3378. /*
  3379. ** CAPI3REF: Number Of SQL Parameters
  3380. **
  3381. ** ^This routine can be used to find the number of [SQL parameters]
  3382. ** in a [prepared statement]. SQL parameters are tokens of the
  3383. ** form "?", "?NNN", ":AAA", "$AAA", or "@AAA" that serve as
  3384. ** placeholders for values that are [sqlite3_bind_blob | bound]
  3385. ** to the parameters at a later time.
  3386. **
  3387. ** ^(This routine actually returns the index of the largest (rightmost)
  3388. ** parameter. For all forms except ?NNN, this will correspond to the
  3389. ** number of unique parameters. If parameters of the ?NNN form are used,
  3390. ** there may be gaps in the list.)^
  3391. **
  3392. ** See also: [sqlite3_bind_blob|sqlite3_bind()],
  3393. ** [sqlite3_bind_parameter_name()], and
  3394. ** [sqlite3_bind_parameter_index()].
  3395. */
  3396. //SQLITE_API int sqlite3_bind_parameter_count(sqlite3_stmt);
  3397. /*
  3398. ** CAPI3REF: Name Of A Host Parameter
  3399. **
  3400. ** ^The sqlite3_bind_parameter_name(P,N) interface returns
  3401. ** the name of the N-th [SQL parameter] in the [prepared statement] P.
  3402. ** ^(SQL parameters of the form "?NNN" or ":AAA" or "@AAA" or "$AAA"
  3403. ** have a name which is the string "?NNN" or ":AAA" or "@AAA" or "$AAA"
  3404. ** respectively.
  3405. ** In other words, the initial ":" or "$" or "@" or "?"
  3406. ** is included as part of the name.)^
  3407. ** ^Parameters of the form "?" without a following integer have no name
  3408. ** and are referred to as "nameless" or "anonymous parameters".
  3409. **
  3410. ** ^The first host parameter has an index of 1, not 0.
  3411. **
  3412. ** ^If the value N is out of range or if the N-th parameter is
  3413. ** nameless, then NULL is returned. ^The returned string is
  3414. ** always in UTF-8 encoding even if the named parameter was
  3415. ** originally specified as UTF-16 in [sqlite3_prepare16()] or
  3416. ** [sqlite3_prepare16_v2()].
  3417. **
  3418. ** See also: [sqlite3_bind_blob|sqlite3_bind()],
  3419. ** [sqlite3_bind_parameter_count()], and
  3420. ** [sqlite3_bind_parameter_index()].
  3421. */
  3422. //SQLITE_API string sqlite3_bind_parameter_name(sqlite3_stmt*, int);
  3423. /*
  3424. ** CAPI3REF: Index Of A Parameter With A Given Name
  3425. **
  3426. ** ^Return the index of an SQL parameter given its name. ^The
  3427. ** index value returned is suitable for use as the second
  3428. ** parameter to [sqlite3_bind_blob|sqlite3_bind()]. ^A zero
  3429. ** is returned if no matching parameter is found. ^The parameter
  3430. ** name must be given in UTF-8 even if the original statement
  3431. ** was prepared from UTF-16 text using [sqlite3_prepare16_v2()].
  3432. **
  3433. ** See also: [sqlite3_bind_blob|sqlite3_bind()],
  3434. ** [sqlite3_bind_parameter_count()], and
  3435. ** [sqlite3_bind_parameter_index()].
  3436. */
  3437. //SQLITE_API int sqlite3_bind_parameter_index(sqlite3_stmt*, string zName);
  3438. /*
  3439. ** CAPI3REF: Reset All Bindings On A Prepared Statement
  3440. **
  3441. ** ^Contrary to the intuition of many, [sqlite3_reset()] does not reset
  3442. ** the [sqlite3_bind_blob | bindings] on a [prepared statement].
  3443. ** ^Use this routine to reset all host parameters to NULL.
  3444. */
  3445. //SQLITE_API int sqlite3_clear_bindings(sqlite3_stmt);
  3446. /*
  3447. ** CAPI3REF: Number Of Columns In A Result Set
  3448. **
  3449. ** ^Return the number of columns in the result set returned by the
  3450. ** [prepared statement]. ^This routine returns 0 if pStmt is an SQL
  3451. ** statement that does not return data (for example an [UPDATE]).
  3452. **
  3453. ** See also: [sqlite3_data_count()]
  3454. */
  3455. //SQLITE_API int sqlite3_column_count(sqlite3_stmt *pStmt);
  3456. /*
  3457. ** CAPI3REF: Column Names In A Result Set
  3458. **
  3459. ** ^These routines return the name assigned to a particular column
  3460. ** in the result set of a [SELECT] statement. ^The sqlite3_column_name()
  3461. ** interface returns a pointer to a zero-terminated UTF-8 string
  3462. ** and sqlite3_column_name16() returns a pointer to a zero-terminated
  3463. ** UTF-16 string. ^The first parameter is the [prepared statement]
  3464. ** that implements the [SELECT] statement. ^The second parameter is the
  3465. ** column number. ^The leftmost column is number 0.
  3466. **
  3467. ** ^The returned string pointer is valid until either the [prepared statement]
  3468. ** is destroyed by [sqlite3_finalize()] or until the statement is automatically
  3469. ** reprepared by the first call to [sqlite3_step()] for a particular run
  3470. ** or until the next call to
  3471. ** sqlite3_column_name() or sqlite3_column_name16() on the same column.
  3472. **
  3473. ** ^If sqlite3_malloc() fails during the processing of either routine
  3474. ** (for example during a conversion from UTF-8 to UTF-16) then a
  3475. ** NULL pointer is returned.
  3476. **
  3477. ** ^The name of a result column is the value of the "AS" clause for
  3478. ** that column, if there is an AS clause. If there is no AS clause
  3479. ** then the name of the column is unspecified and may change from
  3480. ** one release of SQLite to the next.
  3481. */
  3482. //SQLITE_API string sqlite3_column_name(sqlite3_stmt*, int N);
  3483. //SQLITE_API const void *sqlite3_column_name16(sqlite3_stmt*, int N);
  3484. /*
  3485. ** CAPI3REF: Source Of Data In A Query Result
  3486. **
  3487. ** ^These routines provide a means to determine the database, table, and
  3488. ** table column that is the origin of a particular result column in
  3489. ** [SELECT] statement.
  3490. ** ^The name of the database or table or column can be returned as
  3491. ** either a UTF-8 or UTF-16 string. ^The _database_ routines return
  3492. ** the database name, the _table_ routines return the table name, and
  3493. ** the origin_ routines return the column name.
  3494. ** ^The returned string is valid until the [prepared statement] is destroyed
  3495. ** using [sqlite3_finalize()] or until the statement is automatically
  3496. ** reprepared by the first call to [sqlite3_step()] for a particular run
  3497. ** or until the same information is requested
  3498. ** again in a different encoding.
  3499. **
  3500. ** ^The names returned are the original un-aliased names of the
  3501. ** database, table, and column.
  3502. **
  3503. ** ^The first argument to these interfaces is a [prepared statement].
  3504. ** ^These functions return information about the Nth result column returned by
  3505. ** the statement, where N is the second function argument.
  3506. ** ^The left-most column is column 0 for these routines.
  3507. **
  3508. ** ^If the Nth column returned by the statement is an expression or
  3509. ** subquery and is not a column value, then all of these functions return
  3510. ** NULL. ^These routine might also return NULL if a memory allocation error
  3511. ** occurs. ^Otherwise, they return the name of the attached database, table,
  3512. ** or column that query result column was extracted from.
  3513. **
  3514. ** ^As with all other SQLite APIs, those whose names end with "16" return
  3515. ** UTF-16 encoded strings and the other functions return UTF-8.
  3516. **
  3517. ** ^These APIs are only available if the library was compiled with the
  3518. ** [SQLITE_ENABLE_COLUMN_METADATA] C-preprocessor symbol.
  3519. **
  3520. ** If two or more threads call one or more of these routines against the same
  3521. ** prepared statement and column at the same time then the results are
  3522. ** undefined.
  3523. **
  3524. ** If two or more threads call one or more
  3525. ** [sqlite3_column_database_name | column metadata interfaces]
  3526. ** for the same [prepared statement] and result column
  3527. ** at the same time then the results are undefined.
  3528. */
  3529. //SQLITE_API string sqlite3_column_database_name(sqlite3_stmt*,int);
  3530. //SQLITE_API const void *sqlite3_column_database_name16(sqlite3_stmt*,int);
  3531. //SQLITE_API string sqlite3_column_table_name(sqlite3_stmt*,int);
  3532. //SQLITE_API const void *sqlite3_column_table_name16(sqlite3_stmt*,int);
  3533. //SQLITE_API string sqlite3_column_origin_name(sqlite3_stmt*,int);
  3534. //SQLITE_API const void *sqlite3_column_origin_name16(sqlite3_stmt*,int);
  3535. /*
  3536. ** CAPI3REF: Declared Datatype Of A Query Result
  3537. **
  3538. ** ^(The first parameter is a [prepared statement].
  3539. ** If this statement is a [SELECT] statement and the Nth column of the
  3540. ** returned result set of that [SELECT] is a table column (not an
  3541. ** expression or subquery) then the declared type of the table
  3542. ** column is returned.)^ ^If the Nth column of the result set is an
  3543. ** expression or subquery, then a NULL pointer is returned.
  3544. ** ^The returned string is always UTF-8 encoded.
  3545. **
  3546. ** ^(For example, given the database schema:
  3547. **
  3548. ** CREATE TABLE t1(c1 VARIANT);
  3549. **
  3550. ** and the following statement to be compiled:
  3551. **
  3552. ** SELECT c1 + 1, c1 FROM t1;
  3553. **
  3554. ** this routine would return the string "VARIANT" for the second result
  3555. ** column (i==1), and a NULL pointer for the first result column (i==0).)^
  3556. **
  3557. ** ^SQLite uses dynamic run-time typing. ^So just because a column
  3558. ** is declared to contain a particular type does not mean that the
  3559. ** data stored in that column is of the declared type. SQLite is
  3560. ** strongly typed, but the typing is dynamic not static. ^Type
  3561. ** is associated with individual values, not with the containers
  3562. ** used to hold those values.
  3563. */
  3564. //SQLITE_API string sqlite3_column_decltype(sqlite3_stmt*,int);
  3565. //SQLITE_API const void *sqlite3_column_decltype16(sqlite3_stmt*,int);
  3566. /*
  3567. ** CAPI3REF: Evaluate An SQL Statement
  3568. **
  3569. ** After a [prepared statement] has been prepared using either
  3570. ** [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()] or one of the legacy
  3571. ** interfaces [sqlite3_prepare()] or [sqlite3_prepare16()], this function
  3572. ** must be called one or more times to evaluate the statement.
  3573. **
  3574. ** The details of the behavior of the sqlite3_step() interface depend
  3575. ** on whether the statement was prepared using the newer "v2" interface
  3576. ** [sqlite3_prepare_v2()] and [sqlite3_prepare16_v2()] or the older legacy
  3577. ** interface [sqlite3_prepare()] and [sqlite3_prepare16()]. The use of the
  3578. ** new "v2" interface is recommended for new applications but the legacy
  3579. ** interface will continue to be supported.
  3580. **
  3581. ** ^In the legacy interface, the return value will be either [SQLITE_BUSY],
  3582. ** [SQLITE_DONE], [SQLITE_ROW], [SQLITE_ERROR], or [SQLITE_MISUSE].
  3583. ** ^With the "v2" interface, any of the other [result codes] or
  3584. ** [extended result codes] might be returned as well.
  3585. **
  3586. ** ^[SQLITE_BUSY] means that the database engine was unable to acquire the
  3587. ** database locks it needs to do its job. ^If the statement is a [COMMIT]
  3588. ** or occurs outside of an explicit transaction, then you can retry the
  3589. ** statement. If the statement is not a [COMMIT] and occurs within an
  3590. ** explicit transaction then you should rollback the transaction before
  3591. ** continuing.
  3592. **
  3593. ** ^[SQLITE_DONE] means that the statement has finished executing
  3594. ** successfully. sqlite3_step() should not be called again on this virtual
  3595. ** machine without first calling [sqlite3_reset()] to reset the virtual
  3596. ** machine back to its initial state.
  3597. **
  3598. ** ^If the SQL statement being executed returns any data, then [SQLITE_ROW]
  3599. ** is returned each time a new row of data is ready for processing by the
  3600. ** caller. The values may be accessed using the [column access functions].
  3601. ** sqlite3_step() is called again to retrieve the next row of data.
  3602. **
  3603. ** ^[SQLITE_ERROR] means that a run-time error (such as a constraint
  3604. ** violation) has occurred. sqlite3_step() should not be called again on
  3605. ** the VM. More information may be found by calling [sqlite3_errmsg()].
  3606. ** ^With the legacy interface, a more specific error code (for example,
  3607. ** [SQLITE_INTERRUPT], [SQLITE_SCHEMA], [SQLITE_CORRUPT], and so forth)
  3608. ** can be obtained by calling [sqlite3_reset()] on the
  3609. ** [prepared statement]. ^In the "v2" interface,
  3610. ** the more specific error code is returned directly by sqlite3_step().
  3611. **
  3612. ** [SQLITE_MISUSE] means that the this routine was called inappropriately.
  3613. ** Perhaps it was called on a [prepared statement] that has
  3614. ** already been [sqlite3_finalize | finalized] or on one that had
  3615. ** previously returned [SQLITE_ERROR] or [SQLITE_DONE]. Or it could
  3616. ** be the case that the same database connection is being used by two or
  3617. ** more threads at the same moment in time.
  3618. **
  3619. ** For all versions of SQLite up to and including 3.6.23.1, a call to
  3620. ** [sqlite3_reset()] was required after sqlite3_step() returned anything
  3621. ** other than [SQLITE_ROW] before any subsequent invocation of
  3622. ** sqlite3_step(). Failure to reset the prepared statement using
  3623. ** [sqlite3_reset()] would result in an [SQLITE_MISUSE] return from
  3624. ** sqlite3_step(). But after version 3.6.23.1, sqlite3_step() began
  3625. ** calling [sqlite3_reset()] automatically in this circumstance rather
  3626. ** than returning [SQLITE_MISUSE]. This is not considered a compatibility
  3627. ** break because any application that ever receives an SQLITE_MISUSE error
  3628. ** is broken by definition. The [SQLITE_OMIT_AUTORESET] compile-time option
  3629. ** can be used to restore the legacy behavior.
  3630. **
  3631. ** <b>Goofy Interface Alert:</b> In the legacy interface, the sqlite3_step()
  3632. ** API always returns a generic error code, [SQLITE_ERROR], following any
  3633. ** error other than [SQLITE_BUSY] and [SQLITE_MISUSE]. You must call
  3634. ** [sqlite3_reset()] or [sqlite3_finalize()] in order to find one of the
  3635. ** specific [error codes] that better describes the error.
  3636. ** We admit that this is a goofy design. The problem has been fixed
  3637. ** with the "v2" interface. If you prepare all of your SQL statements
  3638. ** using either [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()] instead
  3639. ** of the legacy [sqlite3_prepare()] and [sqlite3_prepare16()] interfaces,
  3640. ** then the more specific [error codes] are returned directly
  3641. ** by sqlite3_step(). The use of the "v2" interface is recommended.
  3642. */
  3643. //SQLITE_API int sqlite3_step(sqlite3_stmt);
  3644. /*
  3645. ** CAPI3REF: Number of columns in a result set
  3646. **
  3647. ** ^The sqlite3_data_count(P) interface returns the number of columns in the
  3648. ** current row of the result set of [prepared statement] P.
  3649. ** ^If prepared statement P does not have results ready to return
  3650. ** (via calls to the [sqlite3_column_int | sqlite3_column_*()] of
  3651. ** interfaces) then sqlite3_data_count(P) returns 0.
  3652. ** ^The sqlite3_data_count(P) routine also returns 0 if P is a NULL pointer.
  3653. **
  3654. ** See also: [sqlite3_column_count()]
  3655. */
  3656. //SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
  3657. /*
  3658. ** CAPI3REF: Fundamental Datatypes
  3659. ** KEYWORDS: SQLITE_TEXT
  3660. **
  3661. ** ^(Every value in SQLite has one of five fundamental datatypes:
  3662. **
  3663. ** <ul>
  3664. ** <li> 64-bit signed integer
  3665. ** <li> 64-bit IEEE floating point number
  3666. ** <li> string
  3667. ** <li> BLOB
  3668. ** <li> NULL
  3669. ** </ul>)^
  3670. **
  3671. ** These constants are codes for each of those types.
  3672. **
  3673. ** Note that the SQLITE_TEXT constant was also used in SQLite version 2
  3674. ** for a completely different meaning. Software that links against both
  3675. ** SQLite version 2 and SQLite version 3 should use SQLITE3_TEXT, not
  3676. ** SQLITE_TEXT.
  3677. */
  3678. //#define SQLITE_INTEGER 1
  3679. //#define SQLITE_FLOAT 2
  3680. //#define SQLITE_BLOB 4
  3681. //#define SQLITE_NULL 5
  3682. //#if SQLITE_TEXT
  3683. //# undef SQLITE_TEXT
  3684. //#else
  3685. //# define SQLITE_TEXT 3
  3686. //#endif
  3687. //#define SQLITE3_TEXT 3
  3688. public const u8 SQLITE_INTEGER = 1;
  3689. public const u8 SQLITE_FLOAT = 2;
  3690. public const u8 SQLITE_BLOB = 4;
  3691. public const u8 SQLITE_NULL = 5;
  3692. public const u8 SQLITE_TEXT = 3;
  3693. public const u8 SQLITE3_TEXT = 3;
  3694. /*
  3695. ** CAPI3REF: Result Values From A Query
  3696. ** KEYWORDS: {column access functions}
  3697. **
  3698. ** These routines form the "result set" interface.
  3699. **
  3700. ** ^These routines return information about a single column of the current
  3701. ** result row of a query. ^In every case the first argument is a pointer
  3702. ** to the [prepared statement] that is being evaluated (the [sqlite3_stmt*]
  3703. ** that was returned from [sqlite3_prepare_v2()] or one of its variants)
  3704. ** and the second argument is the index of the column for which information
  3705. ** should be returned. ^The leftmost column of the result set has the index 0.
  3706. ** ^The number of columns in the result can be determined using
  3707. ** [sqlite3_column_count()].
  3708. **
  3709. ** If the SQL statement does not currently point to a valid row, or if the
  3710. ** column index is out of range, the result is undefined.
  3711. ** These routines may only be called when the most recent call to
  3712. ** [sqlite3_step()] has returned [SQLITE_ROW] and neither
  3713. ** [sqlite3_reset()] nor [sqlite3_finalize()] have been called subsequently.
  3714. ** If any of these routines are called after [sqlite3_reset()] or
  3715. ** [sqlite3_finalize()] or after [sqlite3_step()] has returned
  3716. ** something other than [SQLITE_ROW], the results are undefined.
  3717. ** If [sqlite3_step()] or [sqlite3_reset()] or [sqlite3_finalize()]
  3718. ** are called from a different thread while any of these routines
  3719. ** are pending, then the results are undefined.
  3720. **
  3721. ** ^The sqlite3_column_type() routine returns the
  3722. ** [SQLITE_INTEGER | datatype code] for the initial data type
  3723. ** of the result column. ^The returned value is one of [SQLITE_INTEGER],
  3724. ** [SQLITE_FLOAT], [SQLITE_TEXT], [SQLITE_BLOB], or [SQLITE_NULL]. The value
  3725. ** returned by sqlite3_column_type() is only meaningful if no type
  3726. ** conversions have occurred as described below. After a type conversion,
  3727. ** the value returned by sqlite3_column_type() is undefined. Future
  3728. ** versions of SQLite may change the behavior of sqlite3_column_type()
  3729. ** following a type conversion.
  3730. **
  3731. ** ^If the result is a BLOB or UTF-8 string then the sqlite3_column_bytes()
  3732. ** routine returns the number of bytes in that BLOB or string.
  3733. ** ^If the result is a UTF-16 string, then sqlite3_column_bytes() converts
  3734. ** the string to UTF-8 and then returns the number of bytes.
  3735. ** ^If the result is a numeric value then sqlite3_column_bytes() uses
  3736. ** [sqlite3_snprintf()] to convert that value to a UTF-8 string and returns
  3737. ** the number of bytes in that string.
  3738. ** ^If the result is NULL, then sqlite3_column_bytes() returns zero.
  3739. **
  3740. ** ^If the result is a BLOB or UTF-16 string then the sqlite3_column_bytes16()
  3741. ** routine returns the number of bytes in that BLOB or string.
  3742. ** ^If the result is a UTF-8 string, then sqlite3_column_bytes16() converts
  3743. ** the string to UTF-16 and then returns the number of bytes.
  3744. ** ^If the result is a numeric value then sqlite3_column_bytes16() uses
  3745. ** [sqlite3_snprintf()] to convert that value to a UTF-16 string and returns
  3746. ** the number of bytes in that string.
  3747. ** ^If the result is NULL, then sqlite3_column_bytes16() returns zero.
  3748. **
  3749. ** ^The values returned by [sqlite3_column_bytes()] and
  3750. ** [sqlite3_column_bytes16()] do not include the zero terminators at the end
  3751. ** of the string. ^For clarity: the values returned by
  3752. ** [sqlite3_column_bytes()] and [sqlite3_column_bytes16()] are the number of
  3753. ** bytes in the string, not the number of characters.
  3754. **
  3755. ** ^Strings returned by sqlite3_column_text() and sqlite3_column_text16(),
  3756. ** even empty strings, are always zero terminated. ^The return
  3757. ** value from sqlite3_column_blob() for a zero-length BLOB is a NULL pointer.
  3758. **
  3759. ** ^The object returned by [sqlite3_column_value()] is an
  3760. ** [unprotected sqlite3_value] object. An unprotected sqlite3_value object
  3761. ** may only be used with [sqlite3_bind_value()] and [sqlite3_result_value()].
  3762. ** If the [unprotected sqlite3_value] object returned by
  3763. ** [sqlite3_column_value()] is used in any other way, including calls
  3764. ** to routines like [sqlite3_value_int()], [sqlite3_value_text()],
  3765. ** or [sqlite3_value_bytes()], then the behavior is undefined.
  3766. **
  3767. ** These routines attempt to convert the value where appropriate. ^For
  3768. ** example, if the internal representation is FLOAT and a text result
  3769. ** is requested, [sqlite3_snprintf()] is used internally to perform the
  3770. ** conversion automatically. ^(The following table details the conversions
  3771. ** that are applied:
  3772. **
  3773. ** <blockquote>
  3774. ** <table border="1">
  3775. ** <tr><th> Internal<br>Type <th> Requested<br>Type <th> Conversion
  3776. **
  3777. ** <tr><td> NULL <td> INTEGER <td> Result is 0
  3778. ** <tr><td> NULL <td> FLOAT <td> Result is 0.0
  3779. ** <tr><td> NULL <td> TEXT <td> Result is NULL pointer
  3780. ** <tr><td> NULL <td> BLOB <td> Result is NULL pointer
  3781. ** <tr><td> INTEGER <td> FLOAT <td> Convert from integer to float
  3782. ** <tr><td> INTEGER <td> TEXT <td> ASCII rendering of the integer
  3783. ** <tr><td> INTEGER <td> BLOB <td> Same as INTEGER->TEXT
  3784. ** <tr><td> FLOAT <td> INTEGER <td> Convert from float to integer
  3785. ** <tr><td> FLOAT <td> TEXT <td> ASCII rendering of the float
  3786. ** <tr><td> FLOAT <td> BLOB <td> Same as FLOAT->TEXT
  3787. ** <tr><td> TEXT <td> INTEGER <td> Use atoi()
  3788. ** <tr><td> TEXT <td> FLOAT <td> Use atof()
  3789. ** <tr><td> TEXT <td> BLOB <td> No change
  3790. ** <tr><td> BLOB <td> INTEGER <td> Convert to TEXT then use atoi()
  3791. ** <tr><td> BLOB <td> FLOAT <td> Convert to TEXT then use atof()
  3792. ** <tr><td> BLOB <td> TEXT <td> Add a zero terminator if needed
  3793. ** </table>
  3794. ** </blockquote>)^
  3795. **
  3796. ** The table above makes reference to standard C library functions atoi()
  3797. ** and atof(). SQLite does not really use these functions. It has its
  3798. ** own equivalent internal routines. The atoi() and atof() names are
  3799. ** used in the table for brevity and because they are familiar to most
  3800. ** C programmers.
  3801. **
  3802. ** Note that when type conversions occur, pointers returned by prior
  3803. ** calls to sqlite3_column_blob(), sqlite3_column_text(), and/or
  3804. ** sqlite3_column_text16() may be invalidated.
  3805. ** Type conversions and pointer invalidations might occur
  3806. ** in the following cases:
  3807. **
  3808. ** <ul>
  3809. ** <li> The initial content is a BLOB and sqlite3_column_text() or
  3810. ** sqlite3_column_text16() is called. A zero-terminator might
  3811. ** need to be added to the string.</li>
  3812. ** <li> The initial content is UTF-8 text and sqlite3_column_bytes16() or
  3813. ** sqlite3_column_text16() is called. The content must be converted
  3814. ** to UTF-16.</li>
  3815. ** <li> The initial content is UTF-16 text and sqlite3_column_bytes() or
  3816. ** sqlite3_column_text() is called. The content must be converted
  3817. ** to UTF-8.</li>
  3818. ** </ul>
  3819. **
  3820. ** ^Conversions between UTF-16be and UTF-16le are always done in place and do
  3821. ** not invalidate a prior pointer, though of course the content of the buffer
  3822. ** that the prior pointer references will have been modified. Other kinds
  3823. ** of conversion are done in place when it is possible, but sometimes they
  3824. ** are not possible and in those cases prior pointers are invalidated.
  3825. **
  3826. ** The safest and easiest to remember policy is to invoke these routines
  3827. ** in one of the following ways:
  3828. **
  3829. ** <ul>
  3830. ** <li>sqlite3_column_text() followed by sqlite3_column_bytes()</li>
  3831. ** <li>sqlite3_column_blob() followed by sqlite3_column_bytes()</li>
  3832. ** <li>sqlite3_column_text16() followed by sqlite3_column_bytes16()</li>
  3833. ** </ul>
  3834. **
  3835. ** In other words, you should call sqlite3_column_text(),
  3836. ** sqlite3_column_blob(), or sqlite3_column_text16() first to force the result
  3837. ** into the desired format, then invoke sqlite3_column_bytes() or
  3838. ** sqlite3_column_bytes16() to find the size of the result. Do not mix calls
  3839. ** to sqlite3_column_text() or sqlite3_column_blob() with calls to
  3840. ** sqlite3_column_bytes16(), and do not mix calls to sqlite3_column_text16()
  3841. ** with calls to sqlite3_column_bytes().
  3842. **
  3843. ** ^The pointers returned are valid until a type conversion occurs as
  3844. ** described above, or until [sqlite3_step()] or [sqlite3_reset()] or
  3845. ** [sqlite3_finalize()] is called. ^The memory space used to hold strings
  3846. ** and BLOBs is freed automatically. Do <b>not</b> pass the pointers returned
  3847. ** [sqlite3_column_blob()], [sqlite3_column_text()], etc. into
  3848. ** [sqlite3_free()].
  3849. **
  3850. ** ^(If a memory allocation error occurs during the evaluation of any
  3851. ** of these routines, a default value is returned. The default value
  3852. ** is either the integer 0, the floating point number 0.0, or a NULL
  3853. ** pointer. Subsequent calls to [sqlite3_errcode()] will return
  3854. ** [SQLITE_NOMEM].)^
  3855. */
  3856. //SQLITE_API const void *sqlite3_column_blob(sqlite3_stmt*, int iCol);
  3857. //SQLITE_API int sqlite3_column_bytes(sqlite3_stmt*, int iCol);
  3858. //SQLITE_API int sqlite3_column_bytes16(sqlite3_stmt*, int iCol);
  3859. //SQLITE_API double sqlite3_column_double(sqlite3_stmt*, int iCol);
  3860. //SQLITE_API int sqlite3_column_int(sqlite3_stmt*, int iCol);
  3861. //SQLITE_API sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol);
  3862. //SQLITE_API const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);
  3863. //SQLITE_API const void *sqlite3_column_text16(sqlite3_stmt*, int iCol);
  3864. //SQLITE_API int sqlite3_column_type(sqlite3_stmt*, int iCol);
  3865. //SQLITE_API sqlite3_value *sqlite3_column_value(sqlite3_stmt*, int iCol);
  3866. /*
  3867. ** CAPI3REF: Destroy A Prepared Statement Object
  3868. **
  3869. ** ^The sqlite3_finalize() function is called to delete a [prepared statement].
  3870. ** ^If the most recent evaluation of the statement encountered no errors
  3871. ** or if the statement is never been evaluated, then sqlite3_finalize() returns
  3872. ** SQLITE_OK. ^If the most recent evaluation of statement S failed, then
  3873. ** sqlite3_finalize(S) returns the appropriate [error code] or
  3874. ** [extended error code].
  3875. **
  3876. ** ^The sqlite3_finalize(S) routine can be called at any point during
  3877. ** the life cycle of [prepared statement] S:
  3878. ** before statement S is ever evaluated, after
  3879. ** one or more calls to [sqlite3_reset()], or after any call
  3880. ** to [sqlite3_step()] regardless of whether or not the statement has
  3881. ** completed execution.
  3882. **
  3883. ** ^Invoking sqlite3_finalize() on a NULL pointer is a harmless no-op.
  3884. **
  3885. ** The application must finalize every [prepared statement] in order to avoid
  3886. ** resource leaks. It is a grievous error for the application to try to use
  3887. ** a prepared statement after it has been finalized. Any use of a prepared
  3888. ** statement after it has been finalized can result in undefined and
  3889. ** undesirable behavior such as segfaults and heap corruption.
  3890. */
  3891. //SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt);
  3892. /*
  3893. ** CAPI3REF: Reset A Prepared Statement Object
  3894. **
  3895. ** The sqlite3_reset() function is called to reset a [prepared statement]
  3896. ** object back to its initial state, ready to be re-executed.
  3897. ** ^Any SQL statement variables that had values bound to them using
  3898. ** the [sqlite3_bind_blob | sqlite3_bind_*() API] retain their values.
  3899. ** Use [sqlite3_clear_bindings()] to reset the bindings.
  3900. **
  3901. ** ^The [sqlite3_reset(S)] interface resets the [prepared statement] S
  3902. ** back to the beginning of its program.
  3903. **
  3904. ** ^If the most recent call to [sqlite3_step(S)] for the
  3905. ** [prepared statement] S returned [SQLITE_ROW] or [SQLITE_DONE],
  3906. ** or if [sqlite3_step(S)] has never before been called on S,
  3907. ** then [sqlite3_reset(S)] returns [SQLITE_OK].
  3908. **
  3909. ** ^If the most recent call to [sqlite3_step(S)] for the
  3910. ** [prepared statement] S indicated an error, then
  3911. ** [sqlite3_reset(S)] returns an appropriate [error code].
  3912. **
  3913. ** ^The [sqlite3_reset(S)] interface does not change the values
  3914. ** of any [sqlite3_bind_blob|bindings] on the [prepared statement] S.
  3915. */
  3916. //SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
  3917. /*
  3918. ** CAPI3REF: Create Or Redefine SQL Functions
  3919. ** KEYWORDS: {function creation routines}
  3920. ** KEYWORDS: {application-defined SQL function}
  3921. ** KEYWORDS: {application-defined SQL functions}
  3922. **
  3923. ** ^These functions (collectively known as "function creation routines")
  3924. ** are used to add SQL functions or aggregates or to redefine the behavior
  3925. ** of existing SQL functions or aggregates. The only differences between
  3926. ** these routines are the text encoding expected for
  3927. ** the second parameter (the name of the function being created)
  3928. ** and the presence or absence of a destructor callback for
  3929. ** the application data pointer.
  3930. **
  3931. ** ^The first parameter is the [database connection] to which the SQL
  3932. ** function is to be added. ^If an application uses more than one database
  3933. ** connection then application-defined SQL functions must be added
  3934. ** to each database connection separately.
  3935. **
  3936. ** ^The second parameter is the name of the SQL function to be created or
  3937. ** redefined. ^The length of the name is limited to 255 bytes in a UTF-8
  3938. ** representation, exclusive of the zero-terminator. ^Note that the name
  3939. ** length limit is in UTF-8 bytes, not characters nor UTF-16 bytes.
  3940. ** ^Any attempt to create a function with a longer name
  3941. ** will result in [SQLITE_MISUSE] being returned.
  3942. **
  3943. ** ^The third parameter (nArg)
  3944. ** is the number of arguments that the SQL function or
  3945. ** aggregate takes. ^If this parameter is -1, then the SQL function or
  3946. ** aggregate may take any number of arguments between 0 and the limit
  3947. ** set by [sqlite3_limit]([SQLITE_LIMIT_FUNCTION_ARG]). If the third
  3948. ** parameter is less than -1 or greater than 127 then the behavior is
  3949. ** undefined.
  3950. **
  3951. ** ^The fourth parameter, eTextRep, specifies what
  3952. ** [SQLITE_UTF8 | text encoding] this SQL function prefers for
  3953. ** its parameters. Every SQL function implementation must be able to work
  3954. ** with UTF-8, UTF-16le, or UTF-16be. But some implementations may be
  3955. ** more efficient with one encoding than another. ^An application may
  3956. ** invoke sqlite3_create_function() or sqlite3_create_function16() multiple
  3957. ** times with the same function but with different values of eTextRep.
  3958. ** ^When multiple implementations of the same function are available, SQLite
  3959. ** will pick the one that involves the least amount of data conversion.
  3960. ** If there is only a single implementation which does not care what text
  3961. ** encoding is used, then the fourth argument should be [SQLITE_ANY].
  3962. **
  3963. ** ^(The fifth parameter is an arbitrary pointer. The implementation of the
  3964. ** function can gain access to this pointer using [sqlite3_user_data()].)^
  3965. **
  3966. ** ^The sixth, seventh and eighth parameters, xFunc, xStep and xFinal, are
  3967. ** pointers to C-language functions that implement the SQL function or
  3968. ** aggregate. ^A scalar SQL function requires an implementation of the xFunc
  3969. ** callback only; NULL pointers must be passed as the xStep and xFinal
  3970. ** parameters. ^An aggregate SQL function requires an implementation of xStep
  3971. ** and xFinal and NULL pointer must be passed for xFunc. ^To delete an existing
  3972. ** SQL function or aggregate, pass NULL pointers for all three function
  3973. ** callbacks.
  3974. **
  3975. ** ^(If the ninth parameter to sqlite3_create_function_v2() is not NULL,
  3976. ** then it is destructor for the application data pointer.
  3977. ** The destructor is invoked when the function is deleted, either by being
  3978. ** overloaded or when the database connection closes.)^
  3979. ** ^The destructor is also invoked if the call to
  3980. ** sqlite3_create_function_v2() fails.
  3981. ** ^When the destructor callback of the tenth parameter is invoked, it
  3982. ** is passed a single argument which is a copy of the application data
  3983. ** pointer which was the fifth parameter to sqlite3_create_function_v2().
  3984. **
  3985. ** ^It is permitted to register multiple implementations of the same
  3986. ** functions with the same name but with either differing numbers of
  3987. ** arguments or differing preferred text encodings. ^SQLite will use
  3988. ** the implementation that most closely matches the way in which the
  3989. ** SQL function is used. ^A function implementation with a non-negative
  3990. ** nArg parameter is a better match than a function implementation with
  3991. ** a negative nArg. ^A function where the preferred text encoding
  3992. ** matches the database encoding is a better
  3993. ** match than a function where the encoding is different.
  3994. ** ^A function where the encoding difference is between UTF16le and UTF16be
  3995. ** is a closer match than a function where the encoding difference is
  3996. ** between UTF8 and UTF16.
  3997. **
  3998. ** ^Built-in functions may be overloaded by new application-defined functions.
  3999. **
  4000. ** ^An application-defined function is permitted to call other
  4001. ** SQLite interfaces. However, such calls must not
  4002. ** close the database connection nor finalize or reset the prepared
  4003. ** statement in which the function is running.
  4004. */
  4005. //SQLITE_API int sqlite3_create_function(
  4006. // sqlite3 db,
  4007. // string zFunctionName,
  4008. // int nArg,
  4009. // int eTextRep,
  4010. // void *pApp,
  4011. // void (*xFunc)(sqlite3_context*,int,sqlite3_value*),
  4012. // void (*xStep)(sqlite3_context*,int,sqlite3_value*),
  4013. // void (*xFinal)(sqlite3_context)
  4014. //);
  4015. //SQLITE_API int sqlite3_create_function16(
  4016. // sqlite3 db,
  4017. // string zFunctionName,
  4018. // int nArg,
  4019. // int eTextRep,
  4020. // void *pApp,
  4021. // void (*xFunc)(sqlite3_context*,int,sqlite3_value*),
  4022. // void (*xStep)(sqlite3_context*,int,sqlite3_value*),
  4023. // void (*xFinal)(sqlite3_context)
  4024. //);
  4025. //SQLITE_API int sqlite3_create_function_v2(
  4026. // sqlite3 db,
  4027. // string zFunctionName,
  4028. // int nArg,
  4029. // int eTextRep,
  4030. // void *pApp,
  4031. // void (*xFunc)(sqlite3_context*,int,sqlite3_value*),
  4032. // void (*xStep)(sqlite3_context*,int,sqlite3_value*),
  4033. // void (*xFinal)(sqlite3_context),
  4034. // void(*xDestroy)(void)
  4035. //);
  4036. /*
  4037. ** CAPI3REF: Text Encodings
  4038. **
  4039. ** These constant define integer codes that represent the various
  4040. ** text encodings supported by SQLite.
  4041. */
  4042. //#define SQLITE_UTF8 1
  4043. //#define SQLITE_UTF16LE 2
  4044. //#define SQLITE_UTF16BE 3
  4045. //#define SQLITE_UTF16 4 /* Use native byte order */
  4046. //#define SQLITE_ANY 5 /* sqlite3_create_function only */
  4047. //#define SQLITE_UTF16_ALIGNED 8 /* sqlite3_create_collation only */
  4048. public const u8 SQLITE_UTF8 = 1;
  4049. public const u8 SQLITE_UTF16LE = 2;
  4050. public const u8 SQLITE_UTF16BE = 3;
  4051. public const u8 SQLITE_UTF16 = 4;
  4052. public const u8 SQLITE_ANY = 5;
  4053. public const u8 SQLITE_UTF16_ALIGNED = 8;
  4054. /*
  4055. ** CAPI3REF: Deprecated Functions
  4056. ** DEPRECATED
  4057. **
  4058. ** These functions are [deprecated]. In order to maintain
  4059. ** backwards compatibility with older code, these functions continue
  4060. ** to be supported. However, new applications should avoid
  4061. ** the use of these functions. To help encourage people to avoid
  4062. ** using these functions, we are not going to tell you what they do.
  4063. */
  4064. //#if !SQLITE_OMIT_DEPRECATED
  4065. //SQLITE_API SQLITE_DEPRECATED int sqlite3_aggregate_count(sqlite3_context);
  4066. //SQLITE_API SQLITE_DEPRECATED int sqlite3_expired(sqlite3_stmt);
  4067. //SQLITE_API SQLITE_DEPRECATED int sqlite3_transfer_bindings(sqlite3_stmt*, sqlite3_stmt);
  4068. //SQLITE_API SQLITE_DEPRECATED int sqlite3_global_recover(void);
  4069. //SQLITE_API SQLITE_DEPRECATED void sqlite3_thread_cleanup(void);
  4070. //SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void()(void*,sqlite3_int64,int),void*,sqlite3_int64);
  4071. //#endif
  4072. /*
  4073. ** CAPI3REF: Obtaining SQL Function Parameter Values
  4074. **
  4075. ** The C-language implementation of SQL functions and aggregates uses
  4076. ** this set of interface routines to access the parameter values on
  4077. ** the function or aggregate.
  4078. **
  4079. ** The xFunc (for scalar functions) or xStep (for aggregates) parameters
  4080. ** to [sqlite3_create_function()] and [sqlite3_create_function16()]
  4081. ** define callbacks that implement the SQL functions and aggregates.
  4082. ** The 3rd parameter to these callbacks is an array of pointers to
  4083. ** [protected sqlite3_value] objects. There is one [sqlite3_value] object for
  4084. ** each parameter to the SQL function. These routines are used to
  4085. ** extract values from the [sqlite3_value] objects.
  4086. **
  4087. ** These routines work only with [protected sqlite3_value] objects.
  4088. ** Any attempt to use these routines on an [unprotected sqlite3_value]
  4089. ** object results in undefined behavior.
  4090. **
  4091. ** ^These routines work just like the corresponding [column access functions]
  4092. ** except that these routines take a single [protected sqlite3_value] object
  4093. ** pointer instead of a [sqlite3_stmt*] pointer and an integer column number.
  4094. **
  4095. ** ^The sqlite3_value_text16() interface extracts a UTF-16 string
  4096. ** in the native byte-order of the host machine. ^The
  4097. ** sqlite3_value_text16be() and sqlite3_value_text16le() interfaces
  4098. ** extract UTF-16 strings as big-endian and little-endian respectively.
  4099. **
  4100. ** ^(The sqlite3_value_numeric_type() interface attempts to apply
  4101. ** numeric affinity to the value. This means that an attempt is
  4102. ** made to convert the value to an integer or floating point. If
  4103. ** such a conversion is possible without loss of information (in other
  4104. ** words, if the value is a string that looks like a number)
  4105. ** then the conversion is performed. Otherwise no conversion occurs.
  4106. ** The [SQLITE_INTEGER | datatype] after conversion is returned.)^
  4107. **
  4108. ** Please pay particular attention to the fact that the pointer returned
  4109. ** from [sqlite3_value_blob()], [sqlite3_value_text()], or
  4110. ** [sqlite3_value_text16()] can be invalidated by a subsequent call to
  4111. ** [sqlite3_value_bytes()], [sqlite3_value_bytes16()], [sqlite3_value_text()],
  4112. ** or [sqlite3_value_text16()].
  4113. **
  4114. ** These routines must be called from the same thread as
  4115. ** the SQL function that supplied the [sqlite3_value*] parameters.
  4116. */
  4117. //SQLITE_API const void *sqlite3_value_blob(sqlite3_value);
  4118. //SQLITE_API int sqlite3_value_bytes(sqlite3_value);
  4119. //SQLITE_API int sqlite3_value_bytes16(sqlite3_value);
  4120. //SQLITE_API double sqlite3_value_double(sqlite3_value);
  4121. //SQLITE_API int sqlite3_value_int(sqlite3_value);
  4122. //SQLITE_API sqlite3_int64 sqlite3_value_int64(sqlite3_value);
  4123. //SQLITE_API const unsigned char *sqlite3_value_text(sqlite3_value);
  4124. //SQLITE_API const void *sqlite3_value_text16(sqlite3_value);
  4125. //SQLITE_API const void *sqlite3_value_text16le(sqlite3_value);
  4126. //SQLITE_API const void *sqlite3_value_text16be(sqlite3_value);
  4127. //SQLITE_API int sqlite3_value_type(sqlite3_value);
  4128. //SQLITE_API int sqlite3_value_numeric_type(sqlite3_value);
  4129. /*
  4130. ** CAPI3REF: Obtain Aggregate Function Context
  4131. **
  4132. ** Implementations of aggregate SQL functions use this
  4133. ** routine to allocate memory for storing their state.
  4134. **
  4135. ** ^The first time the sqlite3_aggregate_context(C,N) routine is called
  4136. ** for a particular aggregate function, SQLite
  4137. ** allocates N of memory, zeroes out that memory, and returns a pointer
  4138. ** to the new memory. ^On second and subsequent calls to
  4139. ** sqlite3_aggregate_context() for the same aggregate function instance,
  4140. ** the same buffer is returned. Sqlite3_aggregate_context() is normally
  4141. ** called once for each invocation of the xStep callback and then one
  4142. ** last time when the xFinal callback is invoked. ^(When no rows match
  4143. ** an aggregate query, the xStep() callback of the aggregate function
  4144. ** implementation is never called and xFinal() is called exactly once.
  4145. ** In those cases, sqlite3_aggregate_context() might be called for the
  4146. ** first time from within xFinal().)^
  4147. **
  4148. ** ^The sqlite3_aggregate_context(C,N) routine returns a NULL pointer if N is
  4149. ** less than or equal to zero or if a memory allocate error occurs.
  4150. **
  4151. ** ^(The amount of space allocated by sqlite3_aggregate_context(C,N) is
  4152. ** determined by the N parameter on first successful call. Changing the
  4153. ** value of N in subsequent call to sqlite3_aggregate_context() within
  4154. ** the same aggregate function instance will not resize the memory
  4155. ** allocation.)^
  4156. **
  4157. ** ^SQLite automatically frees the memory allocated by
  4158. ** sqlite3_aggregate_context() when the aggregate query concludes.
  4159. **
  4160. ** The first parameter must be a copy of the
  4161. ** [sqlite3_context | SQL function context] that is the first parameter
  4162. ** to the xStep or xFinal callback routine that implements the aggregate
  4163. ** function.
  4164. **
  4165. ** This routine must be called from the same thread in which
  4166. ** the aggregate SQL function is running.
  4167. */
  4168. //SQLITE_API void *sqlite3_aggregate_context(sqlite3_context*, int nBytes);
  4169. /*
  4170. ** CAPI3REF: User Data For Functions
  4171. **
  4172. ** ^The sqlite3_user_data() interface returns a copy of
  4173. ** the pointer that was the pUserData parameter (the 5th parameter)
  4174. ** of the [sqlite3_create_function()]
  4175. ** and [sqlite3_create_function16()] routines that originally
  4176. ** registered the application defined function.
  4177. **
  4178. ** This routine must be called from the same thread in which
  4179. ** the application-defined function is running.
  4180. */
  4181. //SQLITE_API void *sqlite3_user_data(sqlite3_context);
  4182. /*
  4183. ** CAPI3REF: Database Connection For Functions
  4184. **
  4185. ** ^The sqlite3_context_db_handle() interface returns a copy of
  4186. ** the pointer to the [database connection] (the 1st parameter)
  4187. ** of the [sqlite3_create_function()]
  4188. ** and [sqlite3_create_function16()] routines that originally
  4189. ** registered the application defined function.
  4190. */
  4191. //SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context);
  4192. /*
  4193. ** CAPI3REF: Function Auxiliary Data
  4194. **
  4195. ** The following two functions may be used by scalar SQL functions to
  4196. ** associate metadata with argument values. If the same value is passed to
  4197. ** multiple invocations of the same SQL function during query execution, under
  4198. ** some circumstances the associated metadata may be preserved. This may
  4199. ** be used, for example, to add a regular-expression matching scalar
  4200. ** function. The compiled version of the regular expression is stored as
  4201. ** metadata associated with the SQL value passed as the regular expression
  4202. ** pattern. The compiled regular expression can be reused on multiple
  4203. ** invocations of the same function so that the original pattern string
  4204. ** does not need to be recompiled on each invocation.
  4205. **
  4206. ** ^The sqlite3_get_auxdata() interface returns a pointer to the metadata
  4207. ** associated by the sqlite3_set_auxdata() function with the Nth argument
  4208. ** value to the application-defined function. ^If no metadata has been ever
  4209. ** been set for the Nth argument of the function, or if the corresponding
  4210. ** function parameter has changed since the meta-data was set,
  4211. ** then sqlite3_get_auxdata() returns a NULL pointer.
  4212. **
  4213. ** ^The sqlite3_set_auxdata() interface saves the metadata
  4214. ** pointed to by its 3rd parameter as the metadata for the N-th
  4215. ** argument of the application-defined function. Subsequent
  4216. ** calls to sqlite3_get_auxdata() might return this data, if it has
  4217. ** not been destroyed.
  4218. ** ^If it is not NULL, SQLite will invoke the destructor
  4219. ** function given by the 4th parameter to sqlite3_set_auxdata() on
  4220. ** the metadata when the corresponding function parameter changes
  4221. ** or when the SQL statement completes, whichever comes first.
  4222. **
  4223. ** SQLite is free to call the destructor and drop metadata on any
  4224. ** parameter of any function at any time. ^The only guarantee is that
  4225. ** the destructor will be called before the metadata is dropped.
  4226. **
  4227. ** ^(In practice, metadata is preserved between function calls for
  4228. ** expressions that are constant at compile time. This includes literal
  4229. ** values and [parameters].)^
  4230. **
  4231. ** These routines must be called from the same thread in which
  4232. ** the SQL function is running.
  4233. */
  4234. //SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
  4235. //SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, object ()(void));
  4236. /*
  4237. ** CAPI3REF: Constants Defining Special Destructor Behavior
  4238. **
  4239. ** These are special values for the destructor that is passed in as the
  4240. ** final argument to routines like [sqlite3_result_blob()]. ^If the destructor
  4241. ** argument is SQLITE_STATIC, it means that the content pointer is constant
  4242. ** and will never change. It does not need to be destroyed. ^The
  4243. ** SQLITE_TRANSIENT value means that the content will likely change in
  4244. ** the near future and that SQLite should make its own private copy of
  4245. ** the content before returning.
  4246. **
  4247. ** The typedef is necessary to work around problems in certain
  4248. ** C++ compilers. See ticket #2191.
  4249. */
  4250. //typedef void (*sqlite3_destructor_type)(void);
  4251. //#define SQLITE_STATIC ((sqlite3_destructor_type)0)
  4252. //#define SQLITE_TRANSIENT ((sqlite3_destructor_type)-1)
  4253. static public dxDel SQLITE_STATIC;
  4254. static public dxDel SQLITE_TRANSIENT;
  4255. /*
  4256. ** CAPI3REF: Setting The Result Of An SQL Function
  4257. **
  4258. ** These routines are used by the xFunc or xFinal callbacks that
  4259. ** implement SQL functions and aggregates. See
  4260. ** [sqlite3_create_function()] and [sqlite3_create_function16()]
  4261. ** for additional information.
  4262. **
  4263. ** These functions work very much like the [parameter binding] family of
  4264. ** functions used to bind values to host parameters in prepared statements.
  4265. ** Refer to the [SQL parameter] documentation for additional information.
  4266. **
  4267. ** ^The sqlite3_result_blob() interface sets the result from
  4268. ** an application-defined function to be the BLOB whose content is pointed
  4269. ** to by the second parameter and which is N bytes long where N is the
  4270. ** third parameter.
  4271. **
  4272. ** ^The sqlite3_result_zeroblob() interfaces set the result of
  4273. ** the application-defined function to be a BLOB containing all zero
  4274. ** bytes and N bytes in size, where N is the value of the 2nd parameter.
  4275. **
  4276. ** ^The sqlite3_result_double() interface sets the result from
  4277. ** an application-defined function to be a floating point value specified
  4278. ** by its 2nd argument.
  4279. **
  4280. ** ^The sqlite3_result_error() and sqlite3_result_error16() functions
  4281. ** cause the implemented SQL function to throw an exception.
  4282. ** ^SQLite uses the string pointed to by the
  4283. ** 2nd parameter of sqlite3_result_error() or sqlite3_result_error16()
  4284. ** as the text of an error message. ^SQLite interprets the error
  4285. ** message string from sqlite3_result_error() as UTF-8. ^SQLite
  4286. ** interprets the string from sqlite3_result_error16() as UTF-16 in native
  4287. ** byte order. ^If the third parameter to sqlite3_result_error()
  4288. ** or sqlite3_result_error16() is negative then SQLite takes as the error
  4289. ** message all text up through the first zero character.
  4290. ** ^If the third parameter to sqlite3_result_error() or
  4291. ** sqlite3_result_error16() is non-negative then SQLite takes that many
  4292. ** bytes (not characters) from the 2nd parameter as the error message.
  4293. ** ^The sqlite3_result_error() and sqlite3_result_error16()
  4294. ** routines make a private copy of the error message text before
  4295. ** they return. Hence, the calling function can deallocate or
  4296. ** modify the text after they return without harm.
  4297. ** ^The sqlite3_result_error_code() function changes the error code
  4298. ** returned by SQLite as a result of an error in a function. ^By default,
  4299. ** the error code is SQLITE_ERROR. ^A subsequent call to sqlite3_result_error()
  4300. ** or sqlite3_result_error16() resets the error code to SQLITE_ERROR.
  4301. **
  4302. ** ^The sqlite3_result_toobig() interface causes SQLite to throw an error
  4303. ** indicating that a string or BLOB is too long to represent.
  4304. **
  4305. ** ^The sqlite3_result_nomem() interface causes SQLite to throw an error
  4306. ** indicating that a memory allocation failed.
  4307. **
  4308. ** ^The sqlite3_result_int() interface sets the return value
  4309. ** of the application-defined function to be the 32-bit signed integer
  4310. ** value given in the 2nd argument.
  4311. ** ^The sqlite3_result_int64() interface sets the return value
  4312. ** of the application-defined function to be the 64-bit signed integer
  4313. ** value given in the 2nd argument.
  4314. **
  4315. ** ^The sqlite3_result_null() interface sets the return value
  4316. ** of the application-defined function to be NULL.
  4317. **
  4318. ** ^The sqlite3_result_text(), sqlite3_result_text16(),
  4319. ** sqlite3_result_text16le(), and sqlite3_result_text16be() interfaces
  4320. ** set the return value of the application-defined function to be
  4321. ** a text string which is represented as UTF-8, UTF-16 native byte order,
  4322. ** UTF-16 little endian, or UTF-16 big endian, respectively.
  4323. ** ^SQLite takes the text result from the application from
  4324. ** the 2nd parameter of the sqlite3_result_text* interfaces.
  4325. ** ^If the 3rd parameter to the sqlite3_result_text* interfaces
  4326. ** is negative, then SQLite takes result text from the 2nd parameter
  4327. ** through the first zero character.
  4328. ** ^If the 3rd parameter to the sqlite3_result_text* interfaces
  4329. ** is non-negative, then as many bytes (not characters) of the text
  4330. ** pointed to by the 2nd parameter are taken as the application-defined
  4331. ** function result.
  4332. ** ^If the 4th parameter to the sqlite3_result_text* interfaces
  4333. ** or sqlite3_result_blob is a non-NULL pointer, then SQLite calls that
  4334. ** function as the destructor on the text or BLOB result when it has
  4335. ** finished using that result.
  4336. ** ^If the 4th parameter to the sqlite3_result_text* interfaces or to
  4337. ** sqlite3_result_blob is the special constant SQLITE_STATIC, then SQLite
  4338. ** assumes that the text or BLOB result is in constant space and does not
  4339. ** copy the content of the parameter nor call a destructor on the content
  4340. ** when it has finished using that result.
  4341. ** ^If the 4th parameter to the sqlite3_result_text* interfaces
  4342. ** or sqlite3_result_blob is the special constant SQLITE_TRANSIENT
  4343. ** then SQLite makes a copy of the result into space obtained from
  4344. ** from [sqlite3_malloc()] before it returns.
  4345. **
  4346. ** ^The sqlite3_result_value() interface sets the result of
  4347. ** the application-defined function to be a copy the
  4348. ** [unprotected sqlite3_value] object specified by the 2nd parameter. ^The
  4349. ** sqlite3_result_value() interface makes a copy of the [sqlite3_value]
  4350. ** so that the [sqlite3_value] specified in the parameter may change or
  4351. ** be deallocated after sqlite3_result_value() returns without harm.
  4352. ** ^A [protected sqlite3_value] object may always be used where an
  4353. ** [unprotected sqlite3_value] object is required, so either
  4354. ** kind of [sqlite3_value] object can be used with this interface.
  4355. **
  4356. ** If these routines are called from within the different thread
  4357. ** than the one containing the application-defined function that received
  4358. ** the [sqlite3_context] pointer, the results are undefined.
  4359. */
  4360. //SQLITE_API void sqlite3_result_blob(sqlite3_context*, const void*, int, void()(void));
  4361. //SQLITE_API void sqlite3_result_double(sqlite3_context*, double);
  4362. //SQLITE_API void sqlite3_result_error(sqlite3_context*, const char*, int);
  4363. //SQLITE_API void sqlite3_result_error16(sqlite3_context*, const void*, int);
  4364. //SQLITE_API void sqlite3_result_error_toobig(sqlite3_context);
  4365. //SQLITE_API void sqlite3_result_error_nomem(sqlite3_context);
  4366. //SQLITE_API void sqlite3_result_error_code(sqlite3_context*, int);
  4367. //SQLITE_API void sqlite3_result_int(sqlite3_context*, int);
  4368. //SQLITE_API void sqlite3_result_int64(sqlite3_context*, sqlite3_int64);
  4369. //SQLITE_API void sqlite3_result_null(sqlite3_context);
  4370. //SQLITE_API void sqlite3_result_text(sqlite3_context*, const char*, int, void()(void));
  4371. //SQLITE_API void sqlite3_result_text16(sqlite3_context*, const void*, int, void()(void));
  4372. //SQLITE_API void sqlite3_result_text16le(sqlite3_context*, const void*, int,void()(void));
  4373. //SQLITE_API void sqlite3_result_text16be(sqlite3_context*, const void*, int,void()(void));
  4374. //SQLITE_API void sqlite3_result_value(sqlite3_context*, sqlite3_value);
  4375. //SQLITE_API void sqlite3_result_zeroblob(sqlite3_context*, int n);
  4376. /*
  4377. ** CAPI3REF: Define New Collating Sequences
  4378. **
  4379. ** ^These functions add, remove, or modify a [collation] associated
  4380. ** with the [database connection] specified as the first argument.
  4381. **
  4382. ** ^The name of the collation is a UTF-8 string
  4383. ** for sqlite3_create_collation() and sqlite3_create_collation_v2()
  4384. ** and a UTF-16 string in native byte order for sqlite3_create_collation16().
  4385. ** ^Collation names that compare equal according to [sqlite3_strnicmp()] are
  4386. ** considered to be the same name.
  4387. **
  4388. ** ^(The third argument (eTextRep) must be one of the constants:
  4389. ** <ul>
  4390. ** <li> [SQLITE_UTF8],
  4391. ** <li> [SQLITE_UTF16LE],
  4392. ** <li> [SQLITE_UTF16BE],
  4393. ** <li> [SQLITE_UTF16], or
  4394. ** <li> [SQLITE_UTF16_ALIGNED].
  4395. ** </ul>)^
  4396. ** ^The eTextRep argument determines the encoding of strings passed
  4397. ** to the collating function callback, xCallback.
  4398. ** ^The [SQLITE_UTF16] and [SQLITE_UTF16_ALIGNED] values for eTextRep
  4399. ** force strings to be UTF16 with native byte order.
  4400. ** ^The [SQLITE_UTF16_ALIGNED] value for eTextRep forces strings to begin
  4401. ** on an even byte address.
  4402. **
  4403. ** ^The fourth argument, pArg, is an application data pointer that is passed
  4404. ** through as the first argument to the collating function callback.
  4405. **
  4406. ** ^The fifth argument, xCallback, is a pointer to the collating function.
  4407. ** ^Multiple collating functions can be registered using the same name but
  4408. ** with different eTextRep parameters and SQLite will use whichever
  4409. ** function requires the least amount of data transformation.
  4410. ** ^If the xCallback argument is NULL then the collating function is
  4411. ** deleted. ^When all collating functions having the same name are deleted,
  4412. ** that collation is no longer usable.
  4413. **
  4414. ** ^The collating function callback is invoked with a copy of the pArg
  4415. ** application data pointer and with two strings in the encoding specified
  4416. ** by the eTextRep argument. The collating function must return an
  4417. ** integer that is negative, zero, or positive
  4418. ** if the first string is less than, equal to, or greater than the second,
  4419. ** respectively. A collating function must always return the same answer
  4420. ** given the same inputs. If two or more collating functions are registered
  4421. ** to the same collation name (using different eTextRep values) then all
  4422. ** must give an equivalent answer when invoked with equivalent strings.
  4423. ** The collating function must obey the following properties for all
  4424. ** strings A, B, and C:
  4425. **
  4426. ** <ol>
  4427. ** <li> If A==B then B==A.
  4428. ** <li> If A==B and B==C then A==C.
  4429. ** <li> If A&lt;B THEN B&gt;A.
  4430. ** <li> If A&lt;B and B&lt;C then A&lt;C.
  4431. ** </ol>
  4432. **
  4433. ** If a collating function fails any of the above constraints and that
  4434. ** collating function is registered and used, then the behavior of SQLite
  4435. ** is undefined.
  4436. **
  4437. ** ^The sqlite3_create_collation_v2() works like sqlite3_create_collation()
  4438. ** with the addition that the xDestroy callback is invoked on pArg when
  4439. ** the collating function is deleted.
  4440. ** ^Collating functions are deleted when they are overridden by later
  4441. ** calls to the collation creation functions or when the
  4442. ** [database connection] is closed using [sqlite3_close()].
  4443. **
  4444. ** ^The xDestroy callback is <u>not</u> called if the
  4445. ** sqlite3_create_collation_v2() function fails. Applications that invoke
  4446. ** sqlite3_create_collation_v2() with a non-NULL xDestroy argument should
  4447. ** check the return code and dispose of the application data pointer
  4448. ** themselves rather than expecting SQLite to deal with it for them.
  4449. ** This is different from every other SQLite interface. The inconsistency
  4450. ** is unfortunate but cannot be changed without breaking backwards
  4451. ** compatibility.
  4452. **
  4453. ** See also: [sqlite3_collation_needed()] and [sqlite3_collation_needed16()].
  4454. */
  4455. //SQLITE_API int sqlite3_create_collation(
  4456. // sqlite3*,
  4457. // string zName,
  4458. // int eTextRep,
  4459. // void *pArg,
  4460. // int(*xCompare)(void*,int,const void*,int,const void)
  4461. //);
  4462. //SQLITE_API int sqlite3_create_collation_v2(
  4463. // sqlite3*,
  4464. // string zName,
  4465. // int eTextRep,
  4466. // void *pArg,
  4467. // int(*xCompare)(void*,int,const void*,int,const void),
  4468. // void(*xDestroy)(void)
  4469. //);
  4470. //SQLITE_API int sqlite3_create_collation16(
  4471. // sqlite3*,
  4472. // string zName,
  4473. // int eTextRep,
  4474. // void *pArg,
  4475. // int(*xCompare)(void*,int,const void*,int,const void)
  4476. //);
  4477. /*
  4478. ** CAPI3REF: Collation Needed Callbacks
  4479. **
  4480. ** ^To avoid having to register all collation sequences before a database
  4481. ** can be used, a single callback function may be registered with the
  4482. ** [database connection] to be invoked whenever an undefined collation
  4483. ** sequence is required.
  4484. **
  4485. ** ^If the function is registered using the sqlite3_collation_needed() API,
  4486. ** then it is passed the names of undefined collation sequences as strings
  4487. ** encoded in UTF-8. ^If sqlite3_collation_needed16() is used,
  4488. ** the names are passed as UTF-16 in machine native byte order.
  4489. ** ^A call to either function replaces the existing collation-needed callback.
  4490. **
  4491. ** ^(When the callback is invoked, the first argument passed is a copy
  4492. ** of the second argument to sqlite3_collation_needed() or
  4493. ** sqlite3_collation_needed16(). The second argument is the database
  4494. ** connection. The third argument is one of [SQLITE_UTF8], [SQLITE_UTF16BE],
  4495. ** or [SQLITE_UTF16LE], indicating the most desirable form of the collation
  4496. ** sequence function required. The fourth parameter is the name of the
  4497. ** required collation sequence.)^
  4498. **
  4499. ** The callback function should register the desired collation using
  4500. ** [sqlite3_create_collation()], [sqlite3_create_collation16()], or
  4501. ** [sqlite3_create_collation_v2()].
  4502. */
  4503. //SQLITE_API int sqlite3_collation_needed(
  4504. // sqlite3*,
  4505. // void*,
  4506. // void()(void*,sqlite3*,int eTextRep,const char)
  4507. //);
  4508. //SQLITE_API int sqlite3_collation_needed16(
  4509. // sqlite3*,
  4510. // void*,
  4511. // void()(void*,sqlite3*,int eTextRep,const void)
  4512. //);
  4513. //#if SQLITE_HAS_CODEC
  4514. /*
  4515. ** Specify the key for an encrypted database. This routine should be
  4516. ** called right after sqlite3_open().
  4517. **
  4518. ** The code to implement this API is not available in the public release
  4519. ** of SQLite.
  4520. */
  4521. //SQLITE_API int sqlite3_key(
  4522. // sqlite3 db, /* Database to be rekeyed */
  4523. // const void *pKey, int nKey /* The key */
  4524. //);
  4525. /*
  4526. ** Change the key on an open database. If the current database is not
  4527. ** encrypted, this routine will encrypt it. If pNew==0 or nNew==0, the
  4528. ** database is decrypted.
  4529. **
  4530. ** The code to implement this API is not available in the public release
  4531. ** of SQLite.
  4532. */
  4533. //SQLITE_API int sqlite3_rekey(
  4534. // sqlite3 db, /* Database to be rekeyed */
  4535. // const void *pKey, int nKey /* The new key */
  4536. //);
  4537. /*
  4538. ** Specify the activation key for a SEE database. Unless
  4539. ** activated, none of the SEE routines will work.
  4540. */
  4541. //SQLITE_API void sqlite3_activate_see(
  4542. // string zPassPhrase /* Activation phrase */
  4543. //);
  4544. //#endif
  4545. //#if SQLITE_ENABLE_CEROD
  4546. /*
  4547. ** Specify the activation key for a CEROD database. Unless
  4548. ** activated, none of the CEROD routines will work.
  4549. */
  4550. //SQLITE_API void sqlite3_activate_cerod(
  4551. // string zPassPhrase /* Activation phrase */
  4552. //);
  4553. //#endif
  4554. /*
  4555. ** CAPI3REF: Suspend Execution For A Short Time
  4556. **
  4557. ** The sqlite3_sleep() function causes the current thread to suspend execution
  4558. ** for at least a number of milliseconds specified in its parameter.
  4559. **
  4560. ** If the operating system does not support sleep requests with
  4561. ** millisecond time resolution, then the time will be rounded up to
  4562. ** the nearest second. The number of milliseconds of sleep actually
  4563. ** requested from the operating system is returned.
  4564. **
  4565. ** ^SQLite implements this interface by calling the xSleep()
  4566. ** method of the default [sqlite3_vfs] object. If the xSleep() method
  4567. ** of the default VFS is not implemented correctly, or not implemented at
  4568. ** all, then the behavior of sqlite3_sleep() may deviate from the description
  4569. ** in the previous paragraphs.
  4570. */
  4571. //SQLITE_API int sqlite3_sleep(int);
  4572. /*
  4573. ** CAPI3REF: Name Of The Folder Holding Temporary Files
  4574. **
  4575. ** ^(If this global variable is made to point to a string which is
  4576. ** the name of a folder (a.k.a. directory), then all temporary files
  4577. ** created by SQLite when using a built-in [sqlite3_vfs | VFS]
  4578. ** will be placed in that directory.)^ ^If this variable
  4579. ** is a NULL pointer, then SQLite performs a search for an appropriate
  4580. ** temporary file directory.
  4581. **
  4582. ** It is not safe to read or modify this variable in more than one
  4583. ** thread at a time. It is not safe to read or modify this variable
  4584. ** if a [database connection] is being used at the same time in a separate
  4585. ** thread.
  4586. ** It is intended that this variable be set once
  4587. ** as part of process initialization and before any SQLite interface
  4588. ** routines have been called and that this variable remain unchanged
  4589. ** thereafter.
  4590. **
  4591. ** ^The [temp_store_directory pragma] may modify this variable and cause
  4592. ** it to point to memory obtained from [sqlite3_malloc]. ^Furthermore,
  4593. ** the [temp_store_directory pragma] always assumes that any string
  4594. ** that this variable points to is held in memory obtained from
  4595. ** [sqlite3_malloc] and the pragma may attempt to free that memory
  4596. ** using [sqlite3_free].
  4597. ** Hence, if this variable is modified directly, either it should be
  4598. ** made NULL or made to point to memory obtained from [sqlite3_malloc]
  4599. ** or else the use of the [temp_store_directory pragma] should be avoided.
  4600. */
  4601. //SQLITE_API SQLITE_EXTERN char *sqlite3_temp_directory;
  4602. /*
  4603. ** CAPI3REF: Test For Auto-Commit Mode
  4604. ** KEYWORDS: {autocommit mode}
  4605. **
  4606. ** ^The sqlite3_get_autocommit() interface returns non-zero or
  4607. ** zero if the given database connection is or is not in autocommit mode,
  4608. ** respectively. ^Autocommit mode is on by default.
  4609. ** ^Autocommit mode is disabled by a [BEGIN] statement.
  4610. ** ^Autocommit mode is re-enabled by a [COMMIT] or [ROLLBACK].
  4611. **
  4612. ** If certain kinds of errors occur on a statement within a multi-statement
  4613. ** transaction (errors including [SQLITE_FULL], [SQLITE_IOERR],
  4614. ** [SQLITE_NOMEM], [SQLITE_BUSY], and [SQLITE_INTERRUPT]) then the
  4615. ** transaction might be rolled back automatically. The only way to
  4616. ** find out whether SQLite automatically rolled back the transaction after
  4617. ** an error is to use this function.
  4618. **
  4619. ** If another thread changes the autocommit status of the database
  4620. ** connection while this routine is running, then the return value
  4621. ** is undefined.
  4622. */
  4623. //SQLITE_API int sqlite3_get_autocommit(sqlite3);
  4624. /*
  4625. ** CAPI3REF: Find The Database Handle Of A Prepared Statement
  4626. **
  4627. ** ^The sqlite3_db_handle interface returns the [database connection] handle
  4628. ** to which a [prepared statement] belongs. ^The [database connection]
  4629. ** returned by sqlite3_db_handle is the same [database connection]
  4630. ** that was the first argument
  4631. ** to the [sqlite3_prepare_v2()] call (or its variants) that was used to
  4632. ** create the statement in the first place.
  4633. */
  4634. //SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt);
  4635. /*
  4636. ** CAPI3REF: Find the next prepared statement
  4637. **
  4638. ** ^This interface returns a pointer to the next [prepared statement] after
  4639. ** pStmt associated with the [database connection] pDb. ^If pStmt is NULL
  4640. ** then this interface returns a pointer to the first prepared statement
  4641. ** associated with the database connection pDb. ^If no prepared statement
  4642. ** satisfies the conditions of this routine, it returns NULL.
  4643. **
  4644. ** The [database connection] pointer D in a call to
  4645. ** [sqlite3_next_stmt(D,S)] must refer to an open database
  4646. ** connection and in particular must not be a NULL pointer.
  4647. */
  4648. //SQLITE_API sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt);
  4649. /*
  4650. ** CAPI3REF: Commit And Rollback Notification Callbacks
  4651. **
  4652. ** ^The sqlite3_commit_hook() interface registers a callback
  4653. ** function to be invoked whenever a transaction is [COMMIT | committed].
  4654. ** ^Any callback set by a previous call to sqlite3_commit_hook()
  4655. ** for the same database connection is overridden.
  4656. ** ^The sqlite3_rollback_hook() interface registers a callback
  4657. ** function to be invoked whenever a transaction is [ROLLBACK | rolled back].
  4658. ** ^Any callback set by a previous call to sqlite3_rollback_hook()
  4659. ** for the same database connection is overridden.
  4660. ** ^The pArg argument is passed through to the callback.
  4661. ** ^If the callback on a commit hook function returns non-zero,
  4662. ** then the commit is converted into a rollback.
  4663. **
  4664. ** ^The sqlite3_commit_hook(D,C,P) and sqlite3_rollback_hook(D,C,P) functions
  4665. ** return the P argument from the previous call of the same function
  4666. ** on the same [database connection] D, or NULL for
  4667. ** the first call for each function on D.
  4668. **
  4669. ** The callback implementation must not do anything that will modify
  4670. ** the database connection that invoked the callback. Any actions
  4671. ** to modify the database connection must be deferred until after the
  4672. ** completion of the [sqlite3_step()] call that triggered the commit
  4673. ** or rollback hook in the first place.
  4674. ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their
  4675. ** database connections for the meaning of "modify" in this paragraph.
  4676. **
  4677. ** ^Registering a NULL function disables the callback.
  4678. **
  4679. ** ^When the commit hook callback routine returns zero, the [COMMIT]
  4680. ** operation is allowed to continue normally. ^If the commit hook
  4681. ** returns non-zero, then the [COMMIT] is converted into a [ROLLBACK].
  4682. ** ^The rollback hook is invoked on a rollback that results from a commit
  4683. ** hook returning non-zero, just as it would be with any other rollback.
  4684. **
  4685. ** ^For the purposes of this API, a transaction is said to have been
  4686. ** rolled back if an explicit "ROLLBACK" statement is executed, or
  4687. ** an error or constraint causes an implicit rollback to occur.
  4688. ** ^The rollback callback is not invoked if a transaction is
  4689. ** automatically rolled back because the database connection is closed.
  4690. **
  4691. ** See also the [sqlite3_update_hook()] interface.
  4692. */
  4693. //SQLITE_API void *sqlite3_commit_hook(sqlite3*, int()(void), void);
  4694. //SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void()(void ), void);
  4695. /*
  4696. ** CAPI3REF: Data Change Notification Callbacks
  4697. **
  4698. ** ^The sqlite3_update_hook() interface registers a callback function
  4699. ** with the [database connection] identified by the first argument
  4700. ** to be invoked whenever a row is updated, inserted or deleted.
  4701. ** ^Any callback set by a previous call to this function
  4702. ** for the same database connection is overridden.
  4703. **
  4704. ** ^The second argument is a pointer to the function to invoke when a
  4705. ** row is updated, inserted or deleted.
  4706. ** ^The first argument to the callback is a copy of the third argument
  4707. ** to sqlite3_update_hook().
  4708. ** ^The second callback argument is one of [SQLITE_INSERT], [SQLITE_DELETE],
  4709. ** or [SQLITE_UPDATE], depending on the operation that caused the callback
  4710. ** to be invoked.
  4711. ** ^The third and fourth arguments to the callback contain pointers to the
  4712. ** database and table name containing the affected row.
  4713. ** ^The final callback parameter is the [rowid] of the row.
  4714. ** ^In the case of an update, this is the [rowid] after the update takes place.
  4715. **
  4716. ** ^(The update hook is not invoked when internal system tables are
  4717. ** modified (i.e. sqlite_master and sqlite_sequence).)^
  4718. **
  4719. ** ^In the current implementation, the update hook
  4720. ** is not invoked when duplication rows are deleted because of an
  4721. ** [ON CONFLICT | ON CONFLICT REPLACE] clause. ^Nor is the update hook
  4722. ** invoked when rows are deleted using the [truncate optimization].
  4723. ** The exceptions defined in this paragraph might change in a future
  4724. ** release of SQLite.
  4725. **
  4726. ** The update hook implementation must not do anything that will modify
  4727. ** the database connection that invoked the update hook. Any actions
  4728. ** to modify the database connection must be deferred until after the
  4729. ** completion of the [sqlite3_step()] call that triggered the update hook.
  4730. ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their
  4731. ** database connections for the meaning of "modify" in this paragraph.
  4732. **
  4733. ** ^The sqlite3_update_hook(D,C,P) function
  4734. ** returns the P argument from the previous call
  4735. ** on the same [database connection] D, or NULL for
  4736. ** the first call on D.
  4737. **
  4738. ** See also the [sqlite3_commit_hook()] and [sqlite3_rollback_hook()]
  4739. ** interfaces.
  4740. */
  4741. //SQLITE_API void *sqlite3_update_hook(
  4742. // sqlite3*,
  4743. // void()(void *,int ,char const *,char const *,sqlite3_int64),
  4744. // void*
  4745. //);
  4746. /*
  4747. ** CAPI3REF: Enable Or Disable Shared Pager Cache
  4748. ** KEYWORDS: {shared cache}
  4749. **
  4750. ** ^(This routine enables or disables the sharing of the database cache
  4751. ** and schema data structures between [database connection | connections]
  4752. ** to the same database. Sharing is enabled if the argument is true
  4753. ** and disabled if the argument is false.)^
  4754. **
  4755. ** ^Cache sharing is enabled and disabled for an entire process.
  4756. ** This is a change as of SQLite version 3.5.0. In prior versions of SQLite,
  4757. ** sharing was enabled or disabled for each thread separately.
  4758. **
  4759. ** ^(The cache sharing mode set by this interface effects all subsequent
  4760. ** calls to [sqlite3_open()], [sqlite3_open_v2()], and [sqlite3_open16()].
  4761. ** Existing database connections continue use the sharing mode
  4762. ** that was in effect at the time they were opened.)^
  4763. **
  4764. ** ^(This routine returns [SQLITE_OK] if shared cache was enabled or disabled
  4765. ** successfully. An [error code] is returned otherwise.)^
  4766. **
  4767. ** ^Shared cache is disabled by default. But this might change in
  4768. ** future releases of SQLite. Applications that care about shared
  4769. ** cache setting should set it explicitly.
  4770. **
  4771. ** See Also: [SQLite Shared-Cache Mode]
  4772. */
  4773. //SQLITE_API int sqlite3_enable_shared_cache(int);
  4774. /*
  4775. ** CAPI3REF: Attempt To Free Heap Memory
  4776. **
  4777. ** ^The sqlite3_release_memory() interface attempts to free N bytes
  4778. ** of heap memory by deallocating non-essential memory allocations
  4779. ** held by the database library. Memory used to cache database
  4780. ** pages to improve performance is an example of non-essential memory.
  4781. ** ^sqlite3_release_memory() returns the number of bytes actually freed,
  4782. ** which might be more or less than the amount requested.
  4783. ** ^The sqlite3_release_memory() routine is a no-op returning zero
  4784. ** if SQLite is not compiled with [SQLITE_ENABLE_MEMORY_MANAGEMENT].
  4785. */
  4786. //SQLITE_API int sqlite3_release_memory(int);
  4787. /*
  4788. ** CAPI3REF: Impose A Limit On Heap Size
  4789. **
  4790. ** ^The sqlite3_soft_heap_limit64() interface sets and/or queries the
  4791. ** soft limit on the amount of heap memory that may be allocated by SQLite.
  4792. ** ^SQLite strives to keep heap memory utilization below the soft heap
  4793. ** limit by reducing the number of pages held in the page cache
  4794. ** as heap memory usages approaches the limit.
  4795. ** ^The soft heap limit is "soft" because even though SQLite strives to stay
  4796. ** below the limit, it will exceed the limit rather than generate
  4797. ** an [SQLITE_NOMEM] error. In other words, the soft heap limit
  4798. ** is advisory only.
  4799. **
  4800. ** ^The return value from sqlite3_soft_heap_limit64() is the size of
  4801. ** the soft heap limit prior to the call. ^If the argument N is negative
  4802. ** then no change is made to the soft heap limit. Hence, the current
  4803. ** size of the soft heap limit can be determined by invoking
  4804. ** sqlite3_soft_heap_limit64() with a negative argument.
  4805. **
  4806. ** ^If the argument N is zero then the soft heap limit is disabled.
  4807. **
  4808. ** ^(The soft heap limit is not enforced in the current implementation
  4809. ** if one or more of following conditions are true:
  4810. **
  4811. ** <ul>
  4812. ** <li> The soft heap limit is set to zero.
  4813. ** <li> Memory accounting is disabled using a combination of the
  4814. ** [sqlite3_config]([SQLITE_CONFIG_MEMSTATUS],...) start-time option and
  4815. ** the [SQLITE_DEFAULT_MEMSTATUS] compile-time option.
  4816. ** <li> An alternative page cache implementation is specified using
  4817. ** [sqlite3_config]([SQLITE_CONFIG_PCACHE],...).
  4818. ** <li> The page cache allocates from its own memory pool supplied
  4819. ** by [sqlite3_config]([SQLITE_CONFIG_PAGECACHE],...) rather than
  4820. ** from the heap.
  4821. ** </ul>)^
  4822. **
  4823. ** Beginning with SQLite version 3.7.3, the soft heap limit is enforced
  4824. ** regardless of whether or not the [SQLITE_ENABLE_MEMORY_MANAGEMENT]
  4825. ** compile-time option is invoked. With [SQLITE_ENABLE_MEMORY_MANAGEMENT],
  4826. ** the soft heap limit is enforced on every memory allocation. Without
  4827. ** [SQLITE_ENABLE_MEMORY_MANAGEMENT], the soft heap limit is only enforced
  4828. ** when memory is allocated by the page cache. Testing suggests that because
  4829. ** the page cache is the predominate memory user in SQLite, most
  4830. ** applications will achieve adequate soft heap limit enforcement without
  4831. ** the use of [SQLITE_ENABLE_MEMORY_MANAGEMENT].
  4832. **
  4833. ** The circumstances under which SQLite will enforce the soft heap limit may
  4834. ** changes in future releases of SQLite.
  4835. */
  4836. //SQLITE_API sqlite3_int64 sqlite3_soft_heap_limit64(sqlite3_int64 N);
  4837. /*
  4838. ** CAPI3REF: Deprecated Soft Heap Limit Interface
  4839. ** DEPRECATED
  4840. **
  4841. ** This is a deprecated version of the [sqlite3_soft_heap_limit64()]
  4842. ** interface. This routine is provided for historical compatibility
  4843. ** only. All new applications should use the
  4844. ** [sqlite3_soft_heap_limit64()] interface rather than this one.
  4845. */
  4846. //SQLITE_API SQLITE_DEPRECATED void sqlite3_soft_heap_limit(int N);
  4847. /*
  4848. ** CAPI3REF: Extract Metadata About A Column Of A Table
  4849. **
  4850. ** ^This routine returns metadata about a specific column of a specific
  4851. ** database table accessible using the [database connection] handle
  4852. ** passed as the first function argument.
  4853. **
  4854. ** ^The column is identified by the second, third and fourth parameters to
  4855. ** this function. ^The second parameter is either the name of the database
  4856. ** (i.e. "main", "temp", or an attached database) containing the specified
  4857. ** table or NULL. ^If it is NULL, then all attached databases are searched
  4858. ** for the table using the same algorithm used by the database engine to
  4859. ** resolve unqualified table references.
  4860. **
  4861. ** ^The third and fourth parameters to this function are the table and column
  4862. ** name of the desired column, respectively. Neither of these parameters
  4863. ** may be NULL.
  4864. **
  4865. ** ^Metadata is returned by writing to the memory locations passed as the 5th
  4866. ** and subsequent parameters to this function. ^Any of these arguments may be
  4867. ** NULL, in which case the corresponding element of metadata is omitted.
  4868. **
  4869. ** ^(<blockquote>
  4870. ** <table border="1">
  4871. ** <tr><th> Parameter <th> Output<br>Type <th> Description
  4872. **
  4873. ** <tr><td> 5th <td> const char* <td> Data type
  4874. ** <tr><td> 6th <td> const char* <td> Name of default collation sequence
  4875. ** <tr><td> 7th <td> int <td> True if column has a NOT NULL constraint
  4876. ** <tr><td> 8th <td> int <td> True if column is part of the PRIMARY KEY
  4877. ** <tr><td> 9th <td> int <td> True if column is [AUTOINCREMENT]
  4878. ** </table>
  4879. ** </blockquote>)^
  4880. **
  4881. ** ^The memory pointed to by the character pointers returned for the
  4882. ** declaration type and collation sequence is valid only until the next
  4883. ** call to any SQLite API function.
  4884. **
  4885. ** ^If the specified table is actually a view, an [error code] is returned.
  4886. **
  4887. ** ^If the specified column is "rowid", "oid" or "_rowid_" and an
  4888. ** [INTEGER PRIMARY KEY] column has been explicitly declared, then the output
  4889. ** parameters are set for the explicitly declared column. ^(If there is no
  4890. ** explicitly declared [INTEGER PRIMARY KEY] column, then the output
  4891. ** parameters are set as follows:
  4892. **
  4893. ** <pre>
  4894. ** data type: "INTEGER"
  4895. ** collation sequence: "BINARY"
  4896. ** not null: 0
  4897. ** primary key: 1
  4898. ** auto increment: 0
  4899. ** </pre>)^
  4900. **
  4901. ** ^(This function may load one or more schemas from database files. If an
  4902. ** error occurs during this process, or if the requested table or column
  4903. ** cannot be found, an [error code] is returned and an error message left
  4904. ** in the [database connection] (to be retrieved using sqlite3_errmsg()).)^
  4905. **
  4906. ** ^This API is only available if the library was compiled with the
  4907. ** [SQLITE_ENABLE_COLUMN_METADATA] C-preprocessor symbol defined.
  4908. */
  4909. //SQLITE_API int sqlite3_table_column_metadata(
  4910. // sqlite3 db, /* Connection handle */
  4911. // string zDbName, /* Database name or NULL */
  4912. // string zTableName, /* Table name */
  4913. // string zColumnName, /* Column name */
  4914. // char const **pzDataType, /* OUTPUT: Declared data type */
  4915. // char const **pzCollSeq, /* OUTPUT: Collation sequence name */
  4916. // int *pNotNull, /* OUTPUT: True if NOT NULL constraint exists */
  4917. // int *pPrimaryKey, /* OUTPUT: True if column part of PK */
  4918. // int *pAutoinc /* OUTPUT: True if column is auto-increment */
  4919. //);
  4920. /*
  4921. ** CAPI3REF: Load An Extension
  4922. **
  4923. ** ^This interface loads an SQLite extension library from the named file.
  4924. **
  4925. ** ^The sqlite3_load_extension() interface attempts to load an
  4926. ** SQLite extension library contained in the file zFile.
  4927. **
  4928. ** ^The entry point is zProc.
  4929. ** ^zProc may be 0, in which case the name of the entry point
  4930. ** defaults to "sqlite3_extension_init".
  4931. ** ^The sqlite3_load_extension() interface returns
  4932. ** [SQLITE_OK] on success and [SQLITE_ERROR] if something goes wrong.
  4933. ** ^If an error occurs and pzErrMsg is not 0, then the
  4934. ** [sqlite3_load_extension()] interface shall attempt to
  4935. ** fill *pzErrMsg with error message text stored in memory
  4936. ** obtained from [sqlite3_malloc()]. The calling function
  4937. ** should free this memory by calling [sqlite3_free()].
  4938. **
  4939. ** ^Extension loading must be enabled using
  4940. ** [sqlite3_enable_load_extension()] prior to calling this API,
  4941. ** otherwise an error will be returned.
  4942. **
  4943. ** See also the [load_extension() SQL function].
  4944. */
  4945. //SQLITE_API int sqlite3_load_extension(
  4946. // sqlite3 db, /* Load the extension into this database connection */
  4947. // string zFile, /* Name of the shared library containing extension */
  4948. // string zProc, /* Entry point. Derived from zFile if 0 */
  4949. // char **pzErrMsg /* Put error message here if not 0 */
  4950. //);
  4951. /*
  4952. ** CAPI3REF: Enable Or Disable Extension Loading
  4953. **
  4954. ** ^So as not to open security holes in older applications that are
  4955. ** unprepared to deal with extension loading, and as a means of disabling
  4956. ** extension loading while evaluating user-entered SQL, the following API
  4957. ** is provided to turn the [sqlite3_load_extension()] mechanism on and off.
  4958. **
  4959. ** ^Extension loading is off by default. See ticket #1863.
  4960. ** ^Call the sqlite3_enable_load_extension() routine with onoff==1
  4961. ** to turn extension loading on and call it with onoff==0 to turn
  4962. ** it back off again.
  4963. */
  4964. //SQLITE_API int sqlite3_enable_load_extension(sqlite3 db, int onoff);
  4965. /*
  4966. ** CAPI3REF: Automatically Load Statically Linked Extensions
  4967. **
  4968. ** ^This interface causes the xEntryPoint() function to be invoked for
  4969. ** each new [database connection] that is created. The idea here is that
  4970. ** xEntryPoint() is the entry point for a statically linked SQLite extension
  4971. ** that is to be automatically loaded into all new database connections.
  4972. **
  4973. ** ^(Even though the function prototype shows that xEntryPoint() takes
  4974. ** no arguments and returns void, SQLite invokes xEntryPoint() with three
  4975. ** arguments and expects and integer result as if the signature of the
  4976. ** entry point where as follows:
  4977. **
  4978. ** <blockquote><pre>
  4979. ** &nbsp; int xEntryPoint(
  4980. ** &nbsp; sqlite3 db,
  4981. ** &nbsp; string *pzErrMsg,
  4982. ** &nbsp; const struct sqlite3_api_routines *pThunk
  4983. ** &nbsp; );
  4984. ** </pre></blockquote>)^
  4985. **
  4986. ** If the xEntryPoint routine encounters an error, it should make *pzErrMsg
  4987. ** point to an appropriate error message (obtained from [sqlite3_mprintf()])
  4988. ** and return an appropriate [error code]. ^SQLite ensures that *pzErrMsg
  4989. ** is NULL before calling the xEntryPoint(). ^SQLite will invoke
  4990. ** [sqlite3_free()] on *pzErrMsg after xEntryPoint() returns. ^If any
  4991. ** xEntryPoint() returns an error, the [sqlite3_open()], [sqlite3_open16()],
  4992. ** or [sqlite3_open_v2()] call that provoked the xEntryPoint() will fail.
  4993. **
  4994. ** ^Calling sqlite3_auto_extension(X) with an entry point X that is already
  4995. ** on the list of automatic extensions is a harmless no-op. ^No entry point
  4996. ** will be called more than once for each database connection that is opened.
  4997. **
  4998. ** See also: [sqlite3_reset_auto_extension()].
  4999. */
  5000. //SQLITE_API int sqlite3_auto_extension(void (*xEntryPoint)(void));
  5001. /*
  5002. ** CAPI3REF: Reset Automatic Extension Loading
  5003. **
  5004. ** ^This interface disables all automatic extensions previously
  5005. ** registered using [sqlite3_auto_extension()].
  5006. */
  5007. //SQLITE_API void sqlite3_reset_auto_extension(void);
  5008. /*
  5009. ** The interface to the virtual-table mechanism is currently considered
  5010. ** to be experimental. The interface might change in incompatible ways.
  5011. ** If this is a problem for you, do not use the interface at this time.
  5012. **
  5013. ** When the virtual-table mechanism stabilizes, we will declare the
  5014. ** interface fixed, support it indefinitely, and remove this comment.
  5015. */
  5016. /*
  5017. ** Structures used by the virtual table interface
  5018. */
  5019. //typedef struct sqlite3_vtab sqlite3_vtab;
  5020. //typedef struct sqlite3_index_info sqlite3_index_info;
  5021. //typedef struct sqlite3_vtab_cursor sqlite3_vtab_cursor;
  5022. //typedef struct sqlite3_module sqlite3_module;
  5023. /*
  5024. ** CAPI3REF: Virtual Table Object
  5025. ** KEYWORDS: sqlite3_module {virtual table module}
  5026. **
  5027. ** This structure, sometimes called a "virtual table module",
  5028. ** defines the implementation of a [virtual tables].
  5029. ** This structure consists mostly of methods for the module.
  5030. **
  5031. ** ^A virtual table module is created by filling in a persistent
  5032. ** instance of this structure and passing a pointer to that instance
  5033. ** to [sqlite3_create_module()] or [sqlite3_create_module_v2()].
  5034. ** ^The registration remains valid until it is replaced by a different
  5035. ** module or until the [database connection] closes. The content
  5036. ** of this structure must not change while it is registered with
  5037. ** any database connection.
  5038. */
  5039. //struct sqlite3_module {
  5040. // int iVersion;
  5041. // int (*xCreate)(sqlite3*, object *pAux,
  5042. // int argc, string[] argv,
  5043. // sqlite3_vtab **ppVTab, char*);
  5044. // int (*xConnect)(sqlite3*, object *pAux,
  5045. // int argc, string[] argv,
  5046. // sqlite3_vtab **ppVTab, char*);
  5047. // int (*xBestIndex)(sqlite3_vtab *pVTab, sqlite3_index_info);
  5048. // int (*xDisconnect)(sqlite3_vtab *pVTab);
  5049. // int (*xDestroy)(sqlite3_vtab *pVTab);
  5050. // int (*xOpen)(sqlite3_vtab *pVTab, sqlite3_vtab_cursor **ppCursor);
  5051. // int (*xClose)(sqlite3_vtab_cursor);
  5052. // int (*xFilter)(sqlite3_vtab_cursor*, int idxNum, string idxStr,
  5053. // int argc, sqlite3_value **argv);
  5054. // int (*xNext)(sqlite3_vtab_cursor);
  5055. // int (*xEof)(sqlite3_vtab_cursor);
  5056. // int (*xColumn)(sqlite3_vtab_cursor*, sqlite3_context*, int);
  5057. // int (*xRowid)(sqlite3_vtab_cursor*, sqlite3_int64 *pRowid);
  5058. // int (*xUpdate)(sqlite3_vtab *, int, sqlite3_value **, sqlite3_int64 );
  5059. // int (*xBegin)(sqlite3_vtab *pVTab);
  5060. // int (*xSync)(sqlite3_vtab *pVTab);
  5061. // int (*xCommit)(sqlite3_vtab *pVTab);
  5062. // int (*xRollback)(sqlite3_vtab *pVTab);
  5063. // int (*xFindFunction)(sqlite3_vtab *pVtab, int nArg, string zName,
  5064. // void (**pxFunc)(sqlite3_context*,int,sqlite3_value*),
  5065. // void **ppArg);
  5066. // int (*xRename)(sqlite3_vtab *pVtab, string zNew);
  5067. ///* The methods above are in version 1 of the sqlite_module object. Those
  5068. //** below are for version 2 and greater. */
  5069. //int (*xSavepoint)(sqlite3_vtab *pVTab, int);
  5070. //int (*xRelease)(sqlite3_vtab *pVTab, int);
  5071. //int (*xRollbackTo)(sqlite3_vtab *pVTab, int);
  5072. //};
  5073. // MINIMAL STRUCTURE
  5074. public class sqlite3_module
  5075. {
  5076. public int iVersion;
  5077. public smdxCreateConnect xCreate;
  5078. public smdxCreateConnect xConnect;
  5079. public smdxBestIndex xBestIndex;
  5080. public smdxDisconnect xDisconnect;
  5081. public smdxDestroy xDestroy;
  5082. public smdxOpen xOpen;
  5083. public smdxClose xClose;
  5084. public smdxFilter xFilter;
  5085. public smdxNext xNext;
  5086. public smdxEof xEof;
  5087. public smdxColumn xColumn;
  5088. public smdxRowid xRowid;
  5089. public smdxUpdate xUpdate;
  5090. public smdxFunction xBegin;
  5091. public smdxFunction xSync;
  5092. public smdxFunction xCommit;
  5093. public smdxFunction xRollback;
  5094. public smdxFindFunction xFindFunction;
  5095. public smdxRename xRename;
  5096. /* The methods above are in version 1 of the sqlite_module object. Those
  5097. ** below are for version 2 and greater. */
  5098. public smdxFunctionArg xSavepoint;
  5099. public smdxFunctionArg xRelease;
  5100. public smdxFunctionArg xRollbackTo;
  5101. //Version 1
  5102. public sqlite3_module(
  5103. int iVersion,
  5104. smdxCreateConnect xCreate,
  5105. smdxCreateConnect xConnect,
  5106. smdxBestIndex xBestIndex,
  5107. smdxDisconnect xDisconnect,
  5108. smdxDestroy xDestroy,
  5109. smdxOpen xOpen,
  5110. smdxClose xClose,
  5111. smdxFilter xFilter,
  5112. smdxNext xNext,
  5113. smdxEof xEof,
  5114. smdxColumn xColumn,
  5115. smdxRowid xRowid,
  5116. smdxUpdate xUpdate,
  5117. smdxFunction xBegin,
  5118. smdxFunction xSync,
  5119. smdxFunction xCommit,
  5120. smdxFunction xRollback,
  5121. smdxFindFunction xFindFunction,
  5122. smdxRename xRename )
  5123. {
  5124. this.iVersion = iVersion;
  5125. this.xCreate = xCreate;
  5126. this.xConnect = xConnect;
  5127. this.xBestIndex = xBestIndex;
  5128. this.xDisconnect = xDisconnect;
  5129. this.xDestroy = xDestroy;
  5130. this.xOpen = xOpen;
  5131. this.xClose = xClose;
  5132. this.xFilter = xFilter;
  5133. this.xNext = xNext;
  5134. this.xEof = xEof;
  5135. this.xColumn = xColumn;
  5136. this.xRowid = xRowid;
  5137. this.xUpdate = xUpdate;
  5138. this.xBegin = xBegin;
  5139. this.xSync = xSync;
  5140. this.xCommit = xCommit;
  5141. this.xRollback = xRollback;
  5142. this.xFindFunction = xFindFunction;
  5143. this.xRename = xRename;
  5144. }
  5145. //Version 2
  5146. public sqlite3_module(
  5147. int iVersion,
  5148. smdxCreateConnect xCreate,
  5149. smdxCreateConnect xConnect,
  5150. smdxBestIndex xBestIndex,
  5151. smdxDisconnect xDisconnect,
  5152. smdxDestroy xDestroy,
  5153. smdxOpen xOpen,
  5154. smdxClose xClose,
  5155. smdxFilter xFilter,
  5156. smdxNext xNext,
  5157. smdxEof xEof,
  5158. smdxColumn xColumn,
  5159. smdxRowid xRowid,
  5160. smdxUpdate xUpdate,
  5161. smdxFunction xBegin,
  5162. smdxFunction xSync,
  5163. smdxFunction xCommit,
  5164. smdxFunction xRollback,
  5165. smdxFindFunction xFindFunction,
  5166. smdxRename xRename,
  5167. /* The methods above are in version 1 of the sqlite_module object. Those
  5168. ** below are for version 2 and greater. */
  5169. smdxFunctionArg xSavepoint,
  5170. smdxFunctionArg xRelease,
  5171. smdxFunctionArg xRollbackTo
  5172. )
  5173. {
  5174. this.iVersion = iVersion;
  5175. this.xCreate = xCreate;
  5176. this.xConnect = xConnect;
  5177. this.xBestIndex = xBestIndex;
  5178. this.xDisconnect = xDisconnect;
  5179. this.xDestroy = xDestroy;
  5180. this.xOpen = xOpen;
  5181. this.xClose = xClose;
  5182. this.xFilter = xFilter;
  5183. this.xNext = xNext;
  5184. this.xEof = xEof;
  5185. this.xColumn = xColumn;
  5186. this.xRowid = xRowid;
  5187. this.xUpdate = xUpdate;
  5188. this.xBegin = xBegin;
  5189. this.xSync = xSync;
  5190. this.xCommit = xCommit;
  5191. this.xRollback = xRollback;
  5192. this.xFindFunction = xFindFunction;
  5193. this.xRename = xRename;
  5194. this.xSavepoint = xSavepoint;
  5195. this.xRelease = xRelease;
  5196. this.xRollbackTo = xRollbackTo;
  5197. }
  5198. }
  5199. /*
  5200. ** CAPI3REF: Virtual Table Indexing Information
  5201. ** KEYWORDS: sqlite3_index_info
  5202. **
  5203. ** The sqlite3_index_info structure and its substructures is used as part
  5204. ** of the [virtual table] interface to
  5205. ** pass information into and receive the reply from the [xBestIndex]
  5206. ** method of a [virtual table module]. The fields under **Inputs** are the
  5207. ** inputs to xBestIndex and are read-only. xBestIndex inserts its
  5208. ** results into the **Outputs** fields.
  5209. **
  5210. ** ^(The aConstraint[] array records WHERE clause constraints of the form:
  5211. **
  5212. ** <blockquote>column OP expr</blockquote>
  5213. **
  5214. ** where OP is =, &lt;, &lt;=, &gt;, or &gt;=.)^ ^(The particular operator is
  5215. ** stored in aConstraint[].op using one of the
  5216. ** [SQLITE_INDEX_CONSTRAINT_EQ | SQLITE_INDEX_CONSTRAINT_ values].)^
  5217. ** ^(The index of the column is stored in
  5218. ** aConstraint[].iColumn.)^ ^(aConstraint[].usable is TRUE if the
  5219. ** expr on the right-hand side can be evaluated (and thus the constraint
  5220. ** is usable) and false if it cannot.)^
  5221. **
  5222. ** ^The optimizer automatically inverts terms of the form "expr OP column"
  5223. ** and makes other simplifications to the WHERE clause in an attempt to
  5224. ** get as many WHERE clause terms into the form shown above as possible.
  5225. ** ^The aConstraint[] array only reports WHERE clause terms that are
  5226. ** relevant to the particular virtual table being queried.
  5227. **
  5228. ** ^Information about the ORDER BY clause is stored in aOrderBy[].
  5229. ** ^Each term of aOrderBy records a column of the ORDER BY clause.
  5230. **
  5231. ** The [xBestIndex] method must fill aConstraintUsage[] with information
  5232. ** about what parameters to pass to xFilter. ^If argvIndex>0 then
  5233. ** the right-hand side of the corresponding aConstraint[] is evaluated
  5234. ** and becomes the argvIndex-th entry in argv. ^(If aConstraintUsage[].omit
  5235. ** is true, then the constraint is assumed to be fully handled by the
  5236. ** virtual table and is not checked again by SQLite.)^
  5237. **
  5238. ** ^The idxNum and idxPtr values are recorded and passed into the
  5239. ** [xFilter] method.
  5240. ** ^[sqlite3_free()] is used to free idxPtr if and only if
  5241. ** needToFreeIdxPtr is true.
  5242. **
  5243. ** ^The orderByConsumed means that output from [xFilter]/[xNext] will occur in
  5244. ** the correct order to satisfy the ORDER BY clause so that no separate
  5245. ** sorting step is required.
  5246. **
  5247. ** ^The estimatedCost value is an estimate of the cost of doing the
  5248. ** particular lookup. A full scan of a table with N entries should have
  5249. ** a cost of N. A binary search of a table of N entries should have a
  5250. ** cost of approximately log(N).
  5251. */
  5252. //struct sqlite3_index_info {
  5253. // /* Inputs */
  5254. // int nConstraint; /* Number of entries in aConstraint */
  5255. // struct sqlite3_index_constraint {
  5256. // int iColumn; /* Column on left-hand side of constraint */
  5257. // unsigned char op; /* Constraint operator */
  5258. // unsigned char usable; /* True if this constraint is usable */
  5259. // int iTermOffset; /* Used internally - xBestIndex should ignore */
  5260. // } *aConstraint; /* Table of WHERE clause constraints */
  5261. // int nOrderBy; /* Number of terms in the ORDER BY clause */
  5262. // struct sqlite3_index_orderby {
  5263. // int iColumn; /* Column number */
  5264. // unsigned char desc; /* True for DESC. False for ASC. */
  5265. // } *aOrderBy; /* The ORDER BY clause */
  5266. // /* Outputs */
  5267. // struct sqlite3_index_constraint_usage {
  5268. // int argvIndex; /* if >0, constraint is part of argv to xFilter */
  5269. // unsigned char omit; /* Do not code a test for this constraint */
  5270. // } *aConstraintUsage;
  5271. // int idxNum; /* Number used to identify the index */
  5272. // char *idxStr; /* String, possibly obtained from sqlite3_malloc */
  5273. // int needToFreeIdxStr; /* Free idxStr using sqlite3_free() if true */
  5274. // int orderByConsumed; /* True if output is already ordered */
  5275. // double estimatedCost; /* Estimated cost of using this index */
  5276. //};
  5277. public class sqlite3_index_constraint
  5278. {
  5279. public int iColumn; /* Column on left-hand side of constraint */
  5280. public int op; /* Constraint operator */
  5281. public bool usable; /* True if this constraint is usable */
  5282. public int iTermOffset; /* Used internally - xBestIndex should ignore */
  5283. }
  5284. public class sqlite3_index_orderby
  5285. {
  5286. public int iColumn; /* Column number */
  5287. public bool desc; /* True for DESC. False for ASC. */
  5288. }
  5289. public class sqlite3_index_constraint_usage
  5290. {
  5291. public int argvIndex; /* if >0, constraint is part of argv to xFilter */
  5292. public bool omit; /* Do not code a test for this constraint */
  5293. }
  5294. public class sqlite3_index_info
  5295. {
  5296. /* Inputs */
  5297. public int nConstraint; /* Number of entries in aConstraint */
  5298. public sqlite3_index_constraint[] aConstraint; /* Table of WHERE clause constraints */
  5299. public int nOrderBy; /* Number of terms in the ORDER BY clause */
  5300. public sqlite3_index_orderby[] aOrderBy;/* The ORDER BY clause */
  5301. /* Outputs */
  5302. public sqlite3_index_constraint_usage[] aConstraintUsage;
  5303. public int idxNum; /* Number used to identify the index */
  5304. public string idxStr; /* String, possibly obtained from sqlite3Malloc */
  5305. public int needToFreeIdxStr; /* Free idxStr using sqlite3DbFree(db,) if true */
  5306. public bool orderByConsumed; /* True if output is already ordered */
  5307. public double estimatedCost; /* Estimated cost of using this index */
  5308. }
  5309. /*
  5310. ** CAPI3REF: Virtual Table Constraint Operator Codes
  5311. **
  5312. ** These macros defined the allowed values for the
  5313. ** [sqlite3_index_info].aConstraint[].op field. Each value represents
  5314. ** an operator that is part of a constraint term in the wHERE clause of
  5315. ** a query that uses a [virtual table].
  5316. */
  5317. //#define SQLITE_INDEX_CONSTRAINT_EQ 2
  5318. //#define SQLITE_INDEX_CONSTRAINT_GT 4
  5319. //#define SQLITE_INDEX_CONSTRAINT_LE 8
  5320. //#define SQLITE_INDEX_CONSTRAINT_LT 16
  5321. //#define SQLITE_INDEX_CONSTRAINT_GE 32
  5322. //#define SQLITE_INDEX_CONSTRAINT_MATCH 64
  5323. const int SQLITE_INDEX_CONSTRAINT_EQ = 2;
  5324. const int SQLITE_INDEX_CONSTRAINT_GT = 4;
  5325. const int SQLITE_INDEX_CONSTRAINT_LE = 8;
  5326. const int SQLITE_INDEX_CONSTRAINT_LT = 16;
  5327. const int SQLITE_INDEX_CONSTRAINT_GE = 32;
  5328. const int SQLITE_INDEX_CONSTRAINT_MATCH = 64;
  5329. /*
  5330. ** CAPI3REF: Register A Virtual Table Implementation
  5331. **
  5332. ** ^These routines are used to register a new [virtual table module] name.
  5333. ** ^Module names must be registered before
  5334. ** creating a new [virtual table] using the module and before using a
  5335. ** preexisting [virtual table] for the module.
  5336. **
  5337. ** ^The module name is registered on the [database connection] specified
  5338. ** by the first parameter. ^The name of the module is given by the
  5339. ** second parameter. ^The third parameter is a pointer to
  5340. ** the implementation of the [virtual table module]. ^The fourth
  5341. ** parameter is an arbitrary client data pointer that is passed through
  5342. ** into the [xCreate] and [xConnect] methods of the virtual table module
  5343. ** when a new virtual table is be being created or reinitialized.
  5344. **
  5345. ** ^The sqlite3_create_module_v2() interface has a fifth parameter which
  5346. ** is a pointer to a destructor for the pClientData. ^SQLite will
  5347. ** invoke the destructor function (if it is not NULL) when SQLite
  5348. ** no longer needs the pClientData pointer. ^The destructor will also
  5349. ** be invoked if the call to sqlite3_create_module_v2() fails.
  5350. ** ^The sqlite3_create_module()
  5351. ** interface is equivalent to sqlite3_create_module_v2() with a NULL
  5352. ** destructor.
  5353. */
  5354. //SQLITE_API int sqlite3_create_module(
  5355. // sqlite3 db, /* SQLite connection to register module with */
  5356. // string zName, /* Name of the module */
  5357. // const sqlite3_module *p, /* Methods for the module */
  5358. // void *pClientData /* Client data for xCreate/xConnect */
  5359. //);
  5360. //SQLITE_API int sqlite3_create_module_v2(
  5361. // sqlite3 db, /* SQLite connection to register module with */
  5362. // string zName, /* Name of the module */
  5363. // const sqlite3_module *p, /* Methods for the module */
  5364. // void *pClientData, /* Client data for xCreate/xConnect */
  5365. // void(*xDestroy)(void) /* Module destructor function */
  5366. //);
  5367. /*
  5368. ** CAPI3REF: Virtual Table Instance Object
  5369. ** KEYWORDS: sqlite3_vtab
  5370. **
  5371. ** Every [virtual table module] implementation uses a subclass
  5372. ** of this object to describe a particular instance
  5373. ** of the [virtual table]. Each subclass will
  5374. ** be tailored to the specific needs of the module implementation.
  5375. ** The purpose of this superclass is to define certain fields that are
  5376. ** common to all module implementations.
  5377. **
  5378. ** ^Virtual tables methods can set an error message by assigning a
  5379. ** string obtained from [sqlite3_mprintf()] to zErrMsg. The method should
  5380. ** take care that any prior string is freed by a call to [sqlite3_free()]
  5381. ** prior to assigning a new string to zErrMsg. ^After the error message
  5382. ** is delivered up to the client application, the string will be automatically
  5383. ** freed by sqlite3_free() and the zErrMsg field will be zeroed.
  5384. */
  5385. //struct sqlite3_vtab {
  5386. // const sqlite3_module *pModule; /* The module for this virtual table */
  5387. // int nRef; /* NO LONGER USED */
  5388. // string zErrMsg; /* Error message from sqlite3_mprintf() */
  5389. // /* Virtual table implementations will typically add additional fields */
  5390. //};
  5391. public class sqlite3_vtab
  5392. {
  5393. public sqlite3_module pModule; /* The module for this virtual table */
  5394. public int nRef; /* Used internally */
  5395. public string zErrMsg; /* Error message from sqlite3_mprintf() */
  5396. /* Virtual table implementations will typically add additional fields */
  5397. };
  5398. /*
  5399. ** CAPI3REF: Virtual Table Cursor Object
  5400. ** KEYWORDS: sqlite3_vtab_cursor {virtual table cursor}
  5401. **
  5402. ** Every [virtual table module] implementation uses a subclass of the
  5403. ** following structure to describe cursors that point into the
  5404. ** [virtual table] and are used
  5405. ** to loop through the virtual table. Cursors are created using the
  5406. ** [sqlite3_module.xOpen | xOpen] method of the module and are destroyed
  5407. ** by the [sqlite3_module.xClose | xClose] method. Cursors are used
  5408. ** by the [xFilter], [xNext], [xEof], [xColumn], and [xRowid] methods
  5409. ** of the module. Each module implementation will define
  5410. ** the content of a cursor structure to suit its own needs.
  5411. **
  5412. ** This superclass exists in order to define fields of the cursor that
  5413. ** are common to all implementations.
  5414. */
  5415. //struct sqlite3_vtab_cursor {
  5416. // sqlite3_vtab *pVtab; /* Virtual table of this cursor */
  5417. // /* Virtual table implementations will typically add additional fields */
  5418. //};
  5419. public class sqlite3_vtab_cursor
  5420. {
  5421. public sqlite3_vtab pVtab; /* Virtual table of this cursor */
  5422. /* Virtual table implementations will typically add additional fields */
  5423. };
  5424. /*
  5425. ** CAPI3REF: Declare The Schema Of A Virtual Table
  5426. **
  5427. ** ^The [xCreate] and [xConnect] methods of a
  5428. ** [virtual table module] call this interface
  5429. ** to declare the format (the names and datatypes of the columns) of
  5430. ** the virtual tables they implement.
  5431. */
  5432. //SQLITE_API int sqlite3_declare_vtab(sqlite3*, string zSQL);
  5433. /*
  5434. ** CAPI3REF: Overload A Function For A Virtual Table
  5435. **
  5436. ** ^(Virtual tables can provide alternative implementations of functions
  5437. ** using the [xFindFunction] method of the [virtual table module].
  5438. ** But global versions of those functions
  5439. ** must exist in order to be overloaded.)^
  5440. **
  5441. ** ^(This API makes sure a global version of a function with a particular
  5442. ** name and number of parameters exists. If no such function exists
  5443. ** before this API is called, a new function is created.)^ ^The implementation
  5444. ** of the new function always causes an exception to be thrown. So
  5445. ** the new function is not good for anything by itself. Its only
  5446. ** purpose is to be a placeholder function that can be overloaded
  5447. ** by a [virtual table].
  5448. */
  5449. //SQLITE_API int sqlite3_overload_function(sqlite3*, string zFuncName, int nArg);
  5450. /*
  5451. ** The interface to the virtual-table mechanism defined above (back up
  5452. ** to a comment remarkably similar to this one) is currently considered
  5453. ** to be experimental. The interface might change in incompatible ways.
  5454. ** If this is a problem for you, do not use the interface at this time.
  5455. **
  5456. ** When the virtual-table mechanism stabilizes, we will declare the
  5457. ** interface fixed, support it indefinitely, and remove this comment.
  5458. */
  5459. /*
  5460. ** CAPI3REF: A Handle To An Open BLOB
  5461. ** KEYWORDS: {BLOB handle} {BLOB handles}
  5462. **
  5463. ** An instance of this object represents an open BLOB on which
  5464. ** [sqlite3_blob_open | incremental BLOB I/O] can be performed.
  5465. ** ^Objects of this type are created by [sqlite3_blob_open()]
  5466. ** and destroyed by [sqlite3_blob_close()].
  5467. ** ^The [sqlite3_blob_read()] and [sqlite3_blob_write()] interfaces
  5468. ** can be used to read or write small subsections of the BLOB.
  5469. ** ^The [sqlite3_blob_bytes()] interface returns the size of the BLOB in bytes.
  5470. */
  5471. //typedef struct sqlite3_blob sqlite3_blob;
  5472. /*
  5473. ** CAPI3REF: Open A BLOB For Incremental I/O
  5474. **
  5475. ** ^(This interfaces opens a [BLOB handle | handle] to the BLOB located
  5476. ** in row iRow, column zColumn, table zTable in database zDb;
  5477. ** in other words, the same BLOB that would be selected by:
  5478. **
  5479. ** <pre>
  5480. ** SELECT zColumn FROM zDb.zTable WHERE [rowid] = iRow;
  5481. ** </pre>)^
  5482. **
  5483. ** ^If the flags parameter is non-zero, then the BLOB is opened for read
  5484. ** and write access. ^If it is zero, the BLOB is opened for read access.
  5485. ** ^It is not possible to open a column that is part of an index or primary
  5486. ** key for writing. ^If [foreign key constraints] are enabled, it is
  5487. ** not possible to open a column that is part of a [child key] for writing.
  5488. **
  5489. ** ^Note that the database name is not the filename that contains
  5490. ** the database but rather the symbolic name of the database that
  5491. ** appears after the AS keyword when the database is connected using [ATTACH].
  5492. ** ^For the main database file, the database name is "main".
  5493. ** ^For TEMP tables, the database name is "temp".
  5494. **
  5495. ** ^(On success, [SQLITE_OK] is returned and the new [BLOB handle] is written
  5496. ** to *ppBlob. Otherwise an [error code] is returned and *ppBlob is set
  5497. ** to be a null pointer.)^
  5498. ** ^This function sets the [database connection] error code and message
  5499. ** accessible via [sqlite3_errcode()] and [sqlite3_errmsg()] and related
  5500. ** functions. ^Note that the *ppBlob variable is always initialized in a
  5501. ** way that makes it safe to invoke [sqlite3_blob_close()] on *ppBlob
  5502. ** regardless of the success or failure of this routine.
  5503. **
  5504. ** ^(If the row that a BLOB handle points to is modified by an
  5505. ** [UPDATE], [DELETE], or by [ON CONFLICT] side-effects
  5506. ** then the BLOB handle is marked as "expired".
  5507. ** This is true if any column of the row is changed, even a column
  5508. ** other than the one the BLOB handle is open on.)^
  5509. ** ^Calls to [sqlite3_blob_read()] and [sqlite3_blob_write()] for
  5510. ** a expired BLOB handle fail with a return code of [SQLITE_ABORT].
  5511. ** ^(Changes written into a BLOB prior to the BLOB expiring are not
  5512. ** rolled back by the expiration of the BLOB. Such changes will eventually
  5513. ** commit if the transaction continues to completion.)^
  5514. **
  5515. ** ^Use the [sqlite3_blob_bytes()] interface to determine the size of
  5516. ** the opened blob. ^The size of a blob may not be changed by this
  5517. ** interface. Use the [UPDATE] SQL command to change the size of a
  5518. ** blob.
  5519. **
  5520. ** ^The [sqlite3_bind_zeroblob()] and [sqlite3_result_zeroblob()] interfaces
  5521. ** and the built-in [zeroblob] SQL function can be used, if desired,
  5522. ** to create an empty, zero-filled blob in which to read or write using
  5523. ** this interface.
  5524. **
  5525. ** To avoid a resource leak, every open [BLOB handle] should eventually
  5526. ** be released by a call to [sqlite3_blob_close()].
  5527. */
  5528. //SQLITE_API int sqlite3_blob_open(
  5529. // sqlite3*,
  5530. // string zDb,
  5531. // string zTable,
  5532. // string zColumn,
  5533. // sqlite3_int64 iRow,
  5534. // int flags,
  5535. // sqlite3_blob **ppBlob
  5536. //);
  5537. /*
  5538. ** CAPI3REF: Move a BLOB Handle to a New Row
  5539. **
  5540. ** ^This function is used to move an existing blob handle so that it points
  5541. ** to a different row of the same database table. ^The new row is identified
  5542. ** by the rowid value passed as the second argument. Only the row can be
  5543. ** changed. ^The database, table and column on which the blob handle is open
  5544. ** remain the same. Moving an existing blob handle to a new row can be
  5545. ** faster than closing the existing handle and opening a new one.
  5546. **
  5547. ** ^(The new row must meet the same criteria as for [sqlite3_blob_open()] -
  5548. ** it must exist and there must be either a blob or text value stored in
  5549. ** the nominated column.)^ ^If the new row is not present in the table, or if
  5550. ** it does not contain a blob or text value, or if another error occurs, an
  5551. ** SQLite error code is returned and the blob handle is considered aborted.
  5552. ** ^All subsequent calls to [sqlite3_blob_read()], [sqlite3_blob_write()] or
  5553. ** [sqlite3_blob_reopen()] on an aborted blob handle immediately return
  5554. ** SQLITE_ABORT. ^Calling [sqlite3_blob_bytes()] on an aborted blob handle
  5555. ** always returns zero.
  5556. **
  5557. ** ^This function sets the database handle error code and message.
  5558. */
  5559. //SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64);
  5560. /*
  5561. ** CAPI3REF: Close A BLOB Handle
  5562. **
  5563. ** ^Closes an open [BLOB handle].
  5564. **
  5565. ** ^Closing a BLOB shall cause the current transaction to commit
  5566. ** if there are no other BLOBs, no pending prepared statements, and the
  5567. ** database connection is in [autocommit mode].
  5568. ** ^If any writes were made to the BLOB, they might be held in cache
  5569. ** until the close operation if they will fit.
  5570. **
  5571. ** ^(Closing the BLOB often forces the changes
  5572. ** out to disk and so if any I/O errors occur, they will likely occur
  5573. ** at the time when the BLOB is closed. Any errors that occur during
  5574. ** closing are reported as a non-zero return value.)^
  5575. **
  5576. ** ^(The BLOB is closed unconditionally. Even if this routine returns
  5577. ** an error code, the BLOB is still closed.)^
  5578. **
  5579. ** ^Calling this routine with a null pointer (such as would be returned
  5580. ** by a failed call to [sqlite3_blob_open()]) is a harmless no-op.
  5581. */
  5582. //SQLITE_API int sqlite3_blob_close(sqlite3_blob );
  5583. /*
  5584. ** CAPI3REF: Return The Size Of An Open BLOB
  5585. **
  5586. ** ^Returns the size in bytes of the BLOB accessible via the
  5587. ** successfully opened [BLOB handle] in its only argument. ^The
  5588. ** incremental blob I/O routines can only read or overwriting existing
  5589. ** blob content; they cannot change the size of a blob.
  5590. **
  5591. ** This routine only works on a [BLOB handle] which has been created
  5592. ** by a prior successful call to [sqlite3_blob_open()] and which has not
  5593. ** been closed by [sqlite3_blob_close()]. Passing any other pointer in
  5594. ** to this routine results in undefined and probably undesirable behavior.
  5595. */
  5596. //SQLITE_API int sqlite3_blob_bytes(sqlite3_blob );
  5597. /*
  5598. ** CAPI3REF: Read Data From A BLOB Incrementally
  5599. **
  5600. ** ^(This function is used to read data from an open [BLOB handle] into a
  5601. ** caller-supplied buffer. N bytes of data are copied into buffer Z
  5602. ** from the open BLOB, starting at offset iOffset.)^
  5603. **
  5604. ** ^If offset iOffset is less than N bytes from the end of the BLOB,
  5605. ** [SQLITE_ERROR] is returned and no data is read. ^If N or iOffset is
  5606. ** less than zero, [SQLITE_ERROR] is returned and no data is read.
  5607. ** ^The size of the blob (and hence the maximum value of N+iOffset)
  5608. ** can be determined using the [sqlite3_blob_bytes()] interface.
  5609. **
  5610. ** ^An attempt to read from an expired [BLOB handle] fails with an
  5611. ** error code of [SQLITE_ABORT].
  5612. **
  5613. ** ^(On success, sqlite3_blob_read() returns SQLITE_OK.
  5614. ** Otherwise, an [error code] or an [extended error code] is returned.)^
  5615. **
  5616. ** This routine only works on a [BLOB handle] which has been created
  5617. ** by a prior successful call to [sqlite3_blob_open()] and which has not
  5618. ** been closed by [sqlite3_blob_close()]. Passing any other pointer in
  5619. ** to this routine results in undefined and probably undesirable behavior.
  5620. **
  5621. ** See also: [sqlite3_blob_write()].
  5622. */
  5623. //SQLITE_API int sqlite3_blob_read(sqlite3_blob *, object *Z, int N, int iOffset);
  5624. /*
  5625. ** CAPI3REF: Write Data Into A BLOB Incrementally
  5626. **
  5627. ** ^This function is used to write data into an open [BLOB handle] from a
  5628. ** caller-supplied buffer. ^N bytes of data are copied from the buffer Z
  5629. ** into the open BLOB, starting at offset iOffset.
  5630. **
  5631. ** ^If the [BLOB handle] passed as the first argument was not opened for
  5632. ** writing (the flags parameter to [sqlite3_blob_open()] was zero),
  5633. ** this function returns [SQLITE_READONLY].
  5634. **
  5635. ** ^This function may only modify the contents of the BLOB; it is
  5636. ** not possible to increase the size of a BLOB using this API.
  5637. ** ^If offset iOffset is less than N bytes from the end of the BLOB,
  5638. ** [SQLITE_ERROR] is returned and no data is written. ^If N is
  5639. ** less than zero [SQLITE_ERROR] is returned and no data is written.
  5640. ** The size of the BLOB (and hence the maximum value of N+iOffset)
  5641. ** can be determined using the [sqlite3_blob_bytes()] interface.
  5642. **
  5643. ** ^An attempt to write to an expired [BLOB handle] fails with an
  5644. ** error code of [SQLITE_ABORT]. ^Writes to the BLOB that occurred
  5645. ** before the [BLOB handle] expired are not rolled back by the
  5646. ** expiration of the handle, though of course those changes might
  5647. ** have been overwritten by the statement that expired the BLOB handle
  5648. ** or by other independent statements.
  5649. **
  5650. ** ^(On success, sqlite3_blob_write() returns SQLITE_OK.
  5651. ** Otherwise, an [error code] or an [extended error code] is returned.)^
  5652. **
  5653. ** This routine only works on a [BLOB handle] which has been created
  5654. ** by a prior successful call to [sqlite3_blob_open()] and which has not
  5655. ** been closed by [sqlite3_blob_close()]. Passing any other pointer in
  5656. ** to this routine results in undefined and probably undesirable behavior.
  5657. **
  5658. ** See also: [sqlite3_blob_read()].
  5659. */
  5660. //SQLITE_API int sqlite3_blob_write(sqlite3_blob *, string z, int n, int iOffset);
  5661. /*
  5662. ** CAPI3REF: Virtual File System Objects
  5663. **
  5664. ** A virtual filesystem (VFS) is an [sqlite3_vfs] object
  5665. ** that SQLite uses to interact
  5666. ** with the underlying operating system. Most SQLite builds come with a
  5667. ** single default VFS that is appropriate for the host computer.
  5668. ** New VFSes can be registered and existing VFSes can be unregistered.
  5669. ** The following interfaces are provided.
  5670. **
  5671. ** ^The sqlite3_vfs_find() interface returns a pointer to a VFS given its name.
  5672. ** ^Names are case sensitive.
  5673. ** ^Names are zero-terminated UTF-8 strings.
  5674. ** ^If there is no match, a NULL pointer is returned.
  5675. ** ^If zVfsName is NULL then the default VFS is returned.
  5676. **
  5677. ** ^New VFSes are registered with sqlite3_vfs_register().
  5678. ** ^Each new VFS becomes the default VFS if the makeDflt flag is set.
  5679. ** ^The same VFS can be registered multiple times without injury.
  5680. ** ^To make an existing VFS into the default VFS, register it again
  5681. ** with the makeDflt flag set. If two different VFSes with the
  5682. ** same name are registered, the behavior is undefined. If a
  5683. ** VFS is registered with a name that is NULL or an empty string,
  5684. ** then the behavior is undefined.
  5685. **
  5686. ** ^Unregister a VFS with the sqlite3_vfs_unregister() interface.
  5687. ** ^(If the default VFS is unregistered, another VFS is chosen as
  5688. ** the default. The choice for the new VFS is arbitrary.)^
  5689. */
  5690. //SQLITE_API sqlite3_vfs *sqlite3_vfs_find(string zVfsName);
  5691. //SQLITE_API int sqlite3_vfs_register(sqlite3_vfs*, int makeDflt);
  5692. //SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs);
  5693. /*
  5694. ** CAPI3REF: Mutexes
  5695. **
  5696. ** The SQLite core uses these routines for thread
  5697. ** synchronization. Though they are intended for internal
  5698. ** use by SQLite, code that links against SQLite is
  5699. ** permitted to use any of these routines.
  5700. **
  5701. ** The SQLite source code contains multiple implementations
  5702. ** of these mutex routines. An appropriate implementation
  5703. ** is selected automatically at compile-time. ^(The following
  5704. ** implementations are available in the SQLite core:
  5705. **
  5706. ** <ul>
  5707. ** <li> SQLITE_MUTEX_OS2
  5708. ** <li> SQLITE_MUTEX_PTHREAD
  5709. ** <li> SQLITE_MUTEX_W32
  5710. ** <li> SQLITE_MUTEX_NOOP
  5711. ** </ul>)^
  5712. **
  5713. ** ^The SQLITE_MUTEX_NOOP implementation is a set of routines
  5714. ** that does no real locking and is appropriate for use in
  5715. ** a single-threaded application. ^The SQLITE_MUTEX_OS2,
  5716. ** SQLITE_MUTEX_PTHREAD, and SQLITE_MUTEX_W32 implementations
  5717. ** are appropriate for use on OS/2, Unix, and Windows.
  5718. **
  5719. ** ^(If SQLite is compiled with the SQLITE_MUTEX_APPDEF preprocessor
  5720. ** macro defined (with "-DSQLITE_MUTEX_APPDEF=1"), then no mutex
  5721. ** implementation is included with the library. In this case the
  5722. ** application must supply a custom mutex implementation using the
  5723. ** [SQLITE_CONFIG_MUTEX] option of the sqlite3_config() function
  5724. ** before calling sqlite3_initialize() or any other public sqlite3_
  5725. ** function that calls sqlite3_initialize().)^
  5726. **
  5727. ** ^The sqlite3_mutex_alloc() routine allocates a new
  5728. ** mutex and returns a pointer to it. ^If it returns NULL
  5729. ** that means that a mutex could not be allocated. ^SQLite
  5730. ** will unwind its stack and return an error. ^(The argument
  5731. ** to sqlite3_mutex_alloc() is one of these integer constants:
  5732. **
  5733. ** <ul>
  5734. ** <li> SQLITE_MUTEX_FAST
  5735. ** <li> SQLITE_MUTEX_RECURSIVE
  5736. ** <li> SQLITE_MUTEX_STATIC_MASTER
  5737. ** <li> SQLITE_MUTEX_STATIC_MEM
  5738. ** <li> SQLITE_MUTEX_STATIC_MEM2
  5739. ** <li> SQLITE_MUTEX_STATIC_PRNG
  5740. ** <li> SQLITE_MUTEX_STATIC_LRU
  5741. ** <li> SQLITE_MUTEX_STATIC_LRU2
  5742. ** </ul>)^
  5743. **
  5744. ** ^The first two constants (SQLITE_MUTEX_FAST and SQLITE_MUTEX_RECURSIVE)
  5745. ** cause sqlite3_mutex_alloc() to create
  5746. ** a new mutex. ^The new mutex is recursive when SQLITE_MUTEX_RECURSIVE
  5747. ** is used but not necessarily so when SQLITE_MUTEX_FAST is used.
  5748. ** The mutex implementation does not need to make a distinction
  5749. ** between SQLITE_MUTEX_RECURSIVE and SQLITE_MUTEX_FAST if it does
  5750. ** not want to. ^SQLite will only request a recursive mutex in
  5751. ** cases where it really needs one. ^If a faster non-recursive mutex
  5752. ** implementation is available on the host platform, the mutex subsystem
  5753. ** might return such a mutex in response to SQLITE_MUTEX_FAST.
  5754. **
  5755. ** ^The other allowed parameters to sqlite3_mutex_alloc() (anything other
  5756. ** than SQLITE_MUTEX_FAST and SQLITE_MUTEX_RECURSIVE) each return
  5757. ** a pointer to a static preexisting mutex. ^Six static mutexes are
  5758. ** used by the current version of SQLite. Future versions of SQLite
  5759. ** may add additional static mutexes. Static mutexes are for internal
  5760. ** use by SQLite only. Applications that use SQLite mutexes should
  5761. ** use only the dynamic mutexes returned by SQLITE_MUTEX_FAST or
  5762. ** SQLITE_MUTEX_RECURSIVE.
  5763. **
  5764. ** ^Note that if one of the dynamic mutex parameters (SQLITE_MUTEX_FAST
  5765. ** or SQLITE_MUTEX_RECURSIVE) is used then sqlite3_mutex_alloc()
  5766. ** returns a different mutex on every call. ^But for the static
  5767. ** mutex types, the same mutex is returned on every call that has
  5768. ** the same type number.
  5769. **
  5770. ** ^The sqlite3_mutex_free() routine deallocates a previously
  5771. ** allocated dynamic mutex. ^SQLite is careful to deallocate every
  5772. ** dynamic mutex that it allocates. The dynamic mutexes must not be in
  5773. ** use when they are deallocated. Attempting to deallocate a static
  5774. ** mutex results in undefined behavior. ^SQLite never deallocates
  5775. ** a static mutex.
  5776. **
  5777. ** ^The sqlite3_mutex_enter() and sqlite3_mutex_try() routines attempt
  5778. ** to enter a mutex. ^If another thread is already within the mutex,
  5779. ** sqlite3_mutex_enter() will block and sqlite3_mutex_try() will return
  5780. ** SQLITE_BUSY. ^The sqlite3_mutex_try() interface returns [SQLITE_OK]
  5781. ** upon successful entry. ^(Mutexes created using
  5782. ** SQLITE_MUTEX_RECURSIVE can be entered multiple times by the same thread.
  5783. ** In such cases the,
  5784. ** mutex must be exited an equal number of times before another thread
  5785. ** can enter.)^ ^(If the same thread tries to enter any other
  5786. ** kind of mutex more than once, the behavior is undefined.
  5787. ** SQLite will never exhibit
  5788. ** such behavior in its own use of mutexes.)^
  5789. **
  5790. ** ^(Some systems (for example, Windows 95) do not support the operation
  5791. ** implemented by sqlite3_mutex_try(). On those systems, sqlite3_mutex_try()
  5792. ** will always return SQLITE_BUSY. The SQLite core only ever uses
  5793. ** sqlite3_mutex_try() as an optimization so this is acceptable behavior.)^
  5794. **
  5795. ** ^The sqlite3_mutex_leave() routine exits a mutex that was
  5796. ** previously entered by the same thread. ^(The behavior
  5797. ** is undefined if the mutex is not currently entered by the
  5798. ** calling thread or is not currently allocated. SQLite will
  5799. ** never do either.)^
  5800. **
  5801. ** ^If the argument to sqlite3_mutex_enter(), sqlite3_mutex_try(), or
  5802. ** sqlite3_mutex_leave() is a NULL pointer, then all three routines
  5803. ** behave as no-ops.
  5804. **
  5805. ** See also: [sqlite3_mutex_held()] and [sqlite3_mutex_notheld()].
  5806. */
  5807. //SQLITE_API sqlite3_mutex *sqlite3_mutex_alloc(int);
  5808. //SQLITE_API void sqlite3_mutex_free(sqlite3_mutex);
  5809. //SQLITE_API void sqlite3_mutex_enter(sqlite3_mutex);
  5810. //SQLITE_API int sqlite3_mutex_try(sqlite3_mutex);
  5811. //SQLITE_API void sqlite3_mutex_leave(sqlite3_mutex);
  5812. /*
  5813. ** CAPI3REF: Mutex Methods Object
  5814. **
  5815. ** An instance of this structure defines the low-level routines
  5816. ** used to allocate and use mutexes.
  5817. **
  5818. ** Usually, the default mutex implementations provided by SQLite are
  5819. ** sufficient, however the user has the option of substituting a custom
  5820. ** implementation for specialized deployments or systems for which SQLite
  5821. ** does not provide a suitable implementation. In this case, the user
  5822. ** creates and populates an instance of this structure to pass
  5823. ** to sqlite3_config() along with the [SQLITE_CONFIG_MUTEX] option.
  5824. ** Additionally, an instance of this structure can be used as an
  5825. ** output variable when querying the system for the current mutex
  5826. ** implementation, using the [SQLITE_CONFIG_GETMUTEX] option.
  5827. **
  5828. ** ^The xMutexInit method defined by this structure is invoked as
  5829. ** part of system initialization by the sqlite3_initialize() function.
  5830. ** ^The xMutexInit routine is called by SQLite exactly once for each
  5831. ** effective call to [sqlite3_initialize()].
  5832. **
  5833. ** ^The xMutexEnd method defined by this structure is invoked as
  5834. ** part of system shutdown by the sqlite3_shutdown() function. The
  5835. ** implementation of this method is expected to release all outstanding
  5836. ** resources obtained by the mutex methods implementation, especially
  5837. ** those obtained by the xMutexInit method. ^The xMutexEnd()
  5838. ** interface is invoked exactly once for each call to [sqlite3_shutdown()].
  5839. **
  5840. ** ^(The remaining seven methods defined by this structure (xMutexAlloc,
  5841. ** xMutexFree, xMutexEnter, xMutexTry, xMutexLeave, xMutexHeld and
  5842. ** xMutexNotheld) implement the following interfaces (respectively):
  5843. **
  5844. ** <ul>
  5845. ** <li> [sqlite3_mutex_alloc()] </li>
  5846. ** <li> [sqlite3_mutex_free()] </li>
  5847. ** <li> [sqlite3_mutex_enter()] </li>
  5848. ** <li> [sqlite3_mutex_try()] </li>
  5849. ** <li> [sqlite3_mutex_leave()] </li>
  5850. ** <li> [sqlite3_mutex_held()] </li>
  5851. ** <li> [sqlite3_mutex_notheld()] </li>
  5852. ** </ul>)^
  5853. **
  5854. ** The only difference is that the public sqlite3_XXX functions enumerated
  5855. ** above silently ignore any invocations that pass a NULL pointer instead
  5856. ** of a valid mutex handle. The implementations of the methods defined
  5857. ** by this structure are not required to handle this case, the results
  5858. ** of passing a NULL pointer instead of a valid mutex handle are undefined
  5859. ** (i.e. it is acceptable to provide an implementation that segfaults if
  5860. ** it is passed a NULL pointer).
  5861. **
  5862. ** The xMutexInit() method must be threadsafe. ^It must be harmless to
  5863. ** invoke xMutexInit() multiple times within the same process and without
  5864. ** intervening calls to xMutexEnd(). Second and subsequent calls to
  5865. ** xMutexInit() must be no-ops.
  5866. **
  5867. ** ^xMutexInit() must not use SQLite memory allocation ([sqlite3_malloc()]
  5868. ** and its associates). ^Similarly, xMutexAlloc() must not use SQLite memory
  5869. ** allocation for a static mutex. ^However xMutexAlloc() may use SQLite
  5870. ** memory allocation for a fast or recursive mutex.
  5871. **
  5872. ** ^SQLite will invoke the xMutexEnd() method when [sqlite3_shutdown()] is
  5873. ** called, but only if the prior call to xMutexInit returned SQLITE_OK.
  5874. ** If xMutexInit fails in any way, it is expected to clean up after itself
  5875. ** prior to returning.
  5876. */
  5877. //typedef struct sqlite3_mutex_methods sqlite3_mutex_methods;
  5878. //struct sqlite3_mutex_methods {
  5879. // int (*xMutexInit)(void);
  5880. // int (*xMutexEnd)(void);
  5881. // sqlite3_mutex *(*xMutexAlloc)(int);
  5882. // void (*xMutexFree)(sqlite3_mutex );
  5883. // void (*xMutexEnter)(sqlite3_mutex );
  5884. // int (*xMutexTry)(sqlite3_mutex );
  5885. // void (*xMutexLeave)(sqlite3_mutex );
  5886. // int (*xMutexHeld)(sqlite3_mutex );
  5887. // int (*xMutexNotheld)(sqlite3_mutex );
  5888. //};
  5889. public class sqlite3_mutex_methods
  5890. {
  5891. public dxMutexInit xMutexInit;
  5892. public dxMutexEnd xMutexEnd;
  5893. public dxMutexAlloc xMutexAlloc;
  5894. public dxMutexFree xMutexFree;
  5895. public dxMutexEnter xMutexEnter;
  5896. public dxMutexTry xMutexTry;
  5897. public dxMutexLeave xMutexLeave;
  5898. public dxMutexHeld xMutexHeld;
  5899. public dxMutexNotheld xMutexNotheld;
  5900. public sqlite3_mutex_methods()
  5901. {
  5902. }
  5903. public sqlite3_mutex_methods(
  5904. dxMutexInit xMutexInit,
  5905. dxMutexEnd xMutexEnd,
  5906. dxMutexAlloc xMutexAlloc,
  5907. dxMutexFree xMutexFree,
  5908. dxMutexEnter xMutexEnter,
  5909. dxMutexTry xMutexTry,
  5910. dxMutexLeave xMutexLeave,
  5911. dxMutexHeld xMutexHeld,
  5912. dxMutexNotheld xMutexNotheld
  5913. )
  5914. {
  5915. this.xMutexInit = xMutexInit;
  5916. this.xMutexEnd = xMutexEnd;
  5917. this.xMutexAlloc = xMutexAlloc;
  5918. this.xMutexFree = xMutexFree;
  5919. this.xMutexEnter = xMutexEnter;
  5920. this.xMutexTry = xMutexTry;
  5921. this.xMutexLeave = xMutexLeave;
  5922. this.xMutexHeld = xMutexHeld;
  5923. this.xMutexNotheld = xMutexNotheld;
  5924. }
  5925. //Copy sqlite3_mutex_methods from existing
  5926. public void Copy( sqlite3_mutex_methods cp )
  5927. {
  5928. Debug.Assert( cp != null );
  5929. this.xMutexInit = cp.xMutexInit;
  5930. this.xMutexEnd = cp.xMutexEnd;
  5931. this.xMutexAlloc = cp.xMutexAlloc;
  5932. this.xMutexFree = cp.xMutexFree;
  5933. this.xMutexEnter = cp.xMutexEnter;
  5934. this.xMutexTry = cp.xMutexTry;
  5935. this.xMutexLeave = cp.xMutexLeave;
  5936. this.xMutexHeld = cp.xMutexHeld;
  5937. this.xMutexNotheld = cp.xMutexNotheld;
  5938. }
  5939. }
  5940. /*
  5941. ** CAPI3REF: Mutex Verification Routines
  5942. **
  5943. ** The sqlite3_mutex_held() and sqlite3_mutex_notheld() routines
  5944. ** are intended for use inside Debug.Assert() statements. ^The SQLite core
  5945. ** never uses these routines except inside an Debug.Assert() and applications
  5946. ** are advised to follow the lead of the core. ^The SQLite core only
  5947. ** provides implementations for these routines when it is compiled
  5948. ** with the SQLITE_DEBUG flag. ^External mutex implementations
  5949. ** are only required to provide these routines if SQLITE_DEBUG is
  5950. ** defined and if NDEBUG is not defined.
  5951. **
  5952. ** ^These routines should return true if the mutex in their argument
  5953. ** is held or not held, respectively, by the calling thread.
  5954. **
  5955. ** ^The implementation is not required to provided versions of these
  5956. ** routines that actually work. If the implementation does not provide working
  5957. ** versions of these routines, it should at least provide stubs that always
  5958. ** return true so that one does not get spurious assertion failures.
  5959. **
  5960. ** ^If the argument to sqlite3_mutex_held() is a NULL pointer then
  5961. ** the routine should return 1. This seems counter-intuitive since
  5962. ** clearly the mutex cannot be held if it does not exist. But
  5963. ** the reason the mutex does not exist is because the build is not
  5964. ** using mutexes. And we do not want the Debug.Assert() containing the
  5965. ** call to sqlite3_mutex_held() to fail, so a non-zero return is
  5966. ** the appropriate thing to do. ^The sqlite3_mutex_notheld()
  5967. ** interface should also return 1 when given a NULL pointer.
  5968. */
  5969. //#if !NDEBUG
  5970. //SQLITE_API int sqlite3_mutex_held(sqlite3_mutex);
  5971. //SQLITE_API int sqlite3_mutex_notheld(sqlite3_mutex);
  5972. //#endif
  5973. /*
  5974. ** CAPI3REF: Mutex Types
  5975. **
  5976. ** The [sqlite3_mutex_alloc()] interface takes a single argument
  5977. ** which is one of these integer constants.
  5978. **
  5979. ** The set of static mutexes may change from one SQLite release to the
  5980. ** next. Applications that override the built-in mutex logic must be
  5981. ** prepared to accommodate additional static mutexes.
  5982. */
  5983. //#define SQLITE_MUTEX_FAST 0
  5984. //#define SQLITE_MUTEX_RECURSIVE 1
  5985. //#define SQLITE_MUTEX_STATIC_MASTER 2
  5986. //#define SQLITE_MUTEX_STATIC_MEM 3 /* sqlite3_malloc() */
  5987. //#define SQLITE_MUTEX_STATIC_MEM2 4 /* NOT USED */
  5988. //#define SQLITE_MUTEX_STATIC_OPEN 4 /* sqlite3BtreeOpen() */
  5989. //#define SQLITE_MUTEX_STATIC_PRNG 5 /* sqlite3_random() */
  5990. //#define SQLITE_MUTEX_STATIC_LRU 6 /* lru page list */
  5991. //#define SQLITE_MUTEX_STATIC_LRU2 7 /* NOT USED */
  5992. //#define SQLITE_MUTEX_STATIC_PMEM 7 /* sqlite3PageMalloc() */
  5993. const int SQLITE_MUTEX_FAST = 0;
  5994. const int SQLITE_MUTEX_RECURSIVE = 1;
  5995. const int SQLITE_MUTEX_STATIC_MASTER = 2;
  5996. const int SQLITE_MUTEX_STATIC_MEM = 3;
  5997. const int SQLITE_MUTEX_STATIC_MEM2 = 4;
  5998. const int SQLITE_MUTEX_STATIC_OPEN = 4;
  5999. const int SQLITE_MUTEX_STATIC_PRNG = 5;
  6000. const int SQLITE_MUTEX_STATIC_LRU = 6;
  6001. const int SQLITE_MUTEX_STATIC_LRU2 = 7;
  6002. const int SQLITE_MUTEX_STATIC_PMEM = 7;
  6003. /*
  6004. ** CAPI3REF: Retrieve the mutex for a database connection
  6005. **
  6006. ** ^This interface returns a pointer the [sqlite3_mutex] object that
  6007. ** serializes access to the [database connection] given in the argument
  6008. ** when the [threading mode] is Serialized.
  6009. ** ^If the [threading mode] is Single-thread or Multi-thread then this
  6010. ** routine returns a NULL pointer.
  6011. */
  6012. //SQLITE_API sqlite3_mutex *sqlite3_db_mutex(sqlite3);
  6013. /*
  6014. ** CAPI3REF: Low-Level Control Of Database Files
  6015. **
  6016. ** ^The [sqlite3_file_control()] interface makes a direct call to the
  6017. ** xFileControl method for the [sqlite3_io_methods] object associated
  6018. ** with a particular database identified by the second argument. ^The
  6019. ** name of the database is "main" for the main database or "temp" for the
  6020. ** TEMP database, or the name that appears after the AS keyword for
  6021. ** databases that are added using the [ATTACH] SQL command.
  6022. ** ^A NULL pointer can be used in place of "main" to refer to the
  6023. ** main database file.
  6024. ** ^The third and fourth parameters to this routine
  6025. ** are passed directly through to the second and third parameters of
  6026. ** the xFileControl method. ^The return value of the xFileControl
  6027. ** method becomes the return value of this routine.
  6028. **
  6029. ** ^The SQLITE_FCNTL_FILE_POINTER value for the op parameter causes
  6030. ** a pointer to the underlying [sqlite3_file] object to be written into
  6031. ** the space pointed to by the 4th parameter. ^The SQLITE_FCNTL_FILE_POINTER
  6032. ** case is a short-circuit path which does not actually invoke the
  6033. ** underlying sqlite3_io_methods.xFileControl method.
  6034. **
  6035. ** ^If the second parameter (zDbName) does not match the name of any
  6036. ** open database file, then SQLITE_ERROR is returned. ^This error
  6037. ** code is not remembered and will not be recalled by [sqlite3_errcode()]
  6038. ** or [sqlite3_errmsg()]. The underlying xFileControl method might
  6039. ** also return SQLITE_ERROR. There is no way to distinguish between
  6040. ** an incorrect zDbName and an SQLITE_ERROR return from the underlying
  6041. ** xFileControl method.
  6042. **
  6043. ** See also: [SQLITE_FCNTL_LOCKSTATE]
  6044. */
  6045. //SQLITE_API int sqlite3_file_control(sqlite3*, string zDbName, int op, void);
  6046. /*
  6047. ** CAPI3REF: Testing Interface
  6048. **
  6049. ** ^The sqlite3_test_control() interface is used to read out internal
  6050. ** state of SQLite and to inject faults into SQLite for testing
  6051. ** purposes. ^The first parameter is an operation code that determines
  6052. ** the number, meaning, and operation of all subsequent parameters.
  6053. **
  6054. ** This interface is not for use by applications. It exists solely
  6055. ** for verifying the correct operation of the SQLite library. Depending
  6056. ** on how the SQLite library is compiled, this interface might not exist.
  6057. **
  6058. ** The details of the operation codes, their meanings, the parameters
  6059. ** they take, and what they do are all subject to change without notice.
  6060. ** Unlike most of the SQLite API, this function is not guaranteed to
  6061. ** operate consistently from one release to the next.
  6062. */
  6063. //SQLITE_API int sqlite3_test_control(int op, ...);
  6064. /*
  6065. ** CAPI3REF: Testing Interface Operation Codes
  6066. **
  6067. ** These constants are the valid operation code parameters used
  6068. ** as the first argument to [sqlite3_test_control()].
  6069. **
  6070. ** These parameters and their meanings are subject to change
  6071. ** without notice. These values are for testing purposes only.
  6072. ** Applications should not use any of these parameters or the
  6073. ** [sqlite3_test_control()] interface.
  6074. */
  6075. //#define SQLITE_TESTCTRL_FIRST 5
  6076. //#define SQLITE_TESTCTRL_PRNG_SAVE 5
  6077. //#define SQLITE_TESTCTRL_PRNG_RESTORE 6
  6078. //#define SQLITE_TESTCTRL_PRNG_RESET 7
  6079. //#define SQLITE_TESTCTRL_BITVEC_TEST 8
  6080. //#define SQLITE_TESTCTRL_FAULT_INSTALL 9
  6081. //#define SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS 10
  6082. //#define SQLITE_TESTCTRL_PENDING_BYTE 11
  6083. //#define SQLITE_TESTCTRL_ASSERT 12
  6084. //#define SQLITE_TESTCTRL_ALWAYS 13
  6085. //#define SQLITE_TESTCTRL_RESERVE 14
  6086. //#define SQLITE_TESTCTRL_OPTIMIZATIONS 15
  6087. //#define SQLITE_TESTCTRL_ISKEYWORD 16
  6088. //#define SQLITE_TESTCTRL_PGHDRSZ 17
  6089. //#define SQLITE_TESTCTRL_SCRATCHMALLOC 18
  6090. //#define SQLITE_TESTCTRL_LOCALTIME_FAULT 19
  6091. //#define SQLITE_TESTCTRL_LAST 19
  6092. public const int SQLITE_TESTCTRL_FIRST = 5;
  6093. public const int SQLITE_TESTCTRL_PRNG_SAVE = 5;
  6094. public const int SQLITE_TESTCTRL_PRNG_RESTORE = 6;
  6095. public const int SQLITE_TESTCTRL_PRNG_RESET = 7;
  6096. public const int SQLITE_TESTCTRL_BITVEC_TEST = 8;
  6097. public const int SQLITE_TESTCTRL_FAULT_INSTALL = 9;
  6098. public const int SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS = 10;
  6099. public const int SQLITE_TESTCTRL_PENDING_BYTE = 11;
  6100. public const int SQLITE_TESTCTRL_ASSERT = 12;
  6101. public const int SQLITE_TESTCTRL_ALWAYS = 13;
  6102. public const int SQLITE_TESTCTRL_RESERVE = 14;
  6103. public const int SQLITE_TESTCTRL_OPTIMIZATIONS = 15;
  6104. public const int SQLITE_TESTCTRL_ISKEYWORD = 16;
  6105. public const int SQLITE_TESTCTRL_PGHDRSZ = 17;
  6106. public const int SQLITE_TESTCTRL_SCRATCHMALLOC = 18;
  6107. public const int SQLITE_TESTCTRL_LOCALTIME_FAULT = 19;
  6108. public const int SQLITE_TESTCTRL_LAST = 19;
  6109. /*
  6110. ** CAPI3REF: SQLite Runtime Status
  6111. **
  6112. ** ^This interface is used to retrieve runtime status information
  6113. ** about the performance of SQLite, and optionally to reset various
  6114. ** highwater marks. ^The first argument is an integer code for
  6115. ** the specific parameter to measure. ^(Recognized integer codes
  6116. ** are of the form [status parameters | SQLITE_STATUS_...].)^
  6117. ** ^The current value of the parameter is returned into *pCurrent.
  6118. ** ^The highest recorded value is returned in *pHighwater. ^If the
  6119. ** resetFlag is true, then the highest record value is reset after
  6120. ** *pHighwater is written. ^(Some parameters do not record the highest
  6121. ** value. For those parameters
  6122. ** nothing is written into *pHighwater and the resetFlag is ignored.)^
  6123. ** ^(Other parameters record only the highwater mark and not the current
  6124. ** value. For these latter parameters nothing is written into *pCurrent.)^
  6125. **
  6126. ** ^The sqlite3_status() routine returns SQLITE_OK on success and a
  6127. ** non-zero [error code] on failure.
  6128. **
  6129. ** This routine is threadsafe but is not atomic. This routine can be
  6130. ** called while other threads are running the same or different SQLite
  6131. ** interfaces. However the values returned in *pCurrent and
  6132. ** *pHighwater reflect the status of SQLite at different points in time
  6133. ** and it is possible that another thread might change the parameter
  6134. ** in between the times when *pCurrent and *pHighwater are written.
  6135. **
  6136. ** See also: [sqlite3_db_status()]
  6137. */
  6138. //SQLITE_API int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag);
  6139. /*
  6140. ** CAPI3REF: Status Parameters
  6141. ** KEYWORDS: {status parameters}
  6142. **
  6143. ** These integer constants designate various run-time status parameters
  6144. ** that can be returned by [sqlite3_status()].
  6145. **
  6146. ** <dl>
  6147. ** [[SQLITE_STATUS_MEMORY_USED]] ^(<dt>SQLITE_STATUS_MEMORY_USED</dt>
  6148. ** <dd>This parameter is the current amount of memory checked out
  6149. ** using [sqlite3_malloc()], either directly or indirectly. The
  6150. ** figure includes calls made to [sqlite3_malloc()] by the application
  6151. ** and internal memory usage by the SQLite library. Scratch memory
  6152. ** controlled by [SQLITE_CONFIG_SCRATCH] and auxiliary page-cache
  6153. ** memory controlled by [SQLITE_CONFIG_PAGECACHE] is not included in
  6154. ** this parameter. The amount returned is the sum of the allocation
  6155. ** sizes as reported by the xSize method in [sqlite3_mem_methods].</dd>)^
  6156. **
  6157. ** [[SQLITE_STATUS_MALLOC_SIZE]] ^(<dt>SQLITE_STATUS_MALLOC_SIZE</dt>
  6158. ** <dd>This parameter records the largest memory allocation request
  6159. ** handed to [sqlite3_malloc()] or [sqlite3_realloc()] (or their
  6160. ** internal equivalents). Only the value returned in the
  6161. ** *pHighwater parameter to [sqlite3_status()] is of interest.
  6162. ** The value written into the *pCurrent parameter is undefined.</dd>)^
  6163. **
  6164. ** [[SQLITE_STATUS_MALLOC_COUNT]] ^(<dt>SQLITE_STATUS_MALLOC_COUNT</dt>
  6165. ** <dd>This parameter records the number of separate memory allocations
  6166. ** currently checked out.</dd>)^
  6167. **
  6168. ** [[SQLITE_STATUS_PAGECACHE_USED]] ^(<dt>SQLITE_STATUS_PAGECACHE_USED</dt>
  6169. ** <dd>This parameter returns the number of pages used out of the
  6170. ** [pagecache memory allocator] that was configured using
  6171. ** [SQLITE_CONFIG_PAGECACHE]. The
  6172. ** value returned is in pages, not in bytes.</dd>)^
  6173. **
  6174. ** [[SQLITE_STATUS_PAGECACHE_OVERFLOW]]
  6175. ** ^(<dt>SQLITE_STATUS_PAGECACHE_OVERFLOW</dt>
  6176. ** <dd>This parameter returns the number of bytes of page cache
  6177. ** allocation which could not be satisfied by the [SQLITE_CONFIG_PAGECACHE]
  6178. ** buffer and where forced to overflow to [sqlite3_malloc()]. The
  6179. ** returned value includes allocations that overflowed because they
  6180. ** where too large (they were larger than the "sz" parameter to
  6181. ** [SQLITE_CONFIG_PAGECACHE]) and allocations that overflowed because
  6182. ** no space was left in the page cache.</dd>)^
  6183. **
  6184. ** [[SQLITE_STATUS_PAGECACHE_SIZE]] ^(<dt>SQLITE_STATUS_PAGECACHE_SIZE</dt>
  6185. ** <dd>This parameter records the largest memory allocation request
  6186. ** handed to [pagecache memory allocator]. Only the value returned in the
  6187. ** *pHighwater parameter to [sqlite3_status()] is of interest.
  6188. ** The value written into the *pCurrent parameter is undefined.</dd>)^
  6189. **
  6190. ** [[SQLITE_STATUS_SCRATCH_USED]] ^(<dt>SQLITE_STATUS_SCRATCH_USED</dt>
  6191. ** <dd>This parameter returns the number of allocations used out of the
  6192. ** [scratch memory allocator] configured using
  6193. ** [SQLITE_CONFIG_SCRATCH]. The value returned is in allocations, not
  6194. ** in bytes. Since a single thread may only have one scratch allocation
  6195. ** outstanding at time, this parameter also reports the number of threads
  6196. ** using scratch memory at the same time.</dd>)^
  6197. **
  6198. ** [[SQLITE_STATUS_SCRATCH_OVERFLOW]] ^(<dt>SQLITE_STATUS_SCRATCH_OVERFLOW</dt>
  6199. ** <dd>This parameter returns the number of bytes of scratch memory
  6200. ** allocation which could not be satisfied by the [SQLITE_CONFIG_SCRATCH]
  6201. ** buffer and where forced to overflow to [sqlite3_malloc()]. The values
  6202. ** returned include overflows because the requested allocation was too
  6203. ** larger (that is, because the requested allocation was larger than the
  6204. ** "sz" parameter to [SQLITE_CONFIG_SCRATCH]) and because no scratch buffer
  6205. ** slots were available.
  6206. ** </dd>)^
  6207. **
  6208. ** [[SQLITE_STATUS_SCRATCH_SIZE]] ^(<dt>SQLITE_STATUS_SCRATCH_SIZE</dt>
  6209. ** <dd>This parameter records the largest memory allocation request
  6210. ** handed to [scratch memory allocator]. Only the value returned in the
  6211. ** *pHighwater parameter to [sqlite3_status()] is of interest.
  6212. ** The value written into the *pCurrent parameter is undefined.</dd>)^
  6213. **
  6214. ** [[SQLITE_STATUS_PARSER_STACK]] ^(<dt>SQLITE_STATUS_PARSER_STACK</dt>
  6215. ** <dd>This parameter records the deepest parser stack. It is only
  6216. ** meaningful if SQLite is compiled with [YYTRACKMAXSTACKDEPTH].</dd>)^
  6217. ** </dl>
  6218. **
  6219. ** New status parameters may be added from time to time.
  6220. */
  6221. //#define SQLITE_STATUS_MEMORY_USED 0
  6222. //#define SQLITE_STATUS_PAGECACHE_USED 1
  6223. //#define SQLITE_STATUS_PAGECACHE_OVERFLOW 2
  6224. //#define SQLITE_STATUS_SCRATCH_USED 3
  6225. //#define SQLITE_STATUS_SCRATCH_OVERFLOW 4
  6226. //#define SQLITE_STATUS_MALLOC_SIZE 5
  6227. //#define SQLITE_STATUS_PARSER_STACK 6
  6228. //#define SQLITE_STATUS_PAGECACHE_SIZE 7
  6229. //#define SQLITE_STATUS_SCRATCH_SIZE 8
  6230. //#define SQLITE_STATUS_MALLOC_COUNT 9
  6231. public const int SQLITE_STATUS_MEMORY_USED = 0;
  6232. public const int SQLITE_STATUS_PAGECACHE_USED = 1;
  6233. public const int SQLITE_STATUS_PAGECACHE_OVERFLOW = 2;
  6234. public const int SQLITE_STATUS_SCRATCH_USED = 3;
  6235. public const int SQLITE_STATUS_SCRATCH_OVERFLOW = 4;
  6236. public const int SQLITE_STATUS_MALLOC_SIZE = 5;
  6237. public const int SQLITE_STATUS_PARSER_STACK = 6;
  6238. public const int SQLITE_STATUS_PAGECACHE_SIZE = 7;
  6239. public const int SQLITE_STATUS_SCRATCH_SIZE = 8;
  6240. public const int SQLITE_STATUS_MALLOC_COUNT = 9;
  6241. /*
  6242. ** CAPI3REF: Database Connection Status
  6243. **
  6244. ** ^This interface is used to retrieve runtime status information
  6245. ** about a single [database connection]. ^The first argument is the
  6246. ** database connection object to be interrogated. ^The second argument
  6247. ** is an integer constant, taken from the set of
  6248. ** [SQLITE_DBSTATUS options], that
  6249. ** determines the parameter to interrogate. The set of
  6250. ** [SQLITE_DBSTATUS options] is likely
  6251. ** to grow in future releases of SQLite.
  6252. **
  6253. ** ^The current value of the requested parameter is written into *pCur
  6254. ** and the highest instantaneous value is written into *pHiwtr. ^If
  6255. ** the resetFlg is true, then the highest instantaneous value is
  6256. ** reset back down to the current value.
  6257. **
  6258. ** ^The sqlite3_db_status() routine returns SQLITE_OK on success and a
  6259. ** non-zero [error code] on failure.
  6260. **
  6261. ** See also: [sqlite3_status()] and [sqlite3_stmt_status()].
  6262. */
  6263. //SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int resetFlg);
  6264. /*
  6265. ** CAPI3REF: Status Parameters for database connections
  6266. ** KEYWORDS: {SQLITE_DBSTATUS options}
  6267. **
  6268. ** These constants are the available integer "verbs" that can be passed as
  6269. ** the second argument to the [sqlite3_db_status()] interface.
  6270. **
  6271. ** New verbs may be added in future releases of SQLite. Existing verbs
  6272. ** might be discontinued. Applications should check the return code from
  6273. ** [sqlite3_db_status()] to make sure that the call worked.
  6274. ** The [sqlite3_db_status()] interface will return a non-zero error code
  6275. ** if a discontinued or unsupported verb is invoked.
  6276. **
  6277. ** <dl>
  6278. ** [[SQLITE_DBSTATUS_LOOKASIDE_USED]] ^(<dt>SQLITE_DBSTATUS_LOOKASIDE_USED</dt>
  6279. ** <dd>This parameter returns the number of lookaside memory slots currently
  6280. ** checked out.</dd>)^
  6281. **
  6282. ** [[SQLITE_DBSTATUS_LOOKASIDE_HIT]] ^(<dt>SQLITE_DBSTATUS_LOOKASIDE_HIT</dt>
  6283. ** <dd>This parameter returns the number malloc attempts that were
  6284. ** satisfied using lookaside memory. Only the high-water value is meaningful;
  6285. ** the current value is always zero.)^
  6286. **
  6287. ** [[SQLITE_DBSTATUS_LOOKASIDE_MISS_SIZE]]
  6288. ** ^(<dt>SQLITE_DBSTATUS_LOOKASIDE_MISS_SIZE</dt>
  6289. ** <dd>This parameter returns the number malloc attempts that might have
  6290. ** been satisfied using lookaside memory but failed due to the amount of
  6291. ** memory requested being larger than the lookaside slot size.
  6292. ** Only the high-water value is meaningful;
  6293. ** the current value is always zero.)^
  6294. **
  6295. ** [[SQLITE_DBSTATUS_LOOKASIDE_MISS_FULL]]
  6296. ** ^(<dt>SQLITE_DBSTATUS_LOOKASIDE_MISS_FULL</dt>
  6297. ** <dd>This parameter returns the number malloc attempts that might have
  6298. ** been satisfied using lookaside memory but failed due to all lookaside
  6299. ** memory already being in use.
  6300. ** Only the high-water value is meaningful;
  6301. ** the current value is always zero.)^
  6302. **
  6303. ** [[SQLITE_DBSTATUS_CACHE_USED]] ^(<dt>SQLITE_DBSTATUS_CACHE_USED</dt>
  6304. ** <dd>This parameter returns the approximate number of of bytes of heap
  6305. ** memory used by all pager caches associated with the database connection.)^
  6306. ** ^The highwater mark associated with SQLITE_DBSTATUS_CACHE_USED is always 0.
  6307. **
  6308. ** [[SQLITE_DBSTATUS_SCHEMA_USED]] ^(<dt>SQLITE_DBSTATUS_SCHEMA_USED</dt>
  6309. ** <dd>This parameter returns the approximate number of of bytes of heap
  6310. ** memory used to store the schema for all databases associated
  6311. ** with the connection - main, temp, and any [ATTACH]-ed databases.)^
  6312. ** ^The full amount of memory used by the schemas is reported, even if the
  6313. ** schema memory is shared with other database connections due to
  6314. ** [shared cache mode] being enabled.
  6315. ** ^The highwater mark associated with SQLITE_DBSTATUS_SCHEMA_USED is always 0.
  6316. **
  6317. ** [[SQLITE_DBSTATUS_STMT_USED]] ^(<dt>SQLITE_DBSTATUS_STMT_USED</dt>
  6318. ** <dd>This parameter returns the approximate number of of bytes of heap
  6319. ** and lookaside memory used by all prepared statements associated with
  6320. ** the database connection.)^
  6321. ** ^The highwater mark associated with SQLITE_DBSTATUS_STMT_USED is always 0.
  6322. ** </dd>
  6323. ** </dl>
  6324. */
  6325. //#define SQLITE_DBSTATUS_LOOKASIDE_USED 0
  6326. //#define SQLITE_DBSTATUS_CACHE_USED 1
  6327. //#define SQLITE_DBSTATUS_SCHEMA_USED 2
  6328. //#define SQLITE_DBSTATUS_STMT_USED 3
  6329. //#define SQLITE_DBSTATUS_LOOKASIDE_HIT 4
  6330. //#define SQLITE_DBSTATUS_LOOKASIDE_MISS_SIZE 5
  6331. //#define SQLITE_DBSTATUS_LOOKASIDE_MISS_FULL 6
  6332. //#define SQLITE_DBSTATUS_MAX 6 /* Largest defined DBSTATUS */
  6333. public const int SQLITE_DBSTATUS_LOOKASIDE_USED = 0;
  6334. public const int SQLITE_DBSTATUS_CACHE_USED = 1;
  6335. public const int SQLITE_DBSTATUS_SCHEMA_USED = 2;
  6336. public const int SQLITE_DBSTATUS_STMT_USED = 3;
  6337. public const int SQLITE_DBSTATUS_LOOKASIDE_HIT = 4;
  6338. public const int SQLITE_DBSTATUS_LOOKASIDE_MISS_SIZE = 5;
  6339. public const int SQLITE_DBSTATUS_LOOKASIDE_MISS_FULL = 6;
  6340. public const int SQLITE_DBSTATUS_MAX = 6;
  6341. /*
  6342. ** CAPI3REF: Prepared Statement Status
  6343. **
  6344. ** ^(Each prepared statement maintains various
  6345. ** [SQLITE_STMTSTATUS counters] that measure the number
  6346. ** of times it has performed specific operations.)^ These counters can
  6347. ** be used to monitor the performance characteristics of the prepared
  6348. ** statements. For example, if the number of table steps greatly exceeds
  6349. ** the number of table searches or result rows, that would tend to indicate
  6350. ** that the prepared statement is using a full table scan rather than
  6351. ** an index.
  6352. **
  6353. ** ^(This interface is used to retrieve and reset counter values from
  6354. ** a [prepared statement]. The first argument is the prepared statement
  6355. ** object to be interrogated. The second argument
  6356. ** is an integer code for a specific [SQLITE_STMTSTATUS counte
  6357. ** to be interrogated.)^
  6358. ** ^The current value of the requested counter is returned.
  6359. ** ^If the resetFlg is true, then the counter is reset to zero after this
  6360. ** interface call returns.
  6361. **
  6362. ** See also: [sqlite3_status()] and [sqlite3_db_status()].
  6363. */
  6364. //SQLITE_API int sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
  6365. /*
  6366. ** CAPI3REF: Status Parameters for prepared statements
  6367. ** KEYWORDS: {SQLITE_STMTSTATUS counter} {SQLITE_STMTSTATUS counters}
  6368. **
  6369. ** These preprocessor macros define integer codes that name counter
  6370. ** values associated with the [sqlite3_stmt_status()] interface.
  6371. ** The meanings of the various counters are as follows:
  6372. **
  6373. ** <dl>
  6374. ** [[SQLITE_STMTSTATUS_FULLSCAN_STEP]] <dt>SQLITE_STMTSTATUS_FULLSCAN_STEP</dt>
  6375. ** <dd>^This is the number of times that SQLite has stepped forward in
  6376. ** a table as part of a full table scan. Large numbers for this counter
  6377. ** may indicate opportunities for performance improvement through
  6378. ** careful use of indices.</dd>
  6379. **
  6380. ** [[SQLITE_STMTSTATUS_SORT]] <dt>SQLITE_STMTSTATUS_SORT</dt>
  6381. ** <dd>^This is the number of sort operations that have occurred.
  6382. ** A non-zero value in this counter may indicate an opportunity to
  6383. ** improvement performance through careful use of indices.</dd>
  6384. **
  6385. ** [[SQLITE_STMTSTATUS_AUTOINDEX]] <dt>SQLITE_STMTSTATUS_AUTOINDEX</dt>
  6386. ** <dd>^This is the number of rows inserted into transient indices that
  6387. ** were created automatically in order to help joins run faster.
  6388. ** A non-zero value in this counter may indicate an opportunity to
  6389. ** improvement performance by adding permanent indices that do not
  6390. ** need to be reinitialized each time the statement is run.</dd>
  6391. **
  6392. ** </dl>
  6393. */
  6394. //#define SQLITE_STMTSTATUS_FULLSCAN_STEP 1
  6395. //#define SQLITE_STMTSTATUS_SORT 2
  6396. //#define SQLITE_STMTSTATUS_AUTOINDEX 3
  6397. public const int SQLITE_STMTSTATUS_FULLSCAN_STEP = 1;
  6398. public const int SQLITE_STMTSTATUS_SORT = 2;
  6399. public const int SQLITE_STMTSTATUS_AUTOINDEX = 3;
  6400. /*
  6401. ** CAPI3REF: Custom Page Cache Object
  6402. **
  6403. ** The sqlite3_pcache type is opaque. It is implemented by
  6404. ** the pluggable module. The SQLite core has no knowledge of
  6405. ** its size or internal structure and never deals with the
  6406. ** sqlite3_pcache object except by holding and passing pointers
  6407. ** to the object.
  6408. **
  6409. ** See [sqlite3_pcache_methods] for additional information.
  6410. */
  6411. //typedef struct sqlite3_pcache sqlite3_pcache;
  6412. /*
  6413. ** CAPI3REF: Application Defined Page Cache.
  6414. ** KEYWORDS: {page cache}
  6415. **
  6416. ** ^(The [sqlite3_config]([SQLITE_CONFIG_PCACHE], ...) interface can
  6417. ** register an alternative page cache implementation by passing in an
  6418. ** instance of the sqlite3_pcache_methods structure.)^
  6419. ** In many applications, most of the heap memory allocated by
  6420. ** SQLite is used for the page cache.
  6421. ** By implementing a
  6422. ** custom page cache using this API, an application can better control
  6423. ** the amount of memory consumed by SQLite, the way in which
  6424. ** that memory is allocated and released, and the policies used to
  6425. ** determine exactly which parts of a database file are cached and for
  6426. ** how long.
  6427. **
  6428. ** The alternative page cache mechanism is an
  6429. ** extreme measure that is only needed by the most demanding applications.
  6430. ** The built-in page cache is recommended for most uses.
  6431. **
  6432. ** ^(The contents of the sqlite3_pcache_methods structure are copied to an
  6433. ** internal buffer by SQLite within the call to [sqlite3_config]. Hence
  6434. ** the application may discard the parameter after the call to
  6435. ** [sqlite3_config()] returns.)^
  6436. **
  6437. ** [[the xInit() page cache method]]
  6438. ** ^(The xInit() method is called once for each effective
  6439. ** call to [sqlite3_initialize()])^
  6440. ** (usually only once during the lifetime of the process). ^(The xInit()
  6441. ** method is passed a copy of the sqlite3_pcache_methods.pArg value.)^
  6442. ** The intent of the xInit() method is to set up global data structures
  6443. ** required by the custom page cache implementation.
  6444. ** ^(If the xInit() method is NULL, then the
  6445. ** built-in default page cache is used instead of the application defined
  6446. ** page cache.)^
  6447. **
  6448. ** [[the xShutdown() page cache method]]
  6449. ** ^The xShutdown() method is called by [sqlite3_shutdown()].
  6450. ** It can be used to clean up
  6451. ** any outstanding resources before process shutdown, if required.
  6452. ** ^The xShutdown() method may be NULL.
  6453. **
  6454. ** ^SQLite automatically serializes calls to the xInit method,
  6455. ** so the xInit method need not be threadsafe. ^The
  6456. ** xShutdown method is only called from [sqlite3_shutdown()] so it does
  6457. ** not need to be threadsafe either. All other methods must be threadsafe
  6458. ** in multithreaded applications.
  6459. **
  6460. ** ^SQLite will never invoke xInit() more than once without an intervening
  6461. ** call to xShutdown().
  6462. **
  6463. ** [[the xCreate() page cache methods]]
  6464. ** ^SQLite invokes the xCreate() method to construct a new cache instance.
  6465. ** SQLite will typically create one cache instance for each open database file,
  6466. ** though this is not guaranteed. ^The
  6467. ** first parameter, szPage, is the size in bytes of the pages that must
  6468. ** be allocated by the cache. ^szPage will not be a power of two. ^szPage
  6469. ** will the page size of the database file that is to be cached plus an
  6470. ** increment (here called "R") of less than 250. SQLite will use the
  6471. ** extra R bytes on each page to store metadata about the underlying
  6472. ** database page on disk. The value of R depends
  6473. ** on the SQLite version, the target platform, and how SQLite was compiled.
  6474. ** ^(R is constant for a particular build of SQLite. Except, there are two
  6475. ** distinct values of R when SQLite is compiled with the proprietary
  6476. ** ZIPVFS extension.)^ ^The second argument to
  6477. ** xCreate(), bPurgeable, is true if the cache being created will
  6478. ** be used to cache database pages of a file stored on disk, or
  6479. ** false if it is used for an in-memory database. The cache implementation
  6480. ** does not have to do anything special based with the value of bPurgeable;
  6481. ** it is purely advisory. ^On a cache where bPurgeable is false, SQLite will
  6482. ** never invoke xUnpin() except to deliberately delete a page.
  6483. ** ^In other words, calls to xUnpin() on a cache with bPurgeable set to
  6484. ** false will always have the "discard" flag set to true.
  6485. ** ^Hence, a cache created with bPurgeable false will
  6486. ** never contain any unpinned pages.
  6487. **
  6488. ** [[the xCachesize() page cache method]]
  6489. ** ^(The xCachesize() method may be called at any time by SQLite to set the
  6490. ** suggested maximum cache-size (number of pages stored by) the cache
  6491. ** instance passed as the first argument. This is the value configured using
  6492. ** the SQLite "[PRAGMA cache_size]" command.)^ As with the bPurgeable
  6493. ** parameter, the implementation is not required to do anything with this
  6494. ** value; it is advisory only.
  6495. **
  6496. ** [[the xPagecount() page cache methods]]
  6497. ** The xPagecount() method must return the number of pages currently
  6498. ** stored in the cache, both pinned and unpinned.
  6499. **
  6500. ** [[the xFetch() page cache methods]]
  6501. ** The xFetch() method locates a page in the cache and returns a pointer to
  6502. ** the page, or a NULL pointer.
  6503. ** A "page", in this context, means a buffer of szPage bytes aligned at an
  6504. ** 8-byte boundary. The page to be fetched is determined by the key. ^The
  6505. ** minimum key value is 1. After it has been retrieved using xFetch, the page
  6506. ** is considered to be "pinned".
  6507. **
  6508. ** If the requested page is already in the page cache, then the page cache
  6509. ** implementation must return a pointer to the page buffer with its content
  6510. ** intact. If the requested page is not already in the cache, then the
  6511. ** cache implementation should use the value of the createFlag
  6512. ** parameter to help it determined what action to take:
  6513. **
  6514. ** <table border=1 width=85% align=center>
  6515. ** <tr><th> createFlag <th> Behaviour when page is not already in cache
  6516. ** <tr><td> 0 <td> Do not allocate a new page. Return NULL.
  6517. ** <tr><td> 1 <td> Allocate a new page if it easy and convenient to do so.
  6518. ** Otherwise return NULL.
  6519. ** <tr><td> 2 <td> Make every effort to allocate a new page. Only return
  6520. ** NULL if allocating a new page is effectively impossible.
  6521. ** </table>
  6522. **
  6523. ** ^(SQLite will normally invoke xFetch() with a createFlag of 0 or 1. SQLite
  6524. ** will only use a createFlag of 2 after a prior call with a createFlag of 1
  6525. ** failed.)^ In between the to xFetch() calls, SQLite may
  6526. ** attempt to unpin one or more cache pages by spilling the content of
  6527. ** pinned pages to disk and synching the operating system disk cache.
  6528. **
  6529. ** [[the xUnpin() page cache method]]
  6530. ** ^xUnpin() is called by SQLite with a pointer to a currently pinned page
  6531. ** as its second argument. If the third parameter, discard, is non-zero,
  6532. ** then the page must be evicted from the cache.
  6533. ** ^If the discard parameter is
  6534. ** zero, then the page may be discarded or retained at the discretion of
  6535. ** page cache implementation. ^The page cache implementation
  6536. ** may choose to evict unpinned pages at any time.
  6537. **
  6538. ** The cache must not perform any reference counting. A single
  6539. ** call to xUnpin() unpins the page regardless of the number of prior calls
  6540. ** to xFetch().
  6541. **
  6542. ** [[the xRekey() page cache methods]]
  6543. ** The xRekey() method is used to change the key value associated with the
  6544. ** page passed as the second argument. If the cache
  6545. ** previously contains an entry associated with newKey, it must be
  6546. ** discarded. ^Any prior cache entry associated with newKey is guaranteed not
  6547. ** to be pinned.
  6548. **
  6549. ** When SQLite calls the xTruncate() method, the cache must discard all
  6550. ** existing cache entries with page numbers (keys) greater than or equal
  6551. ** to the value of the iLimit parameter passed to xTruncate(). If any
  6552. ** of these pages are pinned, they are implicitly unpinned, meaning that
  6553. ** they can be safely discarded.
  6554. **
  6555. ** [[the xDestroy() page cache method]]
  6556. ** ^The xDestroy() method is used to delete a cache allocated by xCreate().
  6557. ** All resources associated with the specified cache should be freed. ^After
  6558. ** calling the xDestroy() method, SQLite considers the [sqlite3_pcache*]
  6559. ** handle invalid, and will not use it with any other sqlite3_pcache_methods
  6560. ** functions.
  6561. */
  6562. //typedef struct sqlite3_pcache_methods sqlite3_pcache_methods;
  6563. //struct sqlite3_pcache_methods {
  6564. // void *pArg;
  6565. // int (*xInit)(void);
  6566. // void (*xShutdown)(void);
  6567. // sqlite3_pcache *(*xCreate)(int szPage, int bPurgeable);
  6568. // void (*xCachesize)(sqlite3_pcache*, int nCachesize);
  6569. // int (*xPagecount)(sqlite3_pcache);
  6570. // void *(*xFetch)(sqlite3_pcache*, unsigned key, int createFlag);
  6571. // void (*xUnpin)(sqlite3_pcache*, void*, int discard);
  6572. // void (*xRekey)(sqlite3_pcache*, void*, unsigned oldKey, unsigned newKey);
  6573. // void (*xTruncate)(sqlite3_pcache*, unsigned iLimit);
  6574. // void (*xDestroy)(sqlite3_pcache);
  6575. //};
  6576. public class sqlite3_pcache_methods
  6577. {
  6578. public object pArg;
  6579. public dxPC_Init xInit;//int (*xInit)(void);
  6580. public dxPC_Shutdown xShutdown;//public void (*xShutdown)(void);
  6581. public dxPC_Create xCreate;//public sqlite3_pcache *(*xCreate)(int szPage, int bPurgeable);
  6582. public dxPC_Cachesize xCachesize;//public void (*xCachesize)(sqlite3_pcache*, int nCachesize);
  6583. public dxPC_Pagecount xPagecount;//public int (*xPagecount)(sqlite3_pcache);
  6584. public dxPC_Fetch xFetch;//public void *(*xFetch)(sqlite3_pcache*, unsigned key, int createFlag);
  6585. public dxPC_Unpin xUnpin;//public void (*xUnpin)(sqlite3_pcache*, void*, int discard);
  6586. public dxPC_Rekey xRekey;//public void (*xRekey)(sqlite3_pcache*, void*, unsigned oldKey, unsigned newKey);
  6587. public dxPC_Truncate xTruncate;//public void (*xTruncate)(sqlite3_pcache*, unsigned iLimit);
  6588. public dxPC_Destroy xDestroy;//public void (*xDestroy)(sqlite3_pcache);
  6589. public sqlite3_pcache_methods()
  6590. {
  6591. }
  6592. public sqlite3_pcache_methods( object pArg, dxPC_Init xInit, dxPC_Shutdown xShutdown, dxPC_Create xCreate, dxPC_Cachesize xCachesize, dxPC_Pagecount xPagecount, dxPC_Fetch xFetch, dxPC_Unpin xUnpin, dxPC_Rekey xRekey, dxPC_Truncate xTruncate, dxPC_Destroy xDestroy )
  6593. {
  6594. this.pArg = pArg;
  6595. this.xInit = xInit;
  6596. this.xShutdown = xShutdown;
  6597. this.xCreate = xCreate;
  6598. this.xCachesize = xCachesize;
  6599. this.xPagecount = xPagecount;
  6600. this.xFetch = xFetch;
  6601. this.xUnpin = xUnpin;
  6602. this.xRekey = xRekey;
  6603. this.xTruncate = xTruncate;
  6604. this.xDestroy = xDestroy;
  6605. }
  6606. };
  6607. /*
  6608. ** CAPI3REF: Online Backup Object
  6609. **
  6610. ** The sqlite3_backup object records state information about an ongoing
  6611. ** online backup operation. ^The sqlite3_backup object is created by
  6612. ** a call to [sqlite3_backup_init()] and is destroyed by a call to
  6613. ** [sqlite3_backup_finish()].
  6614. **
  6615. ** See Also: [Using the SQLite Online Backup API]
  6616. */
  6617. //typedef struct sqlite3_backup sqlite3_backup;
  6618. /*
  6619. ** CAPI3REF: Online Backup API.
  6620. **
  6621. ** The backup API copies the content of one database into another.
  6622. ** It is useful either for creating backups of databases or
  6623. ** for copying in-memory databases to or from persistent files.
  6624. **
  6625. ** See Also: [Using the SQLite Online Backup API]
  6626. **
  6627. ** ^SQLite holds a write transaction open on the destination database file
  6628. ** for the duration of the backup operation.
  6629. ** ^The source database is read-locked only while it is being read;
  6630. ** it is not locked continuously for the entire backup operation.
  6631. ** ^Thus, the backup may be performed on a live source database without
  6632. ** preventing other database connections from
  6633. ** reading or writing to the source database while the backup is underway.
  6634. **
  6635. ** ^(To perform a backup operation:
  6636. ** <ol>
  6637. ** <li><b>sqlite3_backup_init()</b> is called once to initialize the
  6638. ** backup,
  6639. ** <li><b>sqlite3_backup_step()</b> is called one or more times to transfer
  6640. ** the data between the two databases, and finally
  6641. ** <li><b>sqlite3_backup_finish()</b> is called to release all resources
  6642. ** associated with the backup operation.
  6643. ** </ol>)^
  6644. ** There should be exactly one call to sqlite3_backup_finish() for each
  6645. ** successful call to sqlite3_backup_init().
  6646. **
  6647. ** [[sqlite3_backup_init()]] <b>sqlite3_backup_init()</b>
  6648. **
  6649. ** ^The D and N arguments to sqlite3_backup_init(D,N,S,M) are the
  6650. ** [database connection] associated with the destination database
  6651. ** and the database name, respectively.
  6652. ** ^The database name is "main" for the main database, "temp" for the
  6653. ** temporary database, or the name specified after the AS keyword in
  6654. ** an [ATTACH] statement for an attached database.
  6655. ** ^The S and M arguments passed to
  6656. ** sqlite3_backup_init(D,N,S,M) identify the [database connection]
  6657. ** and database name of the source database, respectively.
  6658. ** ^The source and destination [database connections] (parameters S and D)
  6659. ** must be different or else sqlite3_backup_init(D,N,S,M) will fail with
  6660. ** an error.
  6661. **
  6662. ** ^If an error occurs within sqlite3_backup_init(D,N,S,M), then NULL is
  6663. ** returned and an error code and error message are stored in the
  6664. ** destination [database connection] D.
  6665. ** ^The error code and message for the failed call to sqlite3_backup_init()
  6666. ** can be retrieved using the [sqlite3_errcode()], [sqlite3_errmsg()], and/or
  6667. ** [sqlite3_errmsg16()] functions.
  6668. ** ^A successful call to sqlite3_backup_init() returns a pointer to an
  6669. ** [sqlite3_backup] object.
  6670. ** ^The [sqlite3_backup] object may be used with the sqlite3_backup_step() and
  6671. ** sqlite3_backup_finish() functions to perform the specified backup
  6672. ** operation.
  6673. **
  6674. ** [[sqlite3_backup_step()]] <b>sqlite3_backup_step()</b>
  6675. **
  6676. ** ^Function sqlite3_backup_step(B,N) will copy up to N pages between
  6677. ** the source and destination databases specified by [sqlite3_backup] object B.
  6678. ** ^If N is negative, all remaining source pages are copied.
  6679. ** ^If sqlite3_backup_step(B,N) successfully copies N pages and there
  6680. ** are still more pages to be copied, then the function returns [SQLITE_OK].
  6681. ** ^If sqlite3_backup_step(B,N) successfully finishes copying all pages
  6682. ** from source to destination, then it returns [SQLITE_DONE].
  6683. ** ^If an error occurs while running sqlite3_backup_step(B,N),
  6684. ** then an [error code] is returned. ^As well as [SQLITE_OK] and
  6685. ** [SQLITE_DONE], a call to sqlite3_backup_step() may return [SQLITE_READONLY],
  6686. ** [SQLITE_NOMEM], [SQLITE_BUSY], [SQLITE_LOCKED], or an
  6687. ** [SQLITE_IOERR_ACCESS | SQLITE_IOERR_XXX] extended error code.
  6688. **
  6689. ** ^(The sqlite3_backup_step() might return [SQLITE_READONLY] if
  6690. ** <ol>
  6691. ** <li> the destination database was opened read-only, or
  6692. ** <li> the destination database is using write-ahead-log journaling
  6693. ** and the destination and source page sizes differ, or
  6694. ** <li> the destination database is an in-memory database and the
  6695. ** destination and source page sizes differ.
  6696. ** </ol>)^
  6697. **
  6698. ** ^If sqlite3_backup_step() cannot obtain a required file-system lock, then
  6699. ** the [sqlite3_busy_handler | busy-handler function]
  6700. ** is invoked (if one is specified). ^If the
  6701. ** busy-handler returns non-zero before the lock is available, then
  6702. ** [SQLITE_BUSY] is returned to the caller. ^In this case the call to
  6703. ** sqlite3_backup_step() can be retried later. ^If the source
  6704. ** [database connection]
  6705. ** is being used to write to the source database when sqlite3_backup_step()
  6706. ** is called, then [SQLITE_LOCKED] is returned immediately. ^Again, in this
  6707. ** case the call to sqlite3_backup_step() can be retried later on. ^(If
  6708. ** [SQLITE_IOERR_ACCESS | SQLITE_IOERR_XXX], [SQLITE_NOMEM], or
  6709. ** [SQLITE_READONLY] is returned, then
  6710. ** there is no point in retrying the call to sqlite3_backup_step(). These
  6711. ** errors are considered fatal.)^ The application must accept
  6712. ** that the backup operation has failed and pass the backup operation handle
  6713. ** to the sqlite3_backup_finish() to release associated resources.
  6714. **
  6715. ** ^The first call to sqlite3_backup_step() obtains an exclusive lock
  6716. ** on the destination file. ^The exclusive lock is not released until either
  6717. ** sqlite3_backup_finish() is called or the backup operation is complete
  6718. ** and sqlite3_backup_step() returns [SQLITE_DONE]. ^Every call to
  6719. ** sqlite3_backup_step() obtains a [shared lock] on the source database that
  6720. ** lasts for the duration of the sqlite3_backup_step() call.
  6721. ** ^Because the source database is not locked between calls to
  6722. ** sqlite3_backup_step(), the source database may be modified mid-way
  6723. ** through the backup process. ^If the source database is modified by an
  6724. ** external process or via a database connection other than the one being
  6725. ** used by the backup operation, then the backup will be automatically
  6726. ** restarted by the next call to sqlite3_backup_step(). ^If the source
  6727. ** database is modified by the using the same database connection as is used
  6728. ** by the backup operation, then the backup database is automatically
  6729. ** updated at the same time.
  6730. **
  6731. ** [[sqlite3_backup_finish()]] <b>sqlite3_backup_finish()</b>
  6732. **
  6733. ** When sqlite3_backup_step() has returned [SQLITE_DONE], or when the
  6734. ** application wishes to abandon the backup operation, the application
  6735. ** should destroy the [sqlite3_backup] by passing it to sqlite3_backup_finish().
  6736. ** ^The sqlite3_backup_finish() interfaces releases all
  6737. ** resources associated with the [sqlite3_backup] object.
  6738. ** ^If sqlite3_backup_step() has not yet returned [SQLITE_DONE], then any
  6739. ** active write-transaction on the destination database is rolled back.
  6740. ** The [sqlite3_backup] object is invalid
  6741. ** and may not be used following a call to sqlite3_backup_finish().
  6742. **
  6743. ** ^The value returned by sqlite3_backup_finish is [SQLITE_OK] if no
  6744. ** sqlite3_backup_step() errors occurred, regardless or whether or not
  6745. ** sqlite3_backup_step() completed.
  6746. ** ^If an out-of-memory condition or IO error occurred during any prior
  6747. ** sqlite3_backup_step() call on the same [sqlite3_backup] object, then
  6748. ** sqlite3_backup_finish() returns the corresponding [error code].
  6749. **
  6750. ** ^A return of [SQLITE_BUSY] or [SQLITE_LOCKED] from sqlite3_backup_step()
  6751. ** is not a permanent error and does not affect the return value of
  6752. ** sqlite3_backup_finish().
  6753. **
  6754. ** [[sqlite3_backup__remaining()]] [[sqlite3_backup_pagecount()]]
  6755. ** <b>sqlite3_backup_remaining() and sqlite3_backup_pagecount()</b>
  6756. **
  6757. ** ^Each call to sqlite3_backup_step() sets two values inside
  6758. ** the [sqlite3_backup] object: the number of pages still to be backed
  6759. ** up and the total number of pages in the source database file.
  6760. ** The sqlite3_backup_remaining() and sqlite3_backup_pagecount() interfaces
  6761. ** retrieve these two values, respectively.
  6762. **
  6763. ** ^The values returned by these functions are only updated by
  6764. ** sqlite3_backup_step(). ^If the source database is modified during a backup
  6765. ** operation, then the values are not updated to account for any extra
  6766. ** pages that need to be updated or the size of the source database file
  6767. ** changing.
  6768. **
  6769. ** <b>Concurrent Usage of Database Handles</b>
  6770. **
  6771. ** ^The source [database connection] may be used by the application for other
  6772. ** purposes while a backup operation is underway or being initialized.
  6773. ** ^If SQLite is compiled and configured to support threadsafe database
  6774. ** connections, then the source database connection may be used concurrently
  6775. ** from within other threads.
  6776. **
  6777. ** However, the application must guarantee that the destination
  6778. ** [database connection] is not passed to any other API (by any thread) after
  6779. ** sqlite3_backup_init() is called and before the corresponding call to
  6780. ** sqlite3_backup_finish(). SQLite does not currently check to see
  6781. ** if the application incorrectly accesses the destination [database connection]
  6782. ** and so no error code is reported, but the operations may malfunction
  6783. ** nevertheless. Use of the destination database connection while a
  6784. ** backup is in progress might also also cause a mutex deadlock.
  6785. **
  6786. ** If running in [shared cache mode], the application must
  6787. ** guarantee that the shared cache used by the destination database
  6788. ** is not accessed while the backup is running. In practice this means
  6789. ** that the application must guarantee that the disk file being
  6790. ** backed up to is not accessed by any connection within the process,
  6791. ** not just the specific connection that was passed to sqlite3_backup_init().
  6792. **
  6793. ** The [sqlite3_backup] object itself is partially threadsafe. Multiple
  6794. ** threads may safely make multiple concurrent calls to sqlite3_backup_step().
  6795. ** However, the sqlite3_backup_remaining() and sqlite3_backup_pagecount()
  6796. ** APIs are not strictly speaking threadsafe. If they are invoked at the
  6797. ** same time as another thread is invoking sqlite3_backup_step() it is
  6798. ** possible that they return invalid values.
  6799. */
  6800. //SQLITE_API sqlite3_backup *sqlite3_backup_init(
  6801. // sqlite3 *pDest, /* Destination database handle */
  6802. // string zDestName, /* Destination database name */
  6803. // sqlite3 *pSource, /* Source database handle */
  6804. // string zSourceName /* Source database name */
  6805. //);
  6806. //SQLITE_API int sqlite3_backup_step(sqlite3_backup *p, int nPage);
  6807. //SQLITE_API int sqlite3_backup_finish(sqlite3_backup *p);
  6808. //SQLITE_API int sqlite3_backup_remaining(sqlite3_backup *p);
  6809. //SQLITE_API int sqlite3_backup_pagecount(sqlite3_backup *p);
  6810. /*
  6811. ** CAPI3REF: Unlock Notification
  6812. **
  6813. ** ^When running in shared-cache mode, a database operation may fail with
  6814. ** an [SQLITE_LOCKED] error if the required locks on the shared-cache or
  6815. ** individual tables within the shared-cache cannot be obtained. See
  6816. ** [SQLite Shared-Cache Mode] for a description of shared-cache locking.
  6817. ** ^This API may be used to register a callback that SQLite will invoke
  6818. ** when the connection currently holding the required lock relinquishes it.
  6819. ** ^This API is only available if the library was compiled with the
  6820. ** [SQLITE_ENABLE_UNLOCK_NOTIFY] C-preprocessor symbol defined.
  6821. **
  6822. ** See Also: [Using the SQLite Unlock Notification Feature].
  6823. **
  6824. ** ^Shared-cache locks are released when a database connection concludes
  6825. ** its current transaction, either by committing it or rolling it back.
  6826. **
  6827. ** ^When a connection (known as the blocked connection) fails to obtain a
  6828. ** shared-cache lock and SQLITE_LOCKED is returned to the caller, the
  6829. ** identity of the database connection (the blocking connection) that
  6830. ** has locked the required resource is stored internally. ^After an
  6831. ** application receives an SQLITE_LOCKED error, it may call the
  6832. ** sqlite3_unlock_notify() method with the blocked connection handle as
  6833. ** the first argument to register for a callback that will be invoked
  6834. ** when the blocking connections current transaction is concluded. ^The
  6835. ** callback is invoked from within the [sqlite3_step] or [sqlite3_close]
  6836. ** call that concludes the blocking connections transaction.
  6837. **
  6838. ** ^(If sqlite3_unlock_notify() is called in a multi-threaded application,
  6839. ** there is a chance that the blocking connection will have already
  6840. ** concluded its transaction by the time sqlite3_unlock_notify() is invoked.
  6841. ** If this happens, then the specified callback is invoked immediately,
  6842. ** from within the call to sqlite3_unlock_notify().)^
  6843. **
  6844. ** ^If the blocked connection is attempting to obtain a write-lock on a
  6845. ** shared-cache table, and more than one other connection currently holds
  6846. ** a read-lock on the same table, then SQLite arbitrarily selects one of
  6847. ** the other connections to use as the blocking connection.
  6848. **
  6849. ** ^(There may be at most one unlock-notify callback registered by a
  6850. ** blocked connection. If sqlite3_unlock_notify() is called when the
  6851. ** blocked connection already has a registered unlock-notify callback,
  6852. ** then the new callback replaces the old.)^ ^If sqlite3_unlock_notify() is
  6853. ** called with a NULL pointer as its second argument, then any existing
  6854. ** unlock-notify callback is canceled. ^The blocked connections
  6855. ** unlock-notify callback may also be canceled by closing the blocked
  6856. ** connection using [sqlite3_close()].
  6857. **
  6858. ** The unlock-notify callback is not reentrant. If an application invokes
  6859. ** any sqlite3_xxx API functions from within an unlock-notify callback, a
  6860. ** crash or deadlock may be the result.
  6861. **
  6862. ** ^Unless deadlock is detected (see below), sqlite3_unlock_notify() always
  6863. ** returns SQLITE_OK.
  6864. **
  6865. ** <b>Callback Invocation Details</b>
  6866. **
  6867. ** When an unlock-notify callback is registered, the application provides a
  6868. ** single void* pointer that is passed to the callback when it is invoked.
  6869. ** However, the signature of the callback function allows SQLite to pass
  6870. ** it an array of void* context pointers. The first argument passed to
  6871. ** an unlock-notify callback is a pointer to an array of void* pointers,
  6872. ** and the second is the number of entries in the array.
  6873. **
  6874. ** When a blocking connections transaction is concluded, there may be
  6875. ** more than one blocked connection that has registered for an unlock-notify
  6876. ** callback. ^If two or more such blocked connections have specified the
  6877. ** same callback function, then instead of invoking the callback function
  6878. ** multiple times, it is invoked once with the set of void* context pointers
  6879. ** specified by the blocked connections bundled together into an array.
  6880. ** This gives the application an opportunity to prioritize any actions
  6881. ** related to the set of unblocked database connections.
  6882. **
  6883. ** <b>Deadlock Detection</b>
  6884. **
  6885. ** Assuming that after registering for an unlock-notify callback a
  6886. ** database waits for the callback to be issued before taking any further
  6887. ** action (a reasonable assumption), then using this API may cause the
  6888. ** application to deadlock. For example, if connection X is waiting for
  6889. ** connection Y's transaction to be concluded, and similarly connection
  6890. ** Y is waiting on connection X's transaction, then neither connection
  6891. ** will proceed and the system may remain deadlocked indefinitely.
  6892. **
  6893. ** To avoid this scenario, the sqlite3_unlock_notify() performs deadlock
  6894. ** detection. ^If a given call to sqlite3_unlock_notify() would put the
  6895. ** system in a deadlocked state, then SQLITE_LOCKED is returned and no
  6896. ** unlock-notify callback is registered. The system is said to be in
  6897. ** a deadlocked state if connection A has registered for an unlock-notify
  6898. ** callback on the conclusion of connection B's transaction, and connection
  6899. ** B has itself registered for an unlock-notify callback when connection
  6900. ** A's transaction is concluded. ^Indirect deadlock is also detected, so
  6901. ** the system is also considered to be deadlocked if connection B has
  6902. ** registered for an unlock-notify callback on the conclusion of connection
  6903. ** C's transaction, where connection C is waiting on connection A. ^Any
  6904. ** number of levels of indirection are allowed.
  6905. **
  6906. ** <b>The "DROP TABLE" Exception</b>
  6907. **
  6908. ** When a call to [sqlite3_step()] returns SQLITE_LOCKED, it is almost
  6909. ** always appropriate to call sqlite3_unlock_notify(). There is however,
  6910. ** one exception. When executing a "DROP TABLE" or "DROP INDEX" statement,
  6911. ** SQLite checks if there are any currently executing SELECT statements
  6912. ** that belong to the same connection. If there are, SQLITE_LOCKED is
  6913. ** returned. In this case there is no "blocking connection", so invoking
  6914. ** sqlite3_unlock_notify() results in the unlock-notify callback being
  6915. ** invoked immediately. If the application then re-attempts the "DROP TABLE"
  6916. ** or "DROP INDEX" query, an infinite loop might be the result.
  6917. **
  6918. ** One way around this problem is to check the extended error code returned
  6919. ** by an sqlite3_step() call. ^(If there is a blocking connection, then the
  6920. ** extended error code is set to SQLITE_LOCKED_SHAREDCACHE. Otherwise, in
  6921. ** the special "DROP TABLE/INDEX" case, the extended error code is just
  6922. ** SQLITE_LOCKED.)^
  6923. */
  6924. //SQLITE_API int sqlite3_unlock_notify(
  6925. // sqlite3 *pBlocked, /* Waiting connection */
  6926. // void (*xNotify)(void **apArg, int nArg), /* Callback function to invoke */
  6927. // void *pNotifyArg /* Argument to pass to xNotify */
  6928. //);
  6929. /*
  6930. ** CAPI3REF: String Comparison
  6931. **
  6932. ** ^The [sqlite3_strnicmp()] API allows applications and extensions to
  6933. ** compare the contents of two buffers containing UTF-8 strings in a
  6934. ** case-independent fashion, using the same definition of case independence
  6935. ** that SQLite uses internally when comparing identifiers.
  6936. */
  6937. //SQLITE_API int sqlite3_strnicmp(string , string , int);
  6938. /*
  6939. ** CAPI3REF: Error Logging Interface
  6940. **
  6941. ** ^The [sqlite3_log()] interface writes a message into the error log
  6942. ** established by the [SQLITE_CONFIG_LOG] option to [sqlite3_config()].
  6943. ** ^If logging is enabled, the zFormat string and subsequent arguments are
  6944. ** used with [sqlite3_snprintf()] to generate the final output string.
  6945. **
  6946. ** The sqlite3_log() interface is intended for use by extensions such as
  6947. ** virtual tables, collating functions, and SQL functions. While there is
  6948. ** nothing to prevent an application from calling sqlite3_log(), doing so
  6949. ** is considered bad form.
  6950. **
  6951. ** The zFormat string must not be NULL.
  6952. **
  6953. ** To avoid deadlocks and other threading problems, the sqlite3_log() routine
  6954. ** will not use dynamically allocated memory. The log message is stored in
  6955. ** a fixed-length buffer on the stack. If the log message is longer than
  6956. ** a few hundred characters, it will be truncated to the length of the
  6957. ** buffer.
  6958. */
  6959. //SQLITE_API void sqlite3_log(int iErrCode, string zFormat, ...);
  6960. /*
  6961. ** CAPI3REF: Write-Ahead Log Commit Hook
  6962. **
  6963. ** ^The [sqlite3_wal_hook()] function is used to register a callback that
  6964. ** will be invoked each time a database connection commits data to a
  6965. ** [write-ahead log] (i.e. whenever a transaction is committed in
  6966. ** [journal_mode | journal_mode=WAL mode]).
  6967. **
  6968. ** ^The callback is invoked by SQLite after the commit has taken place and
  6969. ** the associated write-lock on the database released, so the implementation
  6970. ** may read, write or [checkpoint] the database as required.
  6971. **
  6972. ** ^The first parameter passed to the callback function when it is invoked
  6973. ** is a copy of the third parameter passed to sqlite3_wal_hook() when
  6974. ** registering the callback. ^The second is a copy of the database handle.
  6975. ** ^The third parameter is the name of the database that was written to -
  6976. ** either "main" or the name of an [ATTACH]-ed database. ^The fourth parameter
  6977. ** is the number of pages currently in the write-ahead log file,
  6978. ** including those that were just committed.
  6979. **
  6980. ** The callback function should normally return [SQLITE_OK]. ^If an error
  6981. ** code is returned, that error will propagate back up through the
  6982. ** SQLite code base to cause the statement that provoked the callback
  6983. ** to report an error, though the commit will have still occurred. If the
  6984. ** callback returns [SQLITE_ROW] or [SQLITE_DONE], or if it returns a value
  6985. ** that does not correspond to any valid SQLite error code, the results
  6986. ** are undefined.
  6987. **
  6988. ** A single database handle may have at most a single write-ahead log callback
  6989. ** registered at one time. ^Calling [sqlite3_wal_hook()] replaces any
  6990. ** previously registered write-ahead log callback. ^Note that the
  6991. ** [sqlite3_wal_autocheckpoint()] interface and the
  6992. ** [wal_autocheckpoint pragma] both invoke [sqlite3_wal_hook()] and will
  6993. ** those overwrite any prior [sqlite3_wal_hook()] settings.
  6994. */
  6995. //SQLITE_API void *sqlite3_wal_hook(
  6996. // sqlite3*,
  6997. // int()(void *,sqlite3*,const char*,int),
  6998. // void*
  6999. //);
  7000. /*
  7001. ** CAPI3REF: Configure an auto-checkpoint
  7002. **
  7003. ** ^The [sqlite3_wal_autocheckpoint(D,N)] is a wrapper around
  7004. ** [sqlite3_wal_hook()] that causes any database on [database connection] D
  7005. ** to automatically [checkpoint]
  7006. ** after committing a transaction if there are N or
  7007. ** more frames in the [write-ahead log] file. ^Passing zero or
  7008. ** a negative value as the nFrame parameter disables automatic
  7009. ** checkpoints entirely.
  7010. **
  7011. ** ^The callback registered by this function replaces any existing callback
  7012. ** registered using [sqlite3_wal_hook()]. ^Likewise, registering a callback
  7013. ** using [sqlite3_wal_hook()] disables the automatic checkpoint mechanism
  7014. ** configured by this function.
  7015. **
  7016. ** ^The [wal_autocheckpoint pragma] can be used to invoke this interface
  7017. ** from SQL.
  7018. **
  7019. ** ^Every new [database connection] defaults to having the auto-checkpoint
  7020. ** enabled with a threshold of 1000 or [SQLITE_DEFAULT_WAL_AUTOCHECKPOINT]
  7021. ** pages. The use of this interface
  7022. ** for a particular application.
  7023. */
  7024. //SQLITE_API int sqlite3_wal_autocheckpoint(sqlite3 db, int N);
  7025. /*
  7026. ** CAPI3REF: Checkpoint a database
  7027. **
  7028. ** ^The [sqlite3_wal_checkpoint(D,X)] interface causes database named X
  7029. ** on [database connection] D to be [checkpointed]. ^If X is NULL or an
  7030. ** empty string, then a checkpoint is run on all databases of
  7031. ** connection D. ^If the database connection D is not in
  7032. ** [WAL | write-ahead log mode] then this interface is a harmless no-op.
  7033. **
  7034. ** ^The [wal_checkpoint pragma] can be used to invoke this interface
  7035. ** from SQL. ^The [sqlite3_wal_autocheckpoint()] interface and the
  7036. ** [wal_autocheckpoint pragma] can be used to cause this interface to be
  7037. ** run whenever the WAL reaches a certain size threshold.
  7038. **
  7039. ** See also: [sqlite3_wal_checkpoint_v2()]
  7040. */
  7041. //SQLITE_API int sqlite3_wal_checkpoint(sqlite3 db, string zDb);
  7042. /*
  7043. ** CAPI3REF: Checkpoint a database
  7044. **
  7045. ** Run a checkpoint operation on WAL database zDb attached to database
  7046. ** handle db. The specific operation is determined by the value of the
  7047. ** eMode parameter:
  7048. **
  7049. ** <dl>
  7050. ** <dt>SQLITE_CHECKPOINT_PASSIVE<dd>
  7051. ** Checkpoint as many frames as possible without waiting for any database
  7052. ** readers or writers to finish. Sync the db file if all frames in the log
  7053. ** are checkpointed. This mode is the same as calling
  7054. ** sqlite3_wal_checkpoint(). The busy-handler callback is never invoked.
  7055. **
  7056. ** <dt>SQLITE_CHECKPOINT_FULL<dd>
  7057. ** This mode blocks (calls the busy-handler callback) until there is no
  7058. ** database writer and all readers are reading from the most recent database
  7059. ** snapshot. It then checkpoints all frames in the log file and syncs the
  7060. ** database file. This call blocks database writers while it is running,
  7061. ** but not database readers.
  7062. **
  7063. ** <dt>SQLITE_CHECKPOINT_RESTART<dd>
  7064. ** This mode works the same way as SQLITE_CHECKPOINT_FULL, except after
  7065. ** checkpointing the log file it blocks (calls the busy-handler callback)
  7066. ** until all readers are reading from the database file only. This ensures
  7067. ** that the next client to write to the database file restarts the log file
  7068. ** from the beginning. This call blocks database writers while it is running,
  7069. ** but not database readers.
  7070. ** </dl>
  7071. **
  7072. ** If pnLog is not NULL, then *pnLog is set to the total number of frames in
  7073. ** the log file before returning. If pnCkpt is not NULL, then *pnCkpt is set to
  7074. ** the total number of checkpointed frames (including any that were already
  7075. ** checkpointed when this function is called). *pnLog and *pnCkpt may be
  7076. ** populated even if sqlite3_wal_checkpoint_v2() returns other than SQLITE_OK.
  7077. ** If no values are available because of an error, they are both set to -1
  7078. ** before returning to communicate this to the caller.
  7079. **
  7080. ** All calls obtain an exclusive "checkpoint" lock on the database file. If
  7081. ** any other process is running a checkpoint operation at the same time, the
  7082. ** lock cannot be obtained and SQLITE_BUSY is returned. Even if there is a
  7083. ** busy-handler configured, it will not be invoked in this case.
  7084. **
  7085. ** The SQLITE_CHECKPOINT_FULL and RESTART modes also obtain the exclusive
  7086. ** "writer" lock on the database file. If the writer lock cannot be obtained
  7087. ** immediately, and a busy-handler is configured, it is invoked and the writer
  7088. ** lock retried until either the busy-handler returns 0 or the lock is
  7089. ** successfully obtained. The busy-handler is also invoked while waiting for
  7090. ** database readers as described above. If the busy-handler returns 0 before
  7091. ** the writer lock is obtained or while waiting for database readers, the
  7092. ** checkpoint operation proceeds from that point in the same way as
  7093. ** SQLITE_CHECKPOINT_PASSIVE - checkpointing as many frames as possible
  7094. ** without blocking any further. SQLITE_BUSY is returned in this case.
  7095. **
  7096. ** If parameter zDb is NULL or points to a zero length string, then the
  7097. ** specified operation is attempted on all WAL databases. In this case the
  7098. ** values written to output parameters *pnLog and *pnCkpt are undefined. If
  7099. ** an SQLITE_BUSY error is encountered when processing one or more of the
  7100. ** attached WAL databases, the operation is still attempted on any remaining
  7101. ** attached databases and SQLITE_BUSY is returned to the caller. If any other
  7102. ** error occurs while processing an attached database, processing is abandoned
  7103. ** and the error code returned to the caller immediately. If no error
  7104. ** (SQLITE_BUSY or otherwise) is encountered while processing the attached
  7105. ** databases, SQLITE_OK is returned.
  7106. **
  7107. ** If database zDb is the name of an attached database that is not in WAL
  7108. ** mode, SQLITE_OK is returned and both *pnLog and *pnCkpt set to -1. If
  7109. ** zDb is not NULL (or a zero length string) and is not the name of any
  7110. ** attached database, SQLITE_ERROR is returned to the caller.
  7111. */
  7112. //SQLITE_API int sqlite3_wal_checkpoint_v2(
  7113. // sqlite3 db, /* Database handle */
  7114. // string zDb, /* Name of attached database (or NULL) */
  7115. // int eMode, /* SQLITE_CHECKPOINT_* value */
  7116. // int *pnLog, /* OUT: Size of WAL log in frames */
  7117. // int *pnCkpt /* OUT: Total number of frames checkpointed */
  7118. //);
  7119. /*
  7120. ** CAPI3REF: Checkpoint operation parameters
  7121. **
  7122. ** These constants can be used as the 3rd parameter to
  7123. ** [sqlite3_wal_checkpoint_v2()]. See the [sqlite3_wal_checkpoint_v2()]
  7124. ** documentation for additional information about the meaning and use of
  7125. ** each of these values.
  7126. */
  7127. //#define SQLITE_CHECKPOINT_PASSIVE 0
  7128. //#define SQLITE_CHECKPOINT_FULL 1
  7129. //#define SQLITE_CHECKPOINT_RESTART 2
  7130. static public int SQLITE_CHECKPOINT_PASSIVE = 0;
  7131. static public int SQLITE_CHECKPOINT_FULL = 1;
  7132. static public int SQLITE_CHECKPOINT_RESTART = 2;
  7133. /*
  7134. ** CAPI3REF: Virtual Table Interface Configuration
  7135. **
  7136. ** This function may be called by either the [xConnect] or [xCreate] method
  7137. ** of a [virtual table] implementation to configure
  7138. ** various facets of the virtual table interface.
  7139. **
  7140. ** If this interface is invoked outside the context of an xConnect or
  7141. ** xCreate virtual table method then the behavior is undefined.
  7142. **
  7143. ** At present, there is only one option that may be configured using
  7144. ** this function. (See [SQLITE_VTAB_CONSTRAINT_SUPPORT].) Further options
  7145. ** may be added in the future.
  7146. */
  7147. //SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...);
  7148. /*
  7149. ** CAPI3REF: Virtual Table Configuration Options
  7150. **
  7151. ** These macros define the various options to the
  7152. ** [sqlite3_vtab_config()] interface that [virtual table] implementations
  7153. ** can use to customize and optimize their behavior.
  7154. **
  7155. ** <dl>
  7156. ** <dt>SQLITE_VTAB_CONSTRAINT_SUPPORT
  7157. ** <dd>Calls of the form
  7158. ** [sqlite3_vtab_config](db,SQLITE_VTAB_CONSTRAINT_SUPPORT,X) are supported,
  7159. ** where X is an integer. If X is zero, then the [virtual table] whose
  7160. ** [xCreate] or [xConnect] method invoked [sqlite3_vtab_config()] does not
  7161. ** support constraints. In this configuration (which is the default) if
  7162. ** a call to the [xUpdate] method returns [SQLITE_CONSTRAINT], then the entire
  7163. ** statement is rolled back as if [ON CONFLICT | OR ABORT] had been
  7164. ** specified as part of the users SQL statement, regardless of the actual
  7165. ** ON CONFLICT mode specified.
  7166. **
  7167. ** If X is non-zero, then the virtual table implementation guarantees
  7168. ** that if [xUpdate] returns [SQLITE_CONSTRAINT], it will do so before
  7169. ** any modifications to internal or persistent data structures have been made.
  7170. ** If the [ON CONFLICT] mode is ABORT, FAIL, IGNORE or ROLLBACK, SQLite
  7171. ** is able to roll back a statement or database transaction, and abandon
  7172. ** or continue processing the current SQL statement as appropriate.
  7173. ** If the ON CONFLICT mode is REPLACE and the [xUpdate] method returns
  7174. ** [SQLITE_CONSTRAINT], SQLite handles this as if the ON CONFLICT mode
  7175. ** had been ABORT.
  7176. **
  7177. ** Virtual table implementations that are required to handle OR REPLACE
  7178. ** must do so within the [xUpdate] method. If a call to the
  7179. ** [sqlite3_vtab_on_conflict()] function indicates that the current ON
  7180. ** CONFLICT policy is REPLACE, the virtual table implementation should
  7181. ** silently replace the appropriate rows within the xUpdate callback and
  7182. ** return SQLITE_OK. Or, if this is not possible, it may return
  7183. ** SQLITE_CONSTRAINT, in which case SQLite falls back to OR ABORT
  7184. ** constraint handling.
  7185. ** </dl>
  7186. */
  7187. //#define SQLITE_VTAB_CONSTRAINT_SUPPORT 1
  7188. public const int SQLITE_VTAB_CONSTRAINT_SUPPORT = 1;
  7189. /*
  7190. ** CAPI3REF: Determine The Virtual Table Conflict Policy
  7191. **
  7192. ** This function may only be called from within a call to the [xUpdate] method
  7193. ** of a [virtual table] implementation for an INSERT or UPDATE operation. ^The
  7194. ** value returned is one of [SQLITE_ROLLBACK], [SQLITE_IGNORE], [SQLITE_FAIL],
  7195. ** [SQLITE_ABORT], or [SQLITE_REPLACE], according to the [ON CONFLICT] mode
  7196. ** of the SQL statement that triggered the call to the [xUpdate] method of the
  7197. ** [virtual table].
  7198. */
  7199. //SQLITE_API int sqlite3_vtab_on_conflict(sqlite3 );
  7200. /*
  7201. ** CAPI3REF: Conflict resolution modes
  7202. **
  7203. ** These constants are returned by [sqlite3_vtab_on_conflict()] to
  7204. ** inform a [virtual table] implementation what the [ON CONFLICT] mode
  7205. ** is for the SQL statement being evaluated.
  7206. **
  7207. ** Note that the [SQLITE_IGNORE] constant is also used as a potential
  7208. ** return value from the [sqlite3_set_authorizer()] callback and that
  7209. ** [SQLITE_ABORT] is also a [result code].
  7210. */
  7211. //#define SQLITE_ROLLBACK 1
  7212. public const int SQLITE_ROLLBACK = 1;
  7213. /* #define SQLITE_IGNORE 2 // Also used by sqlite3_authorizer() callback */
  7214. //#define SQLITE_FAIL 3
  7215. public const int SQLITE_FAIL = 3;
  7216. /* #define SQLITE_ABORT 4 // Also an error code */
  7217. //#define SQLITE_REPLACE 5
  7218. public const int SQLITE_REPLACE = 5;
  7219. /*
  7220. ** Undo the hack that converts floating point types to integer for
  7221. ** builds on processors without floating point support.
  7222. */
  7223. //#if SQLITE_OMIT_FLOATING_POINT
  7224. //# undef double
  7225. //#endif
  7226. //#if __cplusplus
  7227. //} /* End of the 'extern "C"' block */
  7228. //#endif
  7229. //#endif
  7230. /*
  7231. ** 2010 August 30
  7232. **
  7233. ** The author disclaims copyright to this source code. In place of
  7234. ** a legal notice, here is a blessing:
  7235. **
  7236. ** May you do good and not evil.
  7237. ** May you find forgiveness for yourself and forgive others.
  7238. ** May you share freely, never taking more than you give.
  7239. **
  7240. *************************************************************************
  7241. */
  7242. //#if !_SQLITE3RTREE_H_
  7243. //#define _SQLITE3RTREE_H_
  7244. //#if __cplusplus
  7245. //extern "C" {
  7246. //#endif
  7247. //typedef struct sqlite3_rtree_geometry sqlite3_rtree_geometry;
  7248. /*
  7249. ** Register a geometry callback named zGeom that can be used as part of an
  7250. ** R-Tree geometry query as follows:
  7251. **
  7252. ** SELECT ... FROM <rtree> WHERE <rtree col> MATCH $zGeom(... params ...)
  7253. */
  7254. //SQLITE_API int sqlite3_rtree_geometry_callback(
  7255. // sqlite3 db,
  7256. // string zGeom,
  7257. // int (*xGeom)(sqlite3_rtree_geometry *, int nCoord, double *aCoord, int *pRes),
  7258. // void *pContext
  7259. //);
  7260. /*
  7261. ** A pointer to a structure of the following type is passed as the first
  7262. ** argument to callbacks registered using rtree_geometry_callback().
  7263. */
  7264. //struct sqlite3_rtree_geometry {
  7265. // void *pContext; /* Copy of pContext passed to s_r_g_c() */
  7266. // int nParam; /* Size of array aParam[] */
  7267. // double *aParam; /* Parameters passed to SQL geom function */
  7268. // void *pUser; /* Callback implementation user data */
  7269. // void (*xDelUser)(void ); /* Called by SQLite to clean up pUser */
  7270. //};
  7271. //#if __cplusplus
  7272. //} /* end of the 'extern "C"' block */
  7273. //#endif
  7274. //#endif /* ifndef _SQLITE3RTREE_H_ */
  7275. }
  7276. }