poppler 2.2.5-x64-mingw32 → 3.0.0-x64-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Rakefile +18 -4
- data/lib/2.0/poppler.so +0 -0
- data/lib/2.1/poppler.so +0 -0
- data/lib/2.2/poppler.so +0 -0
- data/vendor/local/bin/cjpeg.exe +0 -0
- data/vendor/local/bin/djpeg.exe +0 -0
- data/vendor/local/bin/jpegtran.exe +0 -0
- data/vendor/local/bin/libjpeg-9.dll +0 -0
- data/vendor/local/bin/libopenjp2.dll +0 -0
- data/vendor/local/bin/{libpoppler-48.dll → libpoppler-55.dll} +0 -0
- data/vendor/local/bin/libpoppler-cpp-0.dll +0 -0
- data/vendor/local/bin/libpoppler-glib-8.dll +0 -0
- data/vendor/local/bin/libsqlite3-0.dll +0 -0
- data/vendor/local/bin/opj_compress.exe +0 -0
- data/vendor/local/bin/opj_decompress.exe +0 -0
- data/vendor/local/bin/opj_dump.exe +0 -0
- data/vendor/local/bin/pdfdetach.exe +0 -0
- data/vendor/local/bin/pdffonts.exe +0 -0
- data/vendor/local/bin/pdfimages.exe +0 -0
- data/vendor/local/bin/pdfinfo.exe +0 -0
- data/vendor/local/bin/pdfseparate.exe +0 -0
- data/vendor/local/bin/pdftocairo.exe +0 -0
- data/vendor/local/bin/pdftohtml.exe +0 -0
- data/vendor/local/bin/pdftoppm.exe +0 -0
- data/vendor/local/bin/pdftops.exe +0 -0
- data/vendor/local/bin/pdftotext.exe +0 -0
- data/vendor/local/bin/pdfunite.exe +0 -0
- data/vendor/local/bin/rdjpgcom.exe +0 -0
- data/vendor/local/bin/sqlite3.exe +0 -0
- data/vendor/local/bin/wrjpgcom.exe +0 -0
- data/vendor/local/include/openjpeg-2.1/openjpeg.h +1559 -0
- data/vendor/local/include/openjpeg-2.1/opj_config.h +10 -0
- data/vendor/local/include/openjpeg-2.1/opj_stdint.h +52 -0
- data/vendor/local/include/poppler/cpp/poppler-global.h +5 -0
- data/vendor/local/include/poppler/cpp/poppler-version.h +2 -2
- data/vendor/local/include/poppler/glib/poppler-annot.h +2 -0
- data/vendor/local/include/poppler/glib/poppler-features.h +1 -1
- data/vendor/local/include/sqlite3.h +1023 -657
- data/vendor/local/include/sqlite3ext.h +42 -2
- data/vendor/local/lib/girepository-1.0/Poppler-0.18.typelib +0 -0
- data/vendor/local/lib/libjpeg.a +0 -0
- data/vendor/local/lib/libjpeg.dll.a +0 -0
- data/vendor/local/lib/libopenjp2.dll.a +0 -0
- data/vendor/local/lib/libpoppler-cpp.a +0 -0
- data/vendor/local/lib/libpoppler-cpp.dll.a +0 -0
- data/vendor/local/lib/libpoppler-cpp.la +2 -2
- data/vendor/local/lib/libpoppler-glib.a +0 -0
- data/vendor/local/lib/libpoppler-glib.dll.a +0 -0
- data/vendor/local/lib/libpoppler-glib.la +3 -3
- data/vendor/local/lib/libpoppler.a +0 -0
- data/vendor/local/lib/libpoppler.dll.a +0 -0
- data/vendor/local/lib/libpoppler.la +3 -3
- data/vendor/local/lib/libsqlite3.a +0 -0
- data/vendor/local/lib/libsqlite3.dll.a +0 -0
- data/vendor/local/lib/openjpeg-2.1/OpenJPEGConfig.cmake +48 -0
- data/vendor/local/lib/openjpeg-2.1/OpenJPEGTargets-noconfig.cmake +46 -0
- data/vendor/local/lib/openjpeg-2.1/OpenJPEGTargets.cmake +92 -0
- data/vendor/local/lib/pkgconfig/libopenjp2.pc +14 -0
- data/vendor/local/lib/pkgconfig/poppler-cairo.pc +2 -2
- data/vendor/local/lib/pkgconfig/poppler-cpp.pc +2 -2
- data/vendor/local/lib/pkgconfig/poppler-glib.pc +2 -2
- data/vendor/local/lib/pkgconfig/poppler-splash.pc +2 -2
- data/vendor/local/lib/pkgconfig/poppler.pc +1 -1
- data/vendor/local/lib/pkgconfig/sqlite3.pc +1 -1
- data/vendor/local/share/gir-1.0/Poppler-0.18.gir +23 -2
- data/vendor/local/share/gtk-doc/html/poppler/PopplerAnnot.html +111 -66
- data/vendor/local/share/gtk-doc/html/poppler/annotation-glossary.html +2 -2
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-22.html +2 -2
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-26.html +419 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-33.html +35 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-full.html +4 -0
- data/vendor/local/share/gtk-doc/html/poppler/index.html +3 -1
- data/vendor/local/share/gtk-doc/html/poppler/index.sgml +1 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-Version-and-Features-Information.html +1 -1
- data/vendor/local/share/gtk-doc/html/poppler/poppler.devhelp2 +3 -0
- data/vendor/local/share/license/openjpeg/AUTHORS +15 -0
- data/vendor/local/share/man/man1/pdftops.1 +18 -1
- data/vendor/local/share/man/man1/pdftotext.1 +4 -0
- data/vendor/local/share/man/man1/sqlite3.1 +45 -38
- metadata +20 -5
| @@ -0,0 +1,10 @@ | |
| 1 | 
            +
            /* create opj_config.h for CMake */
         | 
| 2 | 
            +
            #define OPJ_HAVE_STDINT_H 		1
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            /*--------------------------------------------------------------------------*/
         | 
| 5 | 
            +
            /* OpenJPEG Versioning                                                      */
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            /* Version number. */
         | 
| 8 | 
            +
            #define OPJ_VERSION_MAJOR 2
         | 
| 9 | 
            +
            #define OPJ_VERSION_MINOR 1
         | 
| 10 | 
            +
            #define OPJ_VERSION_BUILD 0
         | 
| @@ -0,0 +1,52 @@ | |
| 1 | 
            +
            /*
         | 
| 2 | 
            +
             * The copyright in this software is being made available under the 2-clauses 
         | 
| 3 | 
            +
             * BSD License, included below. This software may be subject to other third 
         | 
| 4 | 
            +
             * party and contributor rights, including patent rights, and no such rights
         | 
| 5 | 
            +
             * are granted under this license.
         | 
| 6 | 
            +
             *
         | 
| 7 | 
            +
             * Copyright (c) 2012, Mathieu Malaterre <mathieu.malaterre@gmail.com>
         | 
| 8 | 
            +
             * All rights reserved.
         | 
| 9 | 
            +
             *
         | 
| 10 | 
            +
             * Redistribution and use in source and binary forms, with or without
         | 
| 11 | 
            +
             * modification, are permitted provided that the following conditions
         | 
| 12 | 
            +
             * are met:
         | 
| 13 | 
            +
             * 1. Redistributions of source code must retain the above copyright
         | 
| 14 | 
            +
             *    notice, this list of conditions and the following disclaimer.
         | 
| 15 | 
            +
             * 2. Redistributions in binary form must reproduce the above copyright
         | 
| 16 | 
            +
             *    notice, this list of conditions and the following disclaimer in the
         | 
| 17 | 
            +
             *    documentation and/or other materials provided with the distribution.
         | 
| 18 | 
            +
             *
         | 
| 19 | 
            +
             * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
         | 
| 20 | 
            +
             * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
         | 
| 21 | 
            +
             * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
         | 
| 22 | 
            +
             * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
         | 
| 23 | 
            +
             * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
         | 
| 24 | 
            +
             * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
         | 
| 25 | 
            +
             * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
         | 
| 26 | 
            +
             * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
         | 
| 27 | 
            +
             * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
         | 
| 28 | 
            +
             * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
         | 
| 29 | 
            +
             * POSSIBILITY OF SUCH DAMAGE.
         | 
| 30 | 
            +
             */
         | 
| 31 | 
            +
            #ifndef OPJ_STDINT_H
         | 
| 32 | 
            +
            #define OPJ_STDINT_H
         | 
| 33 | 
            +
             | 
| 34 | 
            +
            #include "opj_config.h"
         | 
| 35 | 
            +
            #ifdef OPJ_HAVE_STDINT_H
         | 
| 36 | 
            +
            #include <stdint.h>
         | 
| 37 | 
            +
            #else
         | 
| 38 | 
            +
            #if defined(_WIN32)
         | 
| 39 | 
            +
            typedef   signed __int8   int8_t;
         | 
| 40 | 
            +
            typedef unsigned __int8   uint8_t;
         | 
| 41 | 
            +
            typedef   signed __int16  int16_t;
         | 
| 42 | 
            +
            typedef unsigned __int16  uint16_t;
         | 
| 43 | 
            +
            typedef   signed __int32  int32_t;
         | 
| 44 | 
            +
            typedef unsigned __int32  uint32_t;
         | 
| 45 | 
            +
            typedef   signed __int64  int64_t;
         | 
| 46 | 
            +
            typedef unsigned __int64  uint64_t;
         | 
| 47 | 
            +
            #else
         | 
| 48 | 
            +
            #error unsupported platform
         | 
| 49 | 
            +
            #endif
         | 
| 50 | 
            +
            #endif
         | 
| 51 | 
            +
             | 
| 52 | 
            +
            #endif /* OPJ_STDINT_H */
         | 
| @@ -1,6 +1,7 @@ | |
| 1 1 | 
             
            /*
         | 
| 2 2 | 
             
             * Copyright (C) 2009-2010, Pino Toscano <pino@kde.org>
         | 
| 3 3 | 
             
             * Copyright (C) 2010, Patrick Spendrin <ps_ml@gmx.de>
         | 
| 4 | 
            +
             * Copyright (C) 2014, Hans-Peter Deifel <hpdeifel@gmx.de>
         | 
| 4 5 | 
             
             *
         | 
| 5 6 | 
             
             * This program is free software; you can redistribute it and/or modify
         | 
| 6 7 | 
             
             * it under the terms of the GNU General Public License as published by
         | 
| @@ -106,6 +107,10 @@ POPPLER_CPP_EXPORT time_type convert_date(const std::string &date); | |
| 106 107 |  | 
| 107 108 | 
             
            POPPLER_CPP_EXPORT std::ostream& operator<<(std::ostream& stream, const byte_array &array);
         | 
| 108 109 |  | 
| 110 | 
            +
            typedef void(*debug_func)(const std::string &, void *);
         | 
| 111 | 
            +
             | 
| 112 | 
            +
            POPPLER_CPP_EXPORT void set_debug_error_function(debug_func debug_function, void *closure);
         | 
| 113 | 
            +
             | 
| 109 114 | 
             
            }
         | 
| 110 115 |  | 
| 111 116 | 
             
            #endif
         | 
| @@ -21,9 +21,9 @@ | |
| 21 21 |  | 
| 22 22 | 
             
            #include "poppler-global.h"
         | 
| 23 23 |  | 
| 24 | 
            -
            #define POPPLER_VERSION "0. | 
| 24 | 
            +
            #define POPPLER_VERSION "0.36.0"
         | 
| 25 25 | 
             
            #define POPPLER_VERSION_MAJOR 0
         | 
| 26 | 
            -
            #define POPPLER_VERSION_MINOR  | 
| 26 | 
            +
            #define POPPLER_VERSION_MINOR 36
         | 
| 27 27 | 
             
            #define POPPLER_VERSION_MICRO 0
         | 
| 28 28 |  | 
| 29 29 | 
             
            namespace poppler
         | 
| @@ -202,6 +202,8 @@ void                          poppler_annot_markup_set_popup_is_open           ( | |
| 202 202 | 
             
            										gboolean            is_open);
         | 
| 203 203 | 
             
            gboolean                      poppler_annot_markup_get_popup_rectangle         (PopplerAnnotMarkup *poppler_annot,
         | 
| 204 204 | 
             
            										PopplerRectangle   *poppler_rect);
         | 
| 205 | 
            +
            void                          poppler_annot_markup_set_popup_rectangle         (PopplerAnnotMarkup *poppler_annot,
         | 
| 206 | 
            +
                                                                                            PopplerRectangle   *poppler_rect);
         | 
| 205 207 | 
             
            gdouble                       poppler_annot_markup_get_opacity                 (PopplerAnnotMarkup *poppler_annot);
         | 
| 206 208 | 
             
            void                          poppler_annot_markup_set_opacity                 (PopplerAnnotMarkup *poppler_annot,
         | 
| 207 209 | 
             
            										gdouble             opacity);
         | 
| @@ -23,7 +23,7 @@ | |
| 23 23 | 
             
            **
         | 
| 24 24 | 
             
            ** The official C-language API documentation for SQLite is derived
         | 
| 25 25 | 
             
            ** from comments in this file.  This file is the authoritative source
         | 
| 26 | 
            -
            ** on how SQLite interfaces are  | 
| 26 | 
            +
            ** on how SQLite interfaces are supposed to operate.
         | 
| 27 27 | 
             
            **
         | 
| 28 28 | 
             
            ** The name of this file under configuration management is "sqlite.h.in".
         | 
| 29 29 | 
             
            ** The makefile makes some minor changes to this file (such as inserting
         | 
| @@ -43,21 +43,25 @@ extern "C" { | |
| 43 43 |  | 
| 44 44 |  | 
| 45 45 | 
             
            /*
         | 
| 46 | 
            -
            **  | 
| 46 | 
            +
            ** Provide the ability to override linkage features of the interface.
         | 
| 47 47 | 
             
            */
         | 
| 48 48 | 
             
            #ifndef SQLITE_EXTERN
         | 
| 49 49 | 
             
            # define SQLITE_EXTERN extern
         | 
| 50 50 | 
             
            #endif
         | 
| 51 | 
            -
             | 
| 52 51 | 
             
            #ifndef SQLITE_API
         | 
| 53 52 | 
             
            # define SQLITE_API
         | 
| 54 53 | 
             
            #endif
         | 
| 55 | 
            -
             | 
| 54 | 
            +
            #ifndef SQLITE_CDECL
         | 
| 55 | 
            +
            # define SQLITE_CDECL
         | 
| 56 | 
            +
            #endif
         | 
| 57 | 
            +
            #ifndef SQLITE_STDCALL
         | 
| 58 | 
            +
            # define SQLITE_STDCALL
         | 
| 59 | 
            +
            #endif
         | 
| 56 60 |  | 
| 57 61 | 
             
            /*
         | 
| 58 62 | 
             
            ** These no-op macros are used in front of interfaces to mark those
         | 
| 59 63 | 
             
            ** interfaces as either deprecated or experimental.  New applications
         | 
| 60 | 
            -
            ** should not use deprecated interfaces - they are  | 
| 64 | 
            +
            ** should not use deprecated interfaces - they are supported for backwards
         | 
| 61 65 | 
             
            ** compatibility only.  Application writers should be aware that
         | 
| 62 66 | 
             
            ** experimental interfaces are subject to change in point releases.
         | 
| 63 67 | 
             
            **
         | 
| @@ -107,9 +111,9 @@ extern "C" { | |
| 107 111 | 
             
            ** [sqlite3_libversion_number()], [sqlite3_sourceid()],
         | 
| 108 112 | 
             
            ** [sqlite_version()] and [sqlite_source_id()].
         | 
| 109 113 | 
             
            */
         | 
| 110 | 
            -
            #define SQLITE_VERSION        "3.8. | 
| 111 | 
            -
            #define SQLITE_VERSION_NUMBER  | 
| 112 | 
            -
            #define SQLITE_SOURCE_ID      " | 
| 114 | 
            +
            #define SQLITE_VERSION        "3.8.11.1"
         | 
| 115 | 
            +
            #define SQLITE_VERSION_NUMBER 3008011
         | 
| 116 | 
            +
            #define SQLITE_SOURCE_ID      "2015-07-29 20:00:57 cf538e2783e468bbc25e7cb2a9ee64d3e0e80b2f"
         | 
| 113 117 |  | 
| 114 118 | 
             
            /*
         | 
| 115 119 | 
             
            ** CAPI3REF: Run-Time Library Version Numbers
         | 
| @@ -142,9 +146,9 @@ extern "C" { | |
| 142 146 | 
             
            ** See also: [sqlite_version()] and [sqlite_source_id()].
         | 
| 143 147 | 
             
            */
         | 
| 144 148 | 
             
            SQLITE_API SQLITE_EXTERN const char sqlite3_version[];
         | 
| 145 | 
            -
            SQLITE_API const char *sqlite3_libversion(void);
         | 
| 146 | 
            -
            SQLITE_API const char *sqlite3_sourceid(void);
         | 
| 147 | 
            -
            SQLITE_API int sqlite3_libversion_number(void);
         | 
| 149 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_libversion(void);
         | 
| 150 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_sourceid(void);
         | 
| 151 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_libversion_number(void);
         | 
| 148 152 |  | 
| 149 153 | 
             
            /*
         | 
| 150 154 | 
             
            ** CAPI3REF: Run-Time Library Compilation Options Diagnostics
         | 
| @@ -169,8 +173,8 @@ SQLITE_API int sqlite3_libversion_number(void); | |
| 169 173 | 
             
            ** [sqlite_compileoption_get()] and the [compile_options pragma].
         | 
| 170 174 | 
             
            */
         | 
| 171 175 | 
             
            #ifndef SQLITE_OMIT_COMPILEOPTION_DIAGS
         | 
| 172 | 
            -
            SQLITE_API int sqlite3_compileoption_used(const char *zOptName);
         | 
| 173 | 
            -
            SQLITE_API const char *sqlite3_compileoption_get(int N);
         | 
| 176 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_compileoption_used(const char *zOptName);
         | 
| 177 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_compileoption_get(int N);
         | 
| 174 178 | 
             
            #endif
         | 
| 175 179 |  | 
| 176 180 | 
             
            /*
         | 
| @@ -201,7 +205,7 @@ SQLITE_API const char *sqlite3_compileoption_get(int N); | |
| 201 205 | 
             
            ** SQLITE_THREADSAFE=1 or =2 then mutexes are enabled by default but
         | 
| 202 206 | 
             
            ** can be fully or partially disabled using a call to [sqlite3_config()]
         | 
| 203 207 | 
             
            ** with the verbs [SQLITE_CONFIG_SINGLETHREAD], [SQLITE_CONFIG_MULTITHREAD],
         | 
| 204 | 
            -
            ** or [ | 
| 208 | 
            +
            ** or [SQLITE_CONFIG_SERIALIZED].  ^(The return value of the
         | 
| 205 209 | 
             
            ** sqlite3_threadsafe() function shows only the compile-time setting of
         | 
| 206 210 | 
             
            ** thread safety, not any run-time changes to that setting made by
         | 
| 207 211 | 
             
            ** sqlite3_config(). In other words, the return value from sqlite3_threadsafe()
         | 
| @@ -209,7 +213,7 @@ SQLITE_API const char *sqlite3_compileoption_get(int N); | |
| 209 213 | 
             
            **
         | 
| 210 214 | 
             
            ** See the [threading mode] documentation for additional information.
         | 
| 211 215 | 
             
            */
         | 
| 212 | 
            -
            SQLITE_API int sqlite3_threadsafe(void);
         | 
| 216 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_threadsafe(void);
         | 
| 213 217 |  | 
| 214 218 | 
             
            /*
         | 
| 215 219 | 
             
            ** CAPI3REF: Database Connection Handle
         | 
| @@ -266,6 +270,7 @@ typedef sqlite_uint64 sqlite3_uint64; | |
| 266 270 |  | 
| 267 271 | 
             
            /*
         | 
| 268 272 | 
             
            ** CAPI3REF: Closing A Database Connection
         | 
| 273 | 
            +
            ** DESTRUCTOR: sqlite3
         | 
| 269 274 | 
             
            **
         | 
| 270 275 | 
             
            ** ^The sqlite3_close() and sqlite3_close_v2() routines are destructors
         | 
| 271 276 | 
             
            ** for the [sqlite3] object.
         | 
| @@ -305,8 +310,8 @@ typedef sqlite_uint64 sqlite3_uint64; | |
| 305 310 | 
             
            ** ^Calling sqlite3_close() or sqlite3_close_v2() with a NULL pointer
         | 
| 306 311 | 
             
            ** argument is a harmless no-op.
         | 
| 307 312 | 
             
            */
         | 
| 308 | 
            -
            SQLITE_API int sqlite3_close(sqlite3*);
         | 
| 309 | 
            -
            SQLITE_API int sqlite3_close_v2(sqlite3*);
         | 
| 313 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_close(sqlite3*);
         | 
| 314 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_close_v2(sqlite3*);
         | 
| 310 315 |  | 
| 311 316 | 
             
            /*
         | 
| 312 317 | 
             
            ** The type for a callback function.
         | 
| @@ -317,6 +322,7 @@ typedef int (*sqlite3_callback)(void*,int,char**, char**); | |
| 317 322 |  | 
| 318 323 | 
             
            /*
         | 
| 319 324 | 
             
            ** CAPI3REF: One-Step Query Execution Interface
         | 
| 325 | 
            +
            ** METHOD: sqlite3
         | 
| 320 326 | 
             
            **
         | 
| 321 327 | 
             
            ** The sqlite3_exec() interface is a convenience wrapper around
         | 
| 322 328 | 
             
            ** [sqlite3_prepare_v2()], [sqlite3_step()], and [sqlite3_finalize()],
         | 
| @@ -376,7 +382,7 @@ typedef int (*sqlite3_callback)(void*,int,char**, char**); | |
| 376 382 | 
             
            **      the 2nd parameter of sqlite3_exec() while sqlite3_exec() is running.
         | 
| 377 383 | 
             
            ** </ul>
         | 
| 378 384 | 
             
            */
         | 
| 379 | 
            -
            SQLITE_API int sqlite3_exec(
         | 
| 385 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_exec(
         | 
| 380 386 | 
             
              sqlite3*,                                  /* An open database */
         | 
| 381 387 | 
             
              const char *sql,                           /* SQL to be evaluated */
         | 
| 382 388 | 
             
              int (*callback)(void*,int,char**,char**),  /* Callback function */
         | 
| @@ -497,6 +503,7 @@ SQLITE_API int sqlite3_exec( | |
| 497 503 | 
             
            #define SQLITE_NOTICE_RECOVER_WAL      (SQLITE_NOTICE | (1<<8))
         | 
| 498 504 | 
             
            #define SQLITE_NOTICE_RECOVER_ROLLBACK (SQLITE_NOTICE | (2<<8))
         | 
| 499 505 | 
             
            #define SQLITE_WARNING_AUTOINDEX       (SQLITE_WARNING | (1<<8))
         | 
| 506 | 
            +
            #define SQLITE_AUTH_USER               (SQLITE_AUTH | (1<<8))
         | 
| 500 507 |  | 
| 501 508 | 
             
            /*
         | 
| 502 509 | 
             
            ** CAPI3REF: Flags For File Open Operations
         | 
| @@ -755,14 +762,16 @@ struct sqlite3_io_methods { | |
| 755 762 | 
             
            ** of the [sqlite3_io_methods] object and for the [sqlite3_file_control()]
         | 
| 756 763 | 
             
            ** interface.
         | 
| 757 764 | 
             
            **
         | 
| 765 | 
            +
            ** <ul>
         | 
| 766 | 
            +
            ** <li>[[SQLITE_FCNTL_LOCKSTATE]]
         | 
| 758 767 | 
             
            ** The [SQLITE_FCNTL_LOCKSTATE] opcode is used for debugging.  This
         | 
| 759 768 | 
             
            ** opcode causes the xFileControl method to write the current state of
         | 
| 760 769 | 
             
            ** the lock (one of [SQLITE_LOCK_NONE], [SQLITE_LOCK_SHARED],
         | 
| 761 770 | 
             
            ** [SQLITE_LOCK_RESERVED], [SQLITE_LOCK_PENDING], or [SQLITE_LOCK_EXCLUSIVE])
         | 
| 762 771 | 
             
            ** into an integer that the pArg argument points to. This capability
         | 
| 763 | 
            -
            ** is used during testing and only  | 
| 764 | 
            -
            ** is  | 
| 765 | 
            -
            ** | 
| 772 | 
            +
            ** is used during testing and is only available when the SQLITE_TEST
         | 
| 773 | 
            +
            ** compile-time option is used.
         | 
| 774 | 
            +
            **
         | 
| 766 775 | 
             
            ** <li>[[SQLITE_FCNTL_SIZE_HINT]]
         | 
| 767 776 | 
             
            ** The [SQLITE_FCNTL_SIZE_HINT] opcode is used by SQLite to give the VFS
         | 
| 768 777 | 
             
            ** layer a hint of how large the database file will grow to be during the
         | 
| @@ -887,7 +896,9 @@ struct sqlite3_io_methods { | |
| 887 896 | 
             
            ** [PRAGMA] processing continues.  ^If the [SQLITE_FCNTL_PRAGMA]
         | 
| 888 897 | 
             
            ** file control returns [SQLITE_OK], then the parser assumes that the
         | 
| 889 898 | 
             
            ** VFS has handled the PRAGMA itself and the parser generates a no-op
         | 
| 890 | 
            -
            ** prepared statement | 
| 899 | 
            +
            ** prepared statement if result string is NULL, or that returns a copy
         | 
| 900 | 
            +
            ** of the result string if the string is non-NULL.
         | 
| 901 | 
            +
            ** ^If the [SQLITE_FCNTL_PRAGMA] file control returns
         | 
| 891 902 | 
             
            ** any result code other than [SQLITE_OK] or [SQLITE_NOTFOUND], that means
         | 
| 892 903 | 
             
            ** that the VFS encountered an error while handling the [PRAGMA] and the
         | 
| 893 904 | 
             
            ** compilation of the PRAGMA fails with an error.  ^The [SQLITE_FCNTL_PRAGMA]
         | 
| @@ -945,12 +956,27 @@ struct sqlite3_io_methods { | |
| 945 956 | 
             
            ** pointed to by the pArg argument.  This capability is used during testing
         | 
| 946 957 | 
             
            ** and only needs to be supported when SQLITE_TEST is defined.
         | 
| 947 958 | 
             
            **
         | 
| 959 | 
            +
            ** <li>[[SQLITE_FCNTL_WAL_BLOCK]]
         | 
| 960 | 
            +
            ** The [SQLITE_FCNTL_WAL_BLOCK] is a signal to the VFS layer that it might
         | 
| 961 | 
            +
            ** be advantageous to block on the next WAL lock if the lock is not immediately
         | 
| 962 | 
            +
            ** available.  The WAL subsystem issues this signal during rare
         | 
| 963 | 
            +
            ** circumstances in order to fix a problem with priority inversion.
         | 
| 964 | 
            +
            ** Applications should <em>not</em> use this file-control.
         | 
| 965 | 
            +
            **
         | 
| 966 | 
            +
            ** <li>[[SQLITE_FCNTL_ZIPVFS]]
         | 
| 967 | 
            +
            ** The [SQLITE_FCNTL_ZIPVFS] opcode is implemented by zipvfs only. All other
         | 
| 968 | 
            +
            ** VFS should return SQLITE_NOTFOUND for this opcode.
         | 
| 969 | 
            +
            **
         | 
| 970 | 
            +
            ** <li>[[SQLITE_FCNTL_RBU]]
         | 
| 971 | 
            +
            ** The [SQLITE_FCNTL_RBU] opcode is implemented by the special VFS used by
         | 
| 972 | 
            +
            ** the RBU extension only.  All other VFS should return SQLITE_NOTFOUND for
         | 
| 973 | 
            +
            ** this opcode.  
         | 
| 948 974 | 
             
            ** </ul>
         | 
| 949 975 | 
             
            */
         | 
| 950 976 | 
             
            #define SQLITE_FCNTL_LOCKSTATE               1
         | 
| 951 | 
            -
            #define  | 
| 952 | 
            -
            #define  | 
| 953 | 
            -
            #define  | 
| 977 | 
            +
            #define SQLITE_FCNTL_GET_LOCKPROXYFILE       2
         | 
| 978 | 
            +
            #define SQLITE_FCNTL_SET_LOCKPROXYFILE       3
         | 
| 979 | 
            +
            #define SQLITE_FCNTL_LAST_ERRNO              4
         | 
| 954 980 | 
             
            #define SQLITE_FCNTL_SIZE_HINT               5
         | 
| 955 981 | 
             
            #define SQLITE_FCNTL_CHUNK_SIZE              6
         | 
| 956 982 | 
             
            #define SQLITE_FCNTL_FILE_POINTER            7
         | 
| @@ -969,6 +995,15 @@ struct sqlite3_io_methods { | |
| 969 995 | 
             
            #define SQLITE_FCNTL_SYNC                   21
         | 
| 970 996 | 
             
            #define SQLITE_FCNTL_COMMIT_PHASETWO        22
         | 
| 971 997 | 
             
            #define SQLITE_FCNTL_WIN32_SET_HANDLE       23
         | 
| 998 | 
            +
            #define SQLITE_FCNTL_WAL_BLOCK              24
         | 
| 999 | 
            +
            #define SQLITE_FCNTL_ZIPVFS                 25
         | 
| 1000 | 
            +
            #define SQLITE_FCNTL_RBU                    26
         | 
| 1001 | 
            +
             | 
| 1002 | 
            +
            /* deprecated names */
         | 
| 1003 | 
            +
            #define SQLITE_GET_LOCKPROXYFILE      SQLITE_FCNTL_GET_LOCKPROXYFILE
         | 
| 1004 | 
            +
            #define SQLITE_SET_LOCKPROXYFILE      SQLITE_FCNTL_SET_LOCKPROXYFILE
         | 
| 1005 | 
            +
            #define SQLITE_LAST_ERRNO             SQLITE_FCNTL_LAST_ERRNO
         | 
| 1006 | 
            +
             | 
| 972 1007 |  | 
| 973 1008 | 
             
            /*
         | 
| 974 1009 | 
             
            ** CAPI3REF: Mutex Handle
         | 
| @@ -1220,7 +1255,7 @@ struct sqlite3_vfs { | |
| 1220 1255 | 
             
            ** </ul>
         | 
| 1221 1256 | 
             
            **
         | 
| 1222 1257 | 
             
            ** When unlocking, the same SHARED or EXCLUSIVE flag must be supplied as
         | 
| 1223 | 
            -
            ** was given  | 
| 1258 | 
            +
            ** was given on the corresponding lock.  
         | 
| 1224 1259 | 
             
            **
         | 
| 1225 1260 | 
             
            ** The xShmLock method can transition between unlocked and SHARED or
         | 
| 1226 1261 | 
             
            ** between unlocked and EXCLUSIVE.  It cannot transition between SHARED
         | 
| @@ -1317,10 +1352,10 @@ struct sqlite3_vfs { | |
| 1317 1352 | 
             
            ** must return [SQLITE_OK] on success and some other [error code] upon
         | 
| 1318 1353 | 
             
            ** failure.
         | 
| 1319 1354 | 
             
            */
         | 
| 1320 | 
            -
            SQLITE_API int sqlite3_initialize(void);
         | 
| 1321 | 
            -
            SQLITE_API int sqlite3_shutdown(void);
         | 
| 1322 | 
            -
            SQLITE_API int sqlite3_os_init(void);
         | 
| 1323 | 
            -
            SQLITE_API int sqlite3_os_end(void);
         | 
| 1355 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_initialize(void);
         | 
| 1356 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_shutdown(void);
         | 
| 1357 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_os_init(void);
         | 
| 1358 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_os_end(void);
         | 
| 1324 1359 |  | 
| 1325 1360 | 
             
            /*
         | 
| 1326 1361 | 
             
            ** CAPI3REF: Configuring The SQLite Library
         | 
| @@ -1351,10 +1386,11 @@ SQLITE_API int sqlite3_os_end(void); | |
| 1351 1386 | 
             
            ** ^If the option is unknown or SQLite is unable to set the option
         | 
| 1352 1387 | 
             
            ** then this routine returns a non-zero [error code].
         | 
| 1353 1388 | 
             
            */
         | 
| 1354 | 
            -
            SQLITE_API int sqlite3_config(int, ...);
         | 
| 1389 | 
            +
            SQLITE_API int SQLITE_CDECL sqlite3_config(int, ...);
         | 
| 1355 1390 |  | 
| 1356 1391 | 
             
            /*
         | 
| 1357 1392 | 
             
            ** CAPI3REF: Configure database connections
         | 
| 1393 | 
            +
            ** METHOD: sqlite3
         | 
| 1358 1394 | 
             
            **
         | 
| 1359 1395 | 
             
            ** The sqlite3_db_config() interface is used to make configuration
         | 
| 1360 1396 | 
             
            ** changes to a [database connection].  The interface is similar to
         | 
| @@ -1369,7 +1405,7 @@ SQLITE_API int sqlite3_config(int, ...); | |
| 1369 1405 | 
             
            ** ^Calls to sqlite3_db_config() return SQLITE_OK if and only if
         | 
| 1370 1406 | 
             
            ** the call is considered successful.
         | 
| 1371 1407 | 
             
            */
         | 
| 1372 | 
            -
            SQLITE_API int sqlite3_db_config(sqlite3*, int op, ...);
         | 
| 1408 | 
            +
            SQLITE_API int SQLITE_CDECL sqlite3_db_config(sqlite3*, int op, ...);
         | 
| 1373 1409 |  | 
| 1374 1410 | 
             
            /*
         | 
| 1375 1411 | 
             
            ** CAPI3REF: Memory Allocation Routines
         | 
| @@ -1503,31 +1539,33 @@ struct sqlite3_mem_methods { | |
| 1503 1539 | 
             
            ** SQLITE_CONFIG_SERIALIZED configuration option.</dd>
         | 
| 1504 1540 | 
             
            **
         | 
| 1505 1541 | 
             
            ** [[SQLITE_CONFIG_MALLOC]] <dt>SQLITE_CONFIG_MALLOC</dt>
         | 
| 1506 | 
            -
            ** <dd> ^( | 
| 1507 | 
            -
            ** instance of the [sqlite3_mem_methods] structure. | 
| 1542 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_MALLOC option takes a single argument which is 
         | 
| 1543 | 
            +
            ** a pointer to an instance of the [sqlite3_mem_methods] structure.
         | 
| 1544 | 
            +
            ** The argument specifies
         | 
| 1508 1545 | 
             
            ** alternative low-level memory allocation routines to be used in place of
         | 
| 1509 1546 | 
             
            ** the memory allocation routines built into SQLite.)^ ^SQLite makes
         | 
| 1510 1547 | 
             
            ** its own private copy of the content of the [sqlite3_mem_methods] structure
         | 
| 1511 1548 | 
             
            ** before the [sqlite3_config()] call returns.</dd>
         | 
| 1512 1549 | 
             
            **
         | 
| 1513 1550 | 
             
            ** [[SQLITE_CONFIG_GETMALLOC]] <dt>SQLITE_CONFIG_GETMALLOC</dt>
         | 
| 1514 | 
            -
            ** <dd> ^( | 
| 1515 | 
            -
            ** instance of the [sqlite3_mem_methods] structure. | 
| 1551 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_GETMALLOC option takes a single argument which
         | 
| 1552 | 
            +
            ** is a pointer to an instance of the [sqlite3_mem_methods] structure.
         | 
| 1553 | 
            +
            ** The [sqlite3_mem_methods]
         | 
| 1516 1554 | 
             
            ** structure is filled with the currently defined memory allocation routines.)^
         | 
| 1517 1555 | 
             
            ** This option can be used to overload the default memory allocation
         | 
| 1518 1556 | 
             
            ** routines with a wrapper that simulations memory allocation failure or
         | 
| 1519 1557 | 
             
            ** tracks memory usage, for example. </dd>
         | 
| 1520 1558 | 
             
            **
         | 
| 1521 1559 | 
             
            ** [[SQLITE_CONFIG_MEMSTATUS]] <dt>SQLITE_CONFIG_MEMSTATUS</dt>
         | 
| 1522 | 
            -
            ** <dd> ^ | 
| 1523 | 
            -
            ** boolean, which enables or disables the collection of | 
| 1524 | 
            -
            ** statistics. ^(When memory allocation statistics are | 
| 1525 | 
            -
            ** following SQLite interfaces become non-operational:
         | 
| 1560 | 
            +
            ** <dd> ^The SQLITE_CONFIG_MEMSTATUS option takes single argument of type int,
         | 
| 1561 | 
            +
            ** interpreted as a boolean, which enables or disables the collection of
         | 
| 1562 | 
            +
            ** memory allocation statistics. ^(When memory allocation statistics are
         | 
| 1563 | 
            +
            ** disabled, the following SQLite interfaces become non-operational:
         | 
| 1526 1564 | 
             
            **   <ul>
         | 
| 1527 1565 | 
             
            **   <li> [sqlite3_memory_used()]
         | 
| 1528 1566 | 
             
            **   <li> [sqlite3_memory_highwater()]
         | 
| 1529 1567 | 
             
            **   <li> [sqlite3_soft_heap_limit64()]
         | 
| 1530 | 
            -
            **   <li> [ | 
| 1568 | 
            +
            **   <li> [sqlite3_status64()]
         | 
| 1531 1569 | 
             
            **   </ul>)^
         | 
| 1532 1570 | 
             
            ** ^Memory allocation statistics are enabled by default unless SQLite is
         | 
| 1533 1571 | 
             
            ** compiled with [SQLITE_DEFAULT_MEMSTATUS]=0 in which case memory
         | 
| @@ -1535,53 +1573,67 @@ struct sqlite3_mem_methods { | |
| 1535 1573 | 
             
            ** </dd>
         | 
| 1536 1574 | 
             
            **
         | 
| 1537 1575 | 
             
            ** [[SQLITE_CONFIG_SCRATCH]] <dt>SQLITE_CONFIG_SCRATCH</dt>
         | 
| 1538 | 
            -
            ** <dd> ^ | 
| 1539 | 
            -
            ** scratch memory.  There are three arguments | 
| 1576 | 
            +
            ** <dd> ^The SQLITE_CONFIG_SCRATCH option specifies a static memory buffer
         | 
| 1577 | 
            +
            ** that SQLite can use for scratch memory.  ^(There are three arguments
         | 
| 1578 | 
            +
            ** to SQLITE_CONFIG_SCRATCH:  A pointer an 8-byte
         | 
| 1540 1579 | 
             
            ** aligned memory buffer from which the scratch allocations will be
         | 
| 1541 1580 | 
             
            ** drawn, the size of each scratch allocation (sz),
         | 
| 1542 | 
            -
            ** and the maximum number of scratch allocations (N). | 
| 1543 | 
            -
            ** argument must be a multiple of 16.
         | 
| 1581 | 
            +
            ** and the maximum number of scratch allocations (N).)^
         | 
| 1544 1582 | 
             
            ** The first argument must be a pointer to an 8-byte aligned buffer
         | 
| 1545 1583 | 
             
            ** of at least sz*N bytes of memory.
         | 
| 1546 | 
            -
            ** ^SQLite will use  | 
| 1547 | 
            -
            **  | 
| 1548 | 
            -
            **  | 
| 1549 | 
            -
            **  | 
| 1584 | 
            +
            ** ^SQLite will not use more than one scratch buffers per thread.
         | 
| 1585 | 
            +
            ** ^SQLite will never request a scratch buffer that is more than 6
         | 
| 1586 | 
            +
            ** times the database page size.
         | 
| 1587 | 
            +
            ** ^If SQLite needs needs additional
         | 
| 1550 1588 | 
             
            ** scratch memory beyond what is provided by this configuration option, then 
         | 
| 1551 | 
            -
            ** [sqlite3_malloc()] will be used to obtain the memory needed | 
| 1589 | 
            +
            ** [sqlite3_malloc()] will be used to obtain the memory needed.<p>
         | 
| 1590 | 
            +
            ** ^When the application provides any amount of scratch memory using
         | 
| 1591 | 
            +
            ** SQLITE_CONFIG_SCRATCH, SQLite avoids unnecessary large
         | 
| 1592 | 
            +
            ** [sqlite3_malloc|heap allocations].
         | 
| 1593 | 
            +
            ** This can help [Robson proof|prevent memory allocation failures] due to heap
         | 
| 1594 | 
            +
            ** fragmentation in low-memory embedded systems.
         | 
| 1595 | 
            +
            ** </dd>
         | 
| 1552 1596 | 
             
            **
         | 
| 1553 1597 | 
             
            ** [[SQLITE_CONFIG_PAGECACHE]] <dt>SQLITE_CONFIG_PAGECACHE</dt>
         | 
| 1554 | 
            -
            ** <dd> ^ | 
| 1555 | 
            -
            ** the database page cache with the default page | 
| 1598 | 
            +
            ** <dd> ^The SQLITE_CONFIG_PAGECACHE option specifies a static memory buffer
         | 
| 1599 | 
            +
            ** that SQLite can use for the database page cache with the default page
         | 
| 1600 | 
            +
            ** cache implementation.  
         | 
| 1556 1601 | 
             
            ** This configuration should not be used if an application-define page
         | 
| 1557 | 
            -
            ** cache implementation is loaded using the SQLITE_CONFIG_PCACHE2 | 
| 1558 | 
            -
            **  | 
| 1602 | 
            +
            ** cache implementation is loaded using the [SQLITE_CONFIG_PCACHE2]
         | 
| 1603 | 
            +
            ** configuration option.
         | 
| 1604 | 
            +
            ** ^There are three arguments to SQLITE_CONFIG_PAGECACHE: A pointer to
         | 
| 1605 | 
            +
            ** 8-byte aligned
         | 
| 1559 1606 | 
             
            ** memory, the size of each page buffer (sz), and the number of pages (N).
         | 
| 1560 1607 | 
             
            ** The sz argument should be the size of the largest database page
         | 
| 1561 | 
            -
            ** (a power of two between 512 and  | 
| 1562 | 
            -
            ** page header.  ^The  | 
| 1563 | 
            -
            **  | 
| 1564 | 
            -
            ** to  | 
| 1565 | 
            -
            **  | 
| 1608 | 
            +
            ** (a power of two between 512 and 65536) plus some extra bytes for each
         | 
| 1609 | 
            +
            ** page header.  ^The number of extra bytes needed by the page header
         | 
| 1610 | 
            +
            ** can be determined using the [SQLITE_CONFIG_PCACHE_HDRSZ] option 
         | 
| 1611 | 
            +
            ** to [sqlite3_config()].
         | 
| 1612 | 
            +
            ** ^It is harmless, apart from the wasted memory,
         | 
| 1613 | 
            +
            ** for the sz parameter to be larger than necessary.  The first
         | 
| 1614 | 
            +
            ** argument should pointer to an 8-byte aligned block of memory that
         | 
| 1615 | 
            +
            ** is at least sz*N bytes of memory, otherwise subsequent behavior is
         | 
| 1616 | 
            +
            ** undefined.
         | 
| 1566 1617 | 
             
            ** ^SQLite will use the memory provided by the first argument to satisfy its
         | 
| 1567 1618 | 
             
            ** memory needs for the first N pages that it adds to cache.  ^If additional
         | 
| 1568 1619 | 
             
            ** page cache memory is needed beyond what is provided by this option, then
         | 
| 1569 | 
            -
            ** SQLite goes to [sqlite3_malloc()] for the additional storage space | 
| 1570 | 
            -
            ** The pointer in the first argument must
         | 
| 1571 | 
            -
            ** be aligned to an 8-byte boundary or subsequent behavior of SQLite
         | 
| 1572 | 
            -
            ** will be undefined.</dd>
         | 
| 1620 | 
            +
            ** SQLite goes to [sqlite3_malloc()] for the additional storage space.</dd>
         | 
| 1573 1621 | 
             
            **
         | 
| 1574 1622 | 
             
            ** [[SQLITE_CONFIG_HEAP]] <dt>SQLITE_CONFIG_HEAP</dt>
         | 
| 1575 | 
            -
            ** <dd> ^ | 
| 1576 | 
            -
            ** for all of its dynamic memory allocation needs | 
| 1577 | 
            -
            ** for by [SQLITE_CONFIG_SCRATCH] and | 
| 1578 | 
            -
            **  | 
| 1623 | 
            +
            ** <dd> ^The SQLITE_CONFIG_HEAP option specifies a static memory buffer 
         | 
| 1624 | 
            +
            ** that SQLite will use for all of its dynamic memory allocation needs
         | 
| 1625 | 
            +
            ** beyond those provided for by [SQLITE_CONFIG_SCRATCH] and
         | 
| 1626 | 
            +
            ** [SQLITE_CONFIG_PAGECACHE].
         | 
| 1627 | 
            +
            ** ^The SQLITE_CONFIG_HEAP option is only available if SQLite is compiled
         | 
| 1628 | 
            +
            ** with either [SQLITE_ENABLE_MEMSYS3] or [SQLITE_ENABLE_MEMSYS5] and returns
         | 
| 1629 | 
            +
            ** [SQLITE_ERROR] if invoked otherwise.
         | 
| 1630 | 
            +
            ** ^There are three arguments to SQLITE_CONFIG_HEAP:
         | 
| 1631 | 
            +
            ** An 8-byte aligned pointer to the memory,
         | 
| 1579 1632 | 
             
            ** the number of bytes in the memory buffer, and the minimum allocation size.
         | 
| 1580 1633 | 
             
            ** ^If the first pointer (the memory pointer) is NULL, then SQLite reverts
         | 
| 1581 1634 | 
             
            ** to using its default memory allocator (the system malloc() implementation),
         | 
| 1582 1635 | 
             
            ** undoing any prior invocation of [SQLITE_CONFIG_MALLOC].  ^If the
         | 
| 1583 | 
            -
            ** memory pointer is not NULL  | 
| 1584 | 
            -
            ** [SQLITE_ENABLE_MEMSYS5] are defined, then the alternative memory
         | 
| 1636 | 
            +
            ** memory pointer is not NULL then the alternative memory
         | 
| 1585 1637 | 
             
            ** allocator is engaged to handle all of SQLites memory allocation needs.
         | 
| 1586 1638 | 
             
            ** The first pointer (the memory pointer) must be aligned to an 8-byte
         | 
| 1587 1639 | 
             
            ** boundary or subsequent behavior of SQLite will be undefined.
         | 
| @@ -1589,11 +1641,11 @@ struct sqlite3_mem_methods { | |
| 1589 1641 | 
             
            ** for the minimum allocation size are 2**5 through 2**8.</dd>
         | 
| 1590 1642 | 
             
            **
         | 
| 1591 1643 | 
             
            ** [[SQLITE_CONFIG_MUTEX]] <dt>SQLITE_CONFIG_MUTEX</dt>
         | 
| 1592 | 
            -
            ** <dd> ^( | 
| 1593 | 
            -
            ** instance of the [sqlite3_mutex_methods] structure. | 
| 1594 | 
            -
            ** alternative low-level mutex routines to be used | 
| 1595 | 
            -
            ** the mutex routines built into SQLite.)^  ^SQLite makes a copy of | 
| 1596 | 
            -
            ** content of the [sqlite3_mutex_methods] structure before the call to
         | 
| 1644 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_MUTEX option takes a single argument which is a
         | 
| 1645 | 
            +
            ** pointer to an instance of the [sqlite3_mutex_methods] structure.
         | 
| 1646 | 
            +
            ** The argument specifies alternative low-level mutex routines to be used
         | 
| 1647 | 
            +
            ** in place the mutex routines built into SQLite.)^  ^SQLite makes a copy of
         | 
| 1648 | 
            +
            ** the content of the [sqlite3_mutex_methods] structure before the call to
         | 
| 1597 1649 | 
             
            ** [sqlite3_config()] returns. ^If SQLite is compiled with
         | 
| 1598 1650 | 
             
            ** the [SQLITE_THREADSAFE | SQLITE_THREADSAFE=0] compile-time option then
         | 
| 1599 1651 | 
             
            ** the entire mutexing subsystem is omitted from the build and hence calls to
         | 
| @@ -1601,8 +1653,8 @@ struct sqlite3_mem_methods { | |
| 1601 1653 | 
             
            ** return [SQLITE_ERROR].</dd>
         | 
| 1602 1654 | 
             
            **
         | 
| 1603 1655 | 
             
            ** [[SQLITE_CONFIG_GETMUTEX]] <dt>SQLITE_CONFIG_GETMUTEX</dt>
         | 
| 1604 | 
            -
            ** <dd> ^( | 
| 1605 | 
            -
            ** instance of the [sqlite3_mutex_methods] structure.  The
         | 
| 1656 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_GETMUTEX option takes a single argument which
         | 
| 1657 | 
            +
            ** is a pointer to an instance of the [sqlite3_mutex_methods] structure.  The
         | 
| 1606 1658 | 
             
            ** [sqlite3_mutex_methods]
         | 
| 1607 1659 | 
             
            ** structure is filled with the currently defined mutex routines.)^
         | 
| 1608 1660 | 
             
            ** This option can be used to overload the default mutex allocation
         | 
| @@ -1614,25 +1666,25 @@ struct sqlite3_mem_methods { | |
| 1614 1666 | 
             
            ** return [SQLITE_ERROR].</dd>
         | 
| 1615 1667 | 
             
            **
         | 
| 1616 1668 | 
             
            ** [[SQLITE_CONFIG_LOOKASIDE]] <dt>SQLITE_CONFIG_LOOKASIDE</dt>
         | 
| 1617 | 
            -
            ** <dd> ^( | 
| 1618 | 
            -
            **  | 
| 1619 | 
            -
            **  | 
| 1669 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_LOOKASIDE option takes two arguments that determine
         | 
| 1670 | 
            +
            ** the default size of lookaside memory on each [database connection].
         | 
| 1671 | 
            +
            ** The first argument is the
         | 
| 1620 1672 | 
             
            ** size of each lookaside buffer slot and the second is the number of
         | 
| 1621 | 
            -
            ** slots allocated to each database connection.)^  ^( | 
| 1622 | 
            -
            ** <i>default</i> lookaside size. The [SQLITE_DBCONFIG_LOOKASIDE]
         | 
| 1623 | 
            -
            **  | 
| 1673 | 
            +
            ** slots allocated to each database connection.)^  ^(SQLITE_CONFIG_LOOKASIDE
         | 
| 1674 | 
            +
            ** sets the <i>default</i> lookaside size. The [SQLITE_DBCONFIG_LOOKASIDE]
         | 
| 1675 | 
            +
            ** option to [sqlite3_db_config()] can be used to change the lookaside
         | 
| 1624 1676 | 
             
            ** configuration on individual connections.)^ </dd>
         | 
| 1625 1677 | 
             
            **
         | 
| 1626 1678 | 
             
            ** [[SQLITE_CONFIG_PCACHE2]] <dt>SQLITE_CONFIG_PCACHE2</dt>
         | 
| 1627 | 
            -
            ** <dd> ^( | 
| 1628 | 
            -
            ** an [sqlite3_pcache_methods2] object.  This object specifies | 
| 1629 | 
            -
            ** to a custom page cache implementation.)^ | 
| 1630 | 
            -
            **  | 
| 1679 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_PCACHE2 option takes a single argument which is 
         | 
| 1680 | 
            +
            ** a pointer to an [sqlite3_pcache_methods2] object.  This object specifies
         | 
| 1681 | 
            +
            ** the interface to a custom page cache implementation.)^
         | 
| 1682 | 
            +
            ** ^SQLite makes a copy of the [sqlite3_pcache_methods2] object.</dd>
         | 
| 1631 1683 | 
             
            **
         | 
| 1632 1684 | 
             
            ** [[SQLITE_CONFIG_GETPCACHE2]] <dt>SQLITE_CONFIG_GETPCACHE2</dt>
         | 
| 1633 | 
            -
            ** <dd> ^( | 
| 1634 | 
            -
            ** [sqlite3_pcache_methods2] object.  SQLite copies of | 
| 1635 | 
            -
            ** page cache implementation into that object.)^ </dd>
         | 
| 1685 | 
            +
            ** <dd> ^(The SQLITE_CONFIG_GETPCACHE2 option takes a single argument which
         | 
| 1686 | 
            +
            ** is a pointer to an [sqlite3_pcache_methods2] object.  SQLite copies of
         | 
| 1687 | 
            +
            ** the current page cache implementation into that object.)^ </dd>
         | 
| 1636 1688 | 
             
            **
         | 
| 1637 1689 | 
             
            ** [[SQLITE_CONFIG_LOG]] <dt>SQLITE_CONFIG_LOG</dt>
         | 
| 1638 1690 | 
             
            ** <dd> The SQLITE_CONFIG_LOG option is used to configure the SQLite
         | 
| @@ -1655,10 +1707,11 @@ struct sqlite3_mem_methods { | |
| 1655 1707 | 
             
            ** function must be threadsafe. </dd>
         | 
| 1656 1708 | 
             
            **
         | 
| 1657 1709 | 
             
            ** [[SQLITE_CONFIG_URI]] <dt>SQLITE_CONFIG_URI
         | 
| 1658 | 
            -
            ** <dd>^( | 
| 1659 | 
            -
            ** URI handling is globally enabled. If the parameter is zero, | 
| 1660 | 
            -
            ** is globally disabled.)^ ^If URI handling is globally | 
| 1661 | 
            -
            ** passed to [sqlite3_open()], [sqlite3_open_v2()], | 
| 1710 | 
            +
            ** <dd>^(The SQLITE_CONFIG_URI option takes a single argument of type int.
         | 
| 1711 | 
            +
            ** If non-zero, then URI handling is globally enabled. If the parameter is zero,
         | 
| 1712 | 
            +
            ** then URI handling is globally disabled.)^ ^If URI handling is globally
         | 
| 1713 | 
            +
            ** enabled, all filenames passed to [sqlite3_open()], [sqlite3_open_v2()],
         | 
| 1714 | 
            +
            ** [sqlite3_open16()] or
         | 
| 1662 1715 | 
             
            ** specified as part of [ATTACH] commands are interpreted as URIs, regardless
         | 
| 1663 1716 | 
             
            ** of whether or not the [SQLITE_OPEN_URI] flag is set when the database
         | 
| 1664 1717 | 
             
            ** connection is opened. ^If it is globally disabled, filenames are
         | 
| @@ -1668,9 +1721,10 @@ struct sqlite3_mem_methods { | |
| 1668 1721 | 
             
            ** [SQLITE_USE_URI] symbol defined.)^
         | 
| 1669 1722 | 
             
            **
         | 
| 1670 1723 | 
             
            ** [[SQLITE_CONFIG_COVERING_INDEX_SCAN]] <dt>SQLITE_CONFIG_COVERING_INDEX_SCAN
         | 
| 1671 | 
            -
            ** <dd>^ | 
| 1672 | 
            -
            ** a boolean in order to enable or disable | 
| 1673 | 
            -
            ** full table scans in the query optimizer. | 
| 1724 | 
            +
            ** <dd>^The SQLITE_CONFIG_COVERING_INDEX_SCAN option takes a single integer
         | 
| 1725 | 
            +
            ** argument which is interpreted as a boolean in order to enable or disable
         | 
| 1726 | 
            +
            ** the use of covering indices for full table scans in the query optimizer.
         | 
| 1727 | 
            +
            ** ^The default setting is determined
         | 
| 1674 1728 | 
             
            ** by the [SQLITE_ALLOW_COVERING_INDEX_SCAN] compile-time option, or is "on"
         | 
| 1675 1729 | 
             
            ** if that compile-time option is omitted.
         | 
| 1676 1730 | 
             
            ** The ability to disable the use of covering indices for full table scans
         | 
| @@ -1710,18 +1764,37 @@ struct sqlite3_mem_methods { | |
| 1710 1764 | 
             
            ** ^The default setting can be overridden by each database connection using
         | 
| 1711 1765 | 
             
            ** either the [PRAGMA mmap_size] command, or by using the
         | 
| 1712 1766 | 
             
            ** [SQLITE_FCNTL_MMAP_SIZE] file control.  ^(The maximum allowed mmap size
         | 
| 1713 | 
            -
            **  | 
| 1714 | 
            -
            **  | 
| 1767 | 
            +
            ** will be silently truncated if necessary so that it does not exceed the
         | 
| 1768 | 
            +
            ** compile-time maximum mmap size set by the
         | 
| 1715 1769 | 
             
            ** [SQLITE_MAX_MMAP_SIZE] compile-time option.)^
         | 
| 1716 1770 | 
             
            ** ^If either argument to this option is negative, then that argument is
         | 
| 1717 1771 | 
             
            ** changed to its compile-time default.
         | 
| 1718 1772 | 
             
            **
         | 
| 1719 1773 | 
             
            ** [[SQLITE_CONFIG_WIN32_HEAPSIZE]]
         | 
| 1720 1774 | 
             
            ** <dt>SQLITE_CONFIG_WIN32_HEAPSIZE
         | 
| 1721 | 
            -
            ** <dd>^ | 
| 1722 | 
            -
            ** with the [SQLITE_WIN32_MALLOC] pre-processor macro | 
| 1723 | 
            -
            ** SQLITE_CONFIG_WIN32_HEAPSIZE takes a 32-bit unsigned integer value
         | 
| 1775 | 
            +
            ** <dd>^The SQLITE_CONFIG_WIN32_HEAPSIZE option is only available if SQLite is
         | 
| 1776 | 
            +
            ** compiled for Windows with the [SQLITE_WIN32_MALLOC] pre-processor macro
         | 
| 1777 | 
            +
            ** defined. ^SQLITE_CONFIG_WIN32_HEAPSIZE takes a 32-bit unsigned integer value
         | 
| 1724 1778 | 
             
            ** that specifies the maximum size of the created heap.
         | 
| 1779 | 
            +
            **
         | 
| 1780 | 
            +
            ** [[SQLITE_CONFIG_PCACHE_HDRSZ]]
         | 
| 1781 | 
            +
            ** <dt>SQLITE_CONFIG_PCACHE_HDRSZ
         | 
| 1782 | 
            +
            ** <dd>^The SQLITE_CONFIG_PCACHE_HDRSZ option takes a single parameter which
         | 
| 1783 | 
            +
            ** is a pointer to an integer and writes into that integer the number of extra
         | 
| 1784 | 
            +
            ** bytes per page required for each page in [SQLITE_CONFIG_PAGECACHE].
         | 
| 1785 | 
            +
            ** The amount of extra space required can change depending on the compiler,
         | 
| 1786 | 
            +
            ** target platform, and SQLite version.
         | 
| 1787 | 
            +
            **
         | 
| 1788 | 
            +
            ** [[SQLITE_CONFIG_PMASZ]]
         | 
| 1789 | 
            +
            ** <dt>SQLITE_CONFIG_PMASZ
         | 
| 1790 | 
            +
            ** <dd>^The SQLITE_CONFIG_PMASZ option takes a single parameter which
         | 
| 1791 | 
            +
            ** is an unsigned integer and sets the "Minimum PMA Size" for the multithreaded
         | 
| 1792 | 
            +
            ** sorter to that integer.  The default minimum PMA Size is set by the
         | 
| 1793 | 
            +
            ** [SQLITE_SORTER_PMASZ] compile-time option.  New threads are launched
         | 
| 1794 | 
            +
            ** to help with sort operations when multithreaded sorting
         | 
| 1795 | 
            +
            ** is enabled (using the [PRAGMA threads] command) and the amount of content
         | 
| 1796 | 
            +
            ** to be sorted exceeds the page size times the minimum of the
         | 
| 1797 | 
            +
            ** [PRAGMA cache_size] setting and this value.
         | 
| 1725 1798 | 
             
            ** </dl>
         | 
| 1726 1799 | 
             
            */
         | 
| 1727 1800 | 
             
            #define SQLITE_CONFIG_SINGLETHREAD  1  /* nil */
         | 
| @@ -1747,6 +1820,8 @@ struct sqlite3_mem_methods { | |
| 1747 1820 | 
             
            #define SQLITE_CONFIG_SQLLOG       21  /* xSqllog, void* */
         | 
| 1748 1821 | 
             
            #define SQLITE_CONFIG_MMAP_SIZE    22  /* sqlite3_int64, sqlite3_int64 */
         | 
| 1749 1822 | 
             
            #define SQLITE_CONFIG_WIN32_HEAPSIZE      23  /* int nByte */
         | 
| 1823 | 
            +
            #define SQLITE_CONFIG_PCACHE_HDRSZ        24  /* int *psz */
         | 
| 1824 | 
            +
            #define SQLITE_CONFIG_PMASZ               25  /* unsigned int szPma */
         | 
| 1750 1825 |  | 
| 1751 1826 | 
             
            /*
         | 
| 1752 1827 | 
             
            ** CAPI3REF: Database Connection Configuration Options
         | 
| @@ -1813,15 +1888,17 @@ struct sqlite3_mem_methods { | |
| 1813 1888 |  | 
| 1814 1889 | 
             
            /*
         | 
| 1815 1890 | 
             
            ** CAPI3REF: Enable Or Disable Extended Result Codes
         | 
| 1891 | 
            +
            ** METHOD: sqlite3
         | 
| 1816 1892 | 
             
            **
         | 
| 1817 1893 | 
             
            ** ^The sqlite3_extended_result_codes() routine enables or disables the
         | 
| 1818 1894 | 
             
            ** [extended result codes] feature of SQLite. ^The extended result
         | 
| 1819 1895 | 
             
            ** codes are disabled by default for historical compatibility.
         | 
| 1820 1896 | 
             
            */
         | 
| 1821 | 
            -
            SQLITE_API int sqlite3_extended_result_codes(sqlite3*, int onoff);
         | 
| 1897 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_extended_result_codes(sqlite3*, int onoff);
         | 
| 1822 1898 |  | 
| 1823 1899 | 
             
            /*
         | 
| 1824 1900 | 
             
            ** CAPI3REF: Last Insert Rowid
         | 
| 1901 | 
            +
            ** METHOD: sqlite3
         | 
| 1825 1902 | 
             
            **
         | 
| 1826 1903 | 
             
            ** ^Each entry in most SQLite tables (except for [WITHOUT ROWID] tables)
         | 
| 1827 1904 | 
             
            ** has a unique 64-bit signed
         | 
| @@ -1869,52 +1946,51 @@ SQLITE_API int sqlite3_extended_result_codes(sqlite3*, int onoff); | |
| 1869 1946 | 
             
            ** unpredictable and might not equal either the old or the new
         | 
| 1870 1947 | 
             
            ** last insert [rowid].
         | 
| 1871 1948 | 
             
            */
         | 
| 1872 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_last_insert_rowid(sqlite3*);
         | 
| 1949 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_last_insert_rowid(sqlite3*);
         | 
| 1873 1950 |  | 
| 1874 1951 | 
             
            /*
         | 
| 1875 1952 | 
             
            ** CAPI3REF: Count The Number Of Rows Modified
         | 
| 1953 | 
            +
            ** METHOD: sqlite3
         | 
| 1876 1954 | 
             
            **
         | 
| 1877 | 
            -
            ** ^This function returns the number of  | 
| 1878 | 
            -
            **  | 
| 1879 | 
            -
            ** on the  | 
| 1880 | 
            -
            ** ^ | 
| 1881 | 
            -
            **  | 
| 1882 | 
            -
            ** | 
| 1883 | 
            -
            **  | 
| 1884 | 
            -
            **  | 
| 1885 | 
            -
            **
         | 
| 1886 | 
            -
            **  | 
| 1887 | 
            -
            **  | 
| 1888 | 
            -
            **
         | 
| 1889 | 
            -
            **  | 
| 1890 | 
            -
            **  | 
| 1891 | 
            -
            ** are  | 
| 1892 | 
            -
            ** | 
| 1893 | 
            -
            **  | 
| 1894 | 
            -
            **
         | 
| 1895 | 
            -
            **  | 
| 1896 | 
            -
            **  | 
| 1897 | 
            -
            **  | 
| 1898 | 
            -
            **  | 
| 1899 | 
            -
            **  | 
| 1900 | 
            -
            **  | 
| 1901 | 
            -
            **  | 
| 1902 | 
            -
            **
         | 
| 1903 | 
            -
            ** ^ | 
| 1904 | 
            -
            **  | 
| 1905 | 
            -
            **
         | 
| 1906 | 
            -
            **  | 
| 1907 | 
            -
            **  | 
| 1908 | 
            -
            **  | 
| 1909 | 
            -
            **
         | 
| 1910 | 
            -
            ** ^ | 
| 1911 | 
            -
            **  | 
| 1912 | 
            -
            **  | 
| 1913 | 
            -
            ** the  | 
| 1914 | 
            -
            **  | 
| 1915 | 
            -
            **  | 
| 1916 | 
            -
            ** However, the number returned does not include changes
         | 
| 1917 | 
            -
            ** caused by subtriggers since those have their own context.)^
         | 
| 1955 | 
            +
            ** ^This function returns the number of rows modified, inserted or
         | 
| 1956 | 
            +
            ** deleted by the most recently completed INSERT, UPDATE or DELETE
         | 
| 1957 | 
            +
            ** statement on the database connection specified by the only parameter.
         | 
| 1958 | 
            +
            ** ^Executing any other type of SQL statement does not modify the value
         | 
| 1959 | 
            +
            ** returned by this function.
         | 
| 1960 | 
            +
            **
         | 
| 1961 | 
            +
            ** ^Only changes made directly by the INSERT, UPDATE or DELETE statement are
         | 
| 1962 | 
            +
            ** considered - auxiliary changes caused by [CREATE TRIGGER | triggers], 
         | 
| 1963 | 
            +
            ** [foreign key actions] or [REPLACE] constraint resolution are not counted.
         | 
| 1964 | 
            +
            ** 
         | 
| 1965 | 
            +
            ** Changes to a view that are intercepted by 
         | 
| 1966 | 
            +
            ** [INSTEAD OF trigger | INSTEAD OF triggers] are not counted. ^The value 
         | 
| 1967 | 
            +
            ** returned by sqlite3_changes() immediately after an INSERT, UPDATE or 
         | 
| 1968 | 
            +
            ** DELETE statement run on a view is always zero. Only changes made to real 
         | 
| 1969 | 
            +
            ** tables are counted.
         | 
| 1970 | 
            +
            **
         | 
| 1971 | 
            +
            ** Things are more complicated if the sqlite3_changes() function is
         | 
| 1972 | 
            +
            ** executed while a trigger program is running. This may happen if the
         | 
| 1973 | 
            +
            ** program uses the [changes() SQL function], or if some other callback
         | 
| 1974 | 
            +
            ** function invokes sqlite3_changes() directly. Essentially:
         | 
| 1975 | 
            +
            ** 
         | 
| 1976 | 
            +
            ** <ul>
         | 
| 1977 | 
            +
            **   <li> ^(Before entering a trigger program the value returned by
         | 
| 1978 | 
            +
            **        sqlite3_changes() function is saved. After the trigger program 
         | 
| 1979 | 
            +
            **        has finished, the original value is restored.)^
         | 
| 1980 | 
            +
            ** 
         | 
| 1981 | 
            +
            **   <li> ^(Within a trigger program each INSERT, UPDATE and DELETE 
         | 
| 1982 | 
            +
            **        statement sets the value returned by sqlite3_changes() 
         | 
| 1983 | 
            +
            **        upon completion as normal. Of course, this value will not include 
         | 
| 1984 | 
            +
            **        any changes performed by sub-triggers, as the sqlite3_changes() 
         | 
| 1985 | 
            +
            **        value will be saved and restored after each sub-trigger has run.)^
         | 
| 1986 | 
            +
            ** </ul>
         | 
| 1987 | 
            +
            ** 
         | 
| 1988 | 
            +
            ** ^This means that if the changes() SQL function (or similar) is used
         | 
| 1989 | 
            +
            ** by the first INSERT, UPDATE or DELETE statement within a trigger, it 
         | 
| 1990 | 
            +
            ** returns the value as set when the calling statement began executing.
         | 
| 1991 | 
            +
            ** ^If it is used by the second or subsequent such statement within a trigger 
         | 
| 1992 | 
            +
            ** program, the value returned reflects the number of rows modified by the 
         | 
| 1993 | 
            +
            ** previous INSERT, UPDATE or DELETE statement within the same trigger.
         | 
| 1918 1994 | 
             
            **
         | 
| 1919 1995 | 
             
            ** See also the [sqlite3_total_changes()] interface, the
         | 
| 1920 1996 | 
             
            ** [count_changes pragma], and the [changes() SQL function].
         | 
| @@ -1923,25 +1999,23 @@ SQLITE_API sqlite3_int64 sqlite3_last_insert_rowid(sqlite3*); | |
| 1923 1999 | 
             
            ** while [sqlite3_changes()] is running then the value returned
         | 
| 1924 2000 | 
             
            ** is unpredictable and not meaningful.
         | 
| 1925 2001 | 
             
            */
         | 
| 1926 | 
            -
            SQLITE_API int sqlite3_changes(sqlite3*);
         | 
| 2002 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_changes(sqlite3*);
         | 
| 1927 2003 |  | 
| 1928 2004 | 
             
            /*
         | 
| 1929 2005 | 
             
            ** CAPI3REF: Total Number Of Rows Modified
         | 
| 2006 | 
            +
            ** METHOD: sqlite3
         | 
| 1930 2007 | 
             
            **
         | 
| 1931 | 
            -
            ** ^This function returns the number of  | 
| 1932 | 
            -
            ** [UPDATE] or [DELETE] statements  | 
| 1933 | 
            -
            **  | 
| 1934 | 
            -
            **  | 
| 1935 | 
            -
            **  | 
| 1936 | 
            -
            **  | 
| 1937 | 
            -
            **  | 
| 1938 | 
            -
            ** count  | 
| 1939 | 
            -
            **  | 
| 1940 | 
            -
            ** are counted. | 
| 1941 | 
            -
            **  | 
| 1942 | 
            -
            ** the statement that makes them is completed (when the statement handle
         | 
| 1943 | 
            -
            ** is passed to [sqlite3_reset()] or [sqlite3_finalize()]).
         | 
| 1944 | 
            -
            **
         | 
| 2008 | 
            +
            ** ^This function returns the total number of rows inserted, modified or
         | 
| 2009 | 
            +
            ** deleted by all [INSERT], [UPDATE] or [DELETE] statements completed
         | 
| 2010 | 
            +
            ** since the database connection was opened, including those executed as
         | 
| 2011 | 
            +
            ** part of trigger programs. ^Executing any other type of SQL statement
         | 
| 2012 | 
            +
            ** does not affect the value returned by sqlite3_total_changes().
         | 
| 2013 | 
            +
            ** 
         | 
| 2014 | 
            +
            ** ^Changes made as part of [foreign key actions] are included in the
         | 
| 2015 | 
            +
            ** count, but those made as part of REPLACE constraint resolution are
         | 
| 2016 | 
            +
            ** not. ^Changes to a view that are intercepted by INSTEAD OF triggers 
         | 
| 2017 | 
            +
            ** are not counted.
         | 
| 2018 | 
            +
            ** 
         | 
| 1945 2019 | 
             
            ** See also the [sqlite3_changes()] interface, the
         | 
| 1946 2020 | 
             
            ** [count_changes pragma], and the [total_changes() SQL function].
         | 
| 1947 2021 | 
             
            **
         | 
| @@ -1949,10 +2023,11 @@ SQLITE_API int sqlite3_changes(sqlite3*); | |
| 1949 2023 | 
             
            ** while [sqlite3_total_changes()] is running then the value
         | 
| 1950 2024 | 
             
            ** returned is unpredictable and not meaningful.
         | 
| 1951 2025 | 
             
            */
         | 
| 1952 | 
            -
            SQLITE_API int sqlite3_total_changes(sqlite3*);
         | 
| 2026 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_total_changes(sqlite3*);
         | 
| 1953 2027 |  | 
| 1954 2028 | 
             
            /*
         | 
| 1955 2029 | 
             
            ** CAPI3REF: Interrupt A Long-Running Query
         | 
| 2030 | 
            +
            ** METHOD: sqlite3
         | 
| 1956 2031 | 
             
            **
         | 
| 1957 2032 | 
             
            ** ^This function causes any pending database operation to abort and
         | 
| 1958 2033 | 
             
            ** return at its earliest opportunity. This routine is typically
         | 
| @@ -1988,7 +2063,7 @@ SQLITE_API int sqlite3_total_changes(sqlite3*); | |
| 1988 2063 | 
             
            ** If the database connection closes while [sqlite3_interrupt()]
         | 
| 1989 2064 | 
             
            ** is running then bad things will likely happen.
         | 
| 1990 2065 | 
             
            */
         | 
| 1991 | 
            -
            SQLITE_API void sqlite3_interrupt(sqlite3*);
         | 
| 2066 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_interrupt(sqlite3*);
         | 
| 1992 2067 |  | 
| 1993 2068 | 
             
            /*
         | 
| 1994 2069 | 
             
            ** CAPI3REF: Determine If An SQL Statement Is Complete
         | 
| @@ -2023,11 +2098,13 @@ SQLITE_API void sqlite3_interrupt(sqlite3*); | |
| 2023 2098 | 
             
            ** The input to [sqlite3_complete16()] must be a zero-terminated
         | 
| 2024 2099 | 
             
            ** UTF-16 string in native byte order.
         | 
| 2025 2100 | 
             
            */
         | 
| 2026 | 
            -
            SQLITE_API int sqlite3_complete(const char *sql);
         | 
| 2027 | 
            -
            SQLITE_API int sqlite3_complete16(const void *sql);
         | 
| 2101 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_complete(const char *sql);
         | 
| 2102 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_complete16(const void *sql);
         | 
| 2028 2103 |  | 
| 2029 2104 | 
             
            /*
         | 
| 2030 2105 | 
             
            ** CAPI3REF: Register A Callback To Handle SQLITE_BUSY Errors
         | 
| 2106 | 
            +
            ** KEYWORDS: {busy-handler callback} {busy handler}
         | 
| 2107 | 
            +
            ** METHOD: sqlite3
         | 
| 2031 2108 | 
             
            **
         | 
| 2032 2109 | 
             
            ** ^The sqlite3_busy_handler(D,X,P) routine sets a callback function X
         | 
| 2033 2110 | 
             
            ** that might be invoked with argument P whenever
         | 
| @@ -2044,7 +2121,7 @@ SQLITE_API int sqlite3_complete16(const void *sql); | |
| 2044 2121 | 
             
            ** ^The first argument to the busy handler is a copy of the void* pointer which
         | 
| 2045 2122 | 
             
            ** is the third argument to sqlite3_busy_handler().  ^The second argument to
         | 
| 2046 2123 | 
             
            ** the busy handler callback is the number of times that the busy handler has
         | 
| 2047 | 
            -
            ** been invoked for the same locking event.  ^If the
         | 
| 2124 | 
            +
            ** been invoked previously for the same locking event.  ^If the
         | 
| 2048 2125 | 
             
            ** busy callback returns 0, then no additional attempts are made to
         | 
| 2049 2126 | 
             
            ** access the database and [SQLITE_BUSY] is returned
         | 
| 2050 2127 | 
             
            ** to the application.
         | 
| @@ -2083,10 +2160,11 @@ SQLITE_API int sqlite3_complete16(const void *sql); | |
| 2083 2160 | 
             
            ** A busy handler must not close the database connection
         | 
| 2084 2161 | 
             
            ** or [prepared statement] that invoked the busy handler.
         | 
| 2085 2162 | 
             
            */
         | 
| 2086 | 
            -
            SQLITE_API int sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*);
         | 
| 2163 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*);
         | 
| 2087 2164 |  | 
| 2088 2165 | 
             
            /*
         | 
| 2089 2166 | 
             
            ** CAPI3REF: Set A Busy Timeout
         | 
| 2167 | 
            +
            ** METHOD: sqlite3
         | 
| 2090 2168 | 
             
            **
         | 
| 2091 2169 | 
             
            ** ^This routine sets a [sqlite3_busy_handler | busy handler] that sleeps
         | 
| 2092 2170 | 
             
            ** for a specified amount of time when a table is locked.  ^The handler
         | 
| @@ -2099,16 +2177,17 @@ SQLITE_API int sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*); | |
| 2099 2177 | 
             
            ** turns off all busy handlers.
         | 
| 2100 2178 | 
             
            **
         | 
| 2101 2179 | 
             
            ** ^(There can only be a single busy handler for a particular
         | 
| 2102 | 
            -
            ** [database connection]  | 
| 2180 | 
            +
            ** [database connection] at any given moment.  If another busy handler
         | 
| 2103 2181 | 
             
            ** was defined  (using [sqlite3_busy_handler()]) prior to calling
         | 
| 2104 2182 | 
             
            ** this routine, that other busy handler is cleared.)^
         | 
| 2105 2183 | 
             
            **
         | 
| 2106 2184 | 
             
            ** See also:  [PRAGMA busy_timeout]
         | 
| 2107 2185 | 
             
            */
         | 
| 2108 | 
            -
            SQLITE_API int sqlite3_busy_timeout(sqlite3*, int ms);
         | 
| 2186 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_busy_timeout(sqlite3*, int ms);
         | 
| 2109 2187 |  | 
| 2110 2188 | 
             
            /*
         | 
| 2111 2189 | 
             
            ** CAPI3REF: Convenience Routines For Running Queries
         | 
| 2190 | 
            +
            ** METHOD: sqlite3
         | 
| 2112 2191 | 
             
            **
         | 
| 2113 2192 | 
             
            ** This is a legacy interface that is preserved for backwards compatibility.
         | 
| 2114 2193 | 
             
            ** Use of this interface is not recommended.
         | 
| @@ -2179,7 +2258,7 @@ SQLITE_API int sqlite3_busy_timeout(sqlite3*, int ms); | |
| 2179 2258 | 
             
            ** reflected in subsequent calls to [sqlite3_errcode()] or
         | 
| 2180 2259 | 
             
            ** [sqlite3_errmsg()].
         | 
| 2181 2260 | 
             
            */
         | 
| 2182 | 
            -
            SQLITE_API int sqlite3_get_table(
         | 
| 2261 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_get_table(
         | 
| 2183 2262 | 
             
              sqlite3 *db,          /* An open database */
         | 
| 2184 2263 | 
             
              const char *zSql,     /* SQL to be evaluated */
         | 
| 2185 2264 | 
             
              char ***pazResult,    /* Results of the query */
         | 
| @@ -2187,13 +2266,17 @@ SQLITE_API int sqlite3_get_table( | |
| 2187 2266 | 
             
              int *pnColumn,        /* Number of result columns written here */
         | 
| 2188 2267 | 
             
              char **pzErrmsg       /* Error msg written here */
         | 
| 2189 2268 | 
             
            );
         | 
| 2190 | 
            -
            SQLITE_API void sqlite3_free_table(char **result);
         | 
| 2269 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_free_table(char **result);
         | 
| 2191 2270 |  | 
| 2192 2271 | 
             
            /*
         | 
| 2193 2272 | 
             
            ** CAPI3REF: Formatted String Printing Functions
         | 
| 2194 2273 | 
             
            **
         | 
| 2195 2274 | 
             
            ** These routines are work-alikes of the "printf()" family of functions
         | 
| 2196 2275 | 
             
            ** from the standard C library.
         | 
| 2276 | 
            +
            ** These routines understand most of the common K&R formatting options,
         | 
| 2277 | 
            +
            ** plus some additional non-standard formats, detailed below.
         | 
| 2278 | 
            +
            ** Note that some of the more obscure formatting options from recent
         | 
| 2279 | 
            +
            ** C-library standards are omitted from this implementation.
         | 
| 2197 2280 | 
             
            **
         | 
| 2198 2281 | 
             
            ** ^The sqlite3_mprintf() and sqlite3_vmprintf() routines write their
         | 
| 2199 2282 | 
             
            ** results into memory obtained from [sqlite3_malloc()].
         | 
| @@ -2226,7 +2309,7 @@ SQLITE_API void sqlite3_free_table(char **result); | |
| 2226 2309 | 
             
            ** These routines all implement some additional formatting
         | 
| 2227 2310 | 
             
            ** options that are useful for constructing SQL statements.
         | 
| 2228 2311 | 
             
            ** All of the usual printf() formatting options apply.  In addition, there
         | 
| 2229 | 
            -
            ** is are "%q", "%Q", and "%z" options.
         | 
| 2312 | 
            +
            ** is are "%q", "%Q", "%w" and "%z" options.
         | 
| 2230 2313 | 
             
            **
         | 
| 2231 2314 | 
             
            ** ^(The %q option works like %s in that it substitutes a nul-terminated
         | 
| 2232 2315 | 
             
            ** string from the argument list.  But %q also doubles every '\'' character.
         | 
| @@ -2279,14 +2362,20 @@ SQLITE_API void sqlite3_free_table(char **result); | |
| 2279 2362 | 
             
            ** The code above will render a correct SQL statement in the zSQL
         | 
| 2280 2363 | 
             
            ** variable even if the zText variable is a NULL pointer.
         | 
| 2281 2364 | 
             
            **
         | 
| 2365 | 
            +
            ** ^(The "%w" formatting option is like "%q" except that it expects to
         | 
| 2366 | 
            +
            ** be contained within double-quotes instead of single quotes, and it
         | 
| 2367 | 
            +
            ** escapes the double-quote character instead of the single-quote
         | 
| 2368 | 
            +
            ** character.)^  The "%w" formatting option is intended for safely inserting
         | 
| 2369 | 
            +
            ** table and column names into a constructed SQL statement.
         | 
| 2370 | 
            +
            **
         | 
| 2282 2371 | 
             
            ** ^(The "%z" formatting option works like "%s" but with the
         | 
| 2283 2372 | 
             
            ** addition that after the string has been read and copied into
         | 
| 2284 2373 | 
             
            ** the result, [sqlite3_free()] is called on the input string.)^
         | 
| 2285 2374 | 
             
            */
         | 
| 2286 | 
            -
            SQLITE_API char *sqlite3_mprintf(const char*,...);
         | 
| 2287 | 
            -
            SQLITE_API char *sqlite3_vmprintf(const char*, va_list);
         | 
| 2288 | 
            -
            SQLITE_API char *sqlite3_snprintf(int,char*,const char*, ...);
         | 
| 2289 | 
            -
            SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list);
         | 
| 2375 | 
            +
            SQLITE_API char *SQLITE_CDECL sqlite3_mprintf(const char*,...);
         | 
| 2376 | 
            +
            SQLITE_API char *SQLITE_STDCALL sqlite3_vmprintf(const char*, va_list);
         | 
| 2377 | 
            +
            SQLITE_API char *SQLITE_CDECL sqlite3_snprintf(int,char*,const char*, ...);
         | 
| 2378 | 
            +
            SQLITE_API char *SQLITE_STDCALL sqlite3_vsnprintf(int,char*,const char*, va_list);
         | 
| 2290 2379 |  | 
| 2291 2380 | 
             
            /*
         | 
| 2292 2381 | 
             
            ** CAPI3REF: Memory Allocation Subsystem
         | 
| @@ -2303,6 +2392,10 @@ SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list); | |
| 2303 2392 | 
             
            ** sqlite3_malloc() is zero or negative then sqlite3_malloc() returns
         | 
| 2304 2393 | 
             
            ** a NULL pointer.
         | 
| 2305 2394 | 
             
            **
         | 
| 2395 | 
            +
            ** ^The sqlite3_malloc64(N) routine works just like
         | 
| 2396 | 
            +
            ** sqlite3_malloc(N) except that N is an unsigned 64-bit integer instead
         | 
| 2397 | 
            +
            ** of a signed 32-bit integer.
         | 
| 2398 | 
            +
            **
         | 
| 2306 2399 | 
             
            ** ^Calling sqlite3_free() with a pointer previously returned
         | 
| 2307 2400 | 
             
            ** by sqlite3_malloc() or sqlite3_realloc() releases that memory so
         | 
| 2308 2401 | 
             
            ** that it might be reused.  ^The sqlite3_free() routine is
         | 
| @@ -2314,24 +2407,38 @@ SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list); | |
| 2314 2407 | 
             
            ** might result if sqlite3_free() is called with a non-NULL pointer that
         | 
| 2315 2408 | 
             
            ** was not obtained from sqlite3_malloc() or sqlite3_realloc().
         | 
| 2316 2409 | 
             
            **
         | 
| 2317 | 
            -
            ** ^ | 
| 2318 | 
            -
            ** prior memory allocation to be at least N bytes | 
| 2319 | 
            -
            **  | 
| 2320 | 
            -
            ** parameter.)^ ^ If the first parameter to sqlite3_realloc()
         | 
| 2410 | 
            +
            ** ^The sqlite3_realloc(X,N) interface attempts to resize a
         | 
| 2411 | 
            +
            ** prior memory allocation X to be at least N bytes.
         | 
| 2412 | 
            +
            ** ^If the X parameter to sqlite3_realloc(X,N)
         | 
| 2321 2413 | 
             
            ** is a NULL pointer then its behavior is identical to calling
         | 
| 2322 | 
            -
            ** sqlite3_malloc(N) | 
| 2323 | 
            -
            ** ^If the  | 
| 2414 | 
            +
            ** sqlite3_malloc(N).
         | 
| 2415 | 
            +
            ** ^If the N parameter to sqlite3_realloc(X,N) is zero or
         | 
| 2324 2416 | 
             
            ** negative then the behavior is exactly the same as calling
         | 
| 2325 | 
            -
            ** sqlite3_free( | 
| 2326 | 
            -
            ** ^sqlite3_realloc() returns a pointer to a memory allocation
         | 
| 2327 | 
            -
            ** of at least N bytes in size or NULL if  | 
| 2417 | 
            +
            ** sqlite3_free(X).
         | 
| 2418 | 
            +
            ** ^sqlite3_realloc(X,N) returns a pointer to a memory allocation
         | 
| 2419 | 
            +
            ** of at least N bytes in size or NULL if insufficient memory is available.
         | 
| 2328 2420 | 
             
            ** ^If M is the size of the prior allocation, then min(N,M) bytes
         | 
| 2329 2421 | 
             
            ** of the prior allocation are copied into the beginning of buffer returned
         | 
| 2330 | 
            -
            ** by sqlite3_realloc() and the prior allocation is freed.
         | 
| 2331 | 
            -
            ** ^If sqlite3_realloc() returns NULL, then the | 
| 2332 | 
            -
            ** is not freed.
         | 
| 2333 | 
            -
            **
         | 
| 2334 | 
            -
            ** ^The  | 
| 2422 | 
            +
            ** by sqlite3_realloc(X,N) and the prior allocation is freed.
         | 
| 2423 | 
            +
            ** ^If sqlite3_realloc(X,N) returns NULL and N is positive, then the
         | 
| 2424 | 
            +
            ** prior allocation is not freed.
         | 
| 2425 | 
            +
            **
         | 
| 2426 | 
            +
            ** ^The sqlite3_realloc64(X,N) interfaces works the same as
         | 
| 2427 | 
            +
            ** sqlite3_realloc(X,N) except that N is a 64-bit unsigned integer instead
         | 
| 2428 | 
            +
            ** of a 32-bit signed integer.
         | 
| 2429 | 
            +
            **
         | 
| 2430 | 
            +
            ** ^If X is a memory allocation previously obtained from sqlite3_malloc(),
         | 
| 2431 | 
            +
            ** sqlite3_malloc64(), sqlite3_realloc(), or sqlite3_realloc64(), then
         | 
| 2432 | 
            +
            ** sqlite3_msize(X) returns the size of that memory allocation in bytes.
         | 
| 2433 | 
            +
            ** ^The value returned by sqlite3_msize(X) might be larger than the number
         | 
| 2434 | 
            +
            ** of bytes requested when X was allocated.  ^If X is a NULL pointer then
         | 
| 2435 | 
            +
            ** sqlite3_msize(X) returns zero.  If X points to something that is not
         | 
| 2436 | 
            +
            ** the beginning of memory allocation, or if it points to a formerly
         | 
| 2437 | 
            +
            ** valid memory allocation that has now been freed, then the behavior
         | 
| 2438 | 
            +
            ** of sqlite3_msize(X) is undefined and possibly harmful.
         | 
| 2439 | 
            +
            **
         | 
| 2440 | 
            +
            ** ^The memory returned by sqlite3_malloc(), sqlite3_realloc(),
         | 
| 2441 | 
            +
            ** sqlite3_malloc64(), and sqlite3_realloc64()
         | 
| 2335 2442 | 
             
            ** is always aligned to at least an 8 byte boundary, or to a
         | 
| 2336 2443 | 
             
            ** 4 byte boundary if the [SQLITE_4_BYTE_ALIGNED_MALLOC] compile-time
         | 
| 2337 2444 | 
             
            ** option is used.
         | 
| @@ -2358,9 +2465,12 @@ SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list); | |
| 2358 2465 | 
             
            ** a block of memory after it has been released using
         | 
| 2359 2466 | 
             
            ** [sqlite3_free()] or [sqlite3_realloc()].
         | 
| 2360 2467 | 
             
            */
         | 
| 2361 | 
            -
            SQLITE_API void *sqlite3_malloc(int);
         | 
| 2362 | 
            -
            SQLITE_API void * | 
| 2363 | 
            -
            SQLITE_API void  | 
| 2468 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_malloc(int);
         | 
| 2469 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_malloc64(sqlite3_uint64);
         | 
| 2470 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_realloc(void*, int);
         | 
| 2471 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_realloc64(void*, sqlite3_uint64);
         | 
| 2472 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_free(void*);
         | 
| 2473 | 
            +
            SQLITE_API sqlite3_uint64 SQLITE_STDCALL sqlite3_msize(void*);
         | 
| 2364 2474 |  | 
| 2365 2475 | 
             
            /*
         | 
| 2366 2476 | 
             
            ** CAPI3REF: Memory Allocator Statistics
         | 
| @@ -2385,8 +2495,8 @@ SQLITE_API void sqlite3_free(void*); | |
| 2385 2495 | 
             
            ** by [sqlite3_memory_highwater(1)] is the high-water mark
         | 
| 2386 2496 | 
             
            ** prior to the reset.
         | 
| 2387 2497 | 
             
            */
         | 
| 2388 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_memory_used(void);
         | 
| 2389 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_memory_highwater(int resetFlag);
         | 
| 2498 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_memory_used(void);
         | 
| 2499 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_memory_highwater(int resetFlag);
         | 
| 2390 2500 |  | 
| 2391 2501 | 
             
            /*
         | 
| 2392 2502 | 
             
            ** CAPI3REF: Pseudo-Random Number Generator
         | 
| @@ -2398,20 +2508,22 @@ SQLITE_API sqlite3_int64 sqlite3_memory_highwater(int resetFlag); | |
| 2398 2508 | 
             
            ** applications to access the same PRNG for other purposes.
         | 
| 2399 2509 | 
             
            **
         | 
| 2400 2510 | 
             
            ** ^A call to this routine stores N bytes of randomness into buffer P.
         | 
| 2401 | 
            -
            ** ^ | 
| 2511 | 
            +
            ** ^The P parameter can be a NULL pointer.
         | 
| 2402 2512 | 
             
            **
         | 
| 2403 2513 | 
             
            ** ^If this routine has not been previously called or if the previous
         | 
| 2404 | 
            -
            ** call had N less than one, then the PRNG is | 
| 2405 | 
            -
            ** obtained from the xRandomness method of | 
| 2406 | 
            -
            **  | 
| 2407 | 
            -
            ** the  | 
| 2514 | 
            +
            ** call had N less than one or a NULL pointer for P, then the PRNG is
         | 
| 2515 | 
            +
            ** seeded using randomness obtained from the xRandomness method of
         | 
| 2516 | 
            +
            ** the default [sqlite3_vfs] object.
         | 
| 2517 | 
            +
            ** ^If the previous call to this routine had an N of 1 or more and a
         | 
| 2518 | 
            +
            ** non-NULL P then the pseudo-randomness is generated
         | 
| 2408 2519 | 
             
            ** internally and without recourse to the [sqlite3_vfs] xRandomness
         | 
| 2409 2520 | 
             
            ** method.
         | 
| 2410 2521 | 
             
            */
         | 
| 2411 | 
            -
            SQLITE_API void sqlite3_randomness(int N, void *P);
         | 
| 2522 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_randomness(int N, void *P);
         | 
| 2412 2523 |  | 
| 2413 2524 | 
             
            /*
         | 
| 2414 2525 | 
             
            ** CAPI3REF: Compile-Time Authorization Callbacks
         | 
| 2526 | 
            +
            ** METHOD: sqlite3
         | 
| 2415 2527 | 
             
            **
         | 
| 2416 2528 | 
             
            ** ^This routine registers an authorizer callback with a particular
         | 
| 2417 2529 | 
             
            ** [database connection], supplied in the first argument.
         | 
| @@ -2490,7 +2602,7 @@ SQLITE_API void sqlite3_randomness(int N, void *P); | |
| 2490 2602 | 
             
            ** as stated in the previous paragraph, sqlite3_step() invokes
         | 
| 2491 2603 | 
             
            ** sqlite3_prepare_v2() to reprepare a statement after a schema change.
         | 
| 2492 2604 | 
             
            */
         | 
| 2493 | 
            -
            SQLITE_API int sqlite3_set_authorizer(
         | 
| 2605 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_set_authorizer(
         | 
| 2494 2606 | 
             
              sqlite3*,
         | 
| 2495 2607 | 
             
              int (*xAuth)(void*,int,const char*,const char*,const char*,const char*),
         | 
| 2496 2608 | 
             
              void *pUserData
         | 
| @@ -2568,6 +2680,7 @@ SQLITE_API int sqlite3_set_authorizer( | |
| 2568 2680 |  | 
| 2569 2681 | 
             
            /*
         | 
| 2570 2682 | 
             
            ** CAPI3REF: Tracing And Profiling Functions
         | 
| 2683 | 
            +
            ** METHOD: sqlite3
         | 
| 2571 2684 | 
             
            **
         | 
| 2572 2685 | 
             
            ** These routines register callback functions that can be used for
         | 
| 2573 2686 | 
             
            ** tracing and profiling the execution of SQL statements.
         | 
| @@ -2594,12 +2707,13 @@ SQLITE_API int sqlite3_set_authorizer( | |
| 2594 2707 | 
             
            ** sqlite3_profile() function is considered experimental and is
         | 
| 2595 2708 | 
             
            ** subject to change in future versions of SQLite.
         | 
| 2596 2709 | 
             
            */
         | 
| 2597 | 
            -
            SQLITE_API void *sqlite3_trace(sqlite3*, void(*xTrace)(void*,const char*), void*);
         | 
| 2598 | 
            -
            SQLITE_API SQLITE_EXPERIMENTAL void *sqlite3_profile(sqlite3*,
         | 
| 2710 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_trace(sqlite3*, void(*xTrace)(void*,const char*), void*);
         | 
| 2711 | 
            +
            SQLITE_API SQLITE_EXPERIMENTAL void *SQLITE_STDCALL sqlite3_profile(sqlite3*,
         | 
| 2599 2712 | 
             
               void(*xProfile)(void*,const char*,sqlite3_uint64), void*);
         | 
| 2600 2713 |  | 
| 2601 2714 | 
             
            /*
         | 
| 2602 2715 | 
             
            ** CAPI3REF: Query Progress Callbacks
         | 
| 2716 | 
            +
            ** METHOD: sqlite3
         | 
| 2603 2717 | 
             
            **
         | 
| 2604 2718 | 
             
            ** ^The sqlite3_progress_handler(D,N,X,P) interface causes the callback
         | 
| 2605 2719 | 
             
            ** function X to be invoked periodically during long running calls to
         | 
| @@ -2629,10 +2743,11 @@ SQLITE_API SQLITE_EXPERIMENTAL void *sqlite3_profile(sqlite3*, | |
| 2629 2743 | 
             
            ** database connections for the meaning of "modify" in this paragraph.
         | 
| 2630 2744 | 
             
            **
         | 
| 2631 2745 | 
             
            */
         | 
| 2632 | 
            -
            SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*);
         | 
| 2746 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*);
         | 
| 2633 2747 |  | 
| 2634 2748 | 
             
            /*
         | 
| 2635 2749 | 
             
            ** CAPI3REF: Opening A New Database Connection
         | 
| 2750 | 
            +
            ** CONSTRUCTOR: sqlite3
         | 
| 2636 2751 | 
             
            **
         | 
| 2637 2752 | 
             
            ** ^These routines open an SQLite database file as specified by the 
         | 
| 2638 2753 | 
             
            ** filename argument. ^The filename argument is interpreted as UTF-8 for
         | 
| @@ -2647,9 +2762,9 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*); | |
| 2647 2762 | 
             
            ** an English language description of the error following a failure of any
         | 
| 2648 2763 | 
             
            ** of the sqlite3_open() routines.
         | 
| 2649 2764 | 
             
            **
         | 
| 2650 | 
            -
            ** ^The default encoding  | 
| 2651 | 
            -
            ** sqlite3_open() or sqlite3_open_v2()  | 
| 2652 | 
            -
            ** UTF-16 in the native byte order | 
| 2765 | 
            +
            ** ^The default encoding will be UTF-8 for databases created using
         | 
| 2766 | 
            +
            ** sqlite3_open() or sqlite3_open_v2().  ^The default encoding for databases
         | 
| 2767 | 
            +
            ** created using sqlite3_open16() will be UTF-16 in the native byte order.
         | 
| 2653 2768 | 
             
            **
         | 
| 2654 2769 | 
             
            ** Whether or not an error occurs when it is opened, resources
         | 
| 2655 2770 | 
             
            ** associated with the [database connection] handle should be released by
         | 
| @@ -2737,13 +2852,14 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*); | |
| 2737 2852 | 
             
            ** then it is interpreted as an absolute path. ^If the path does not begin 
         | 
| 2738 2853 | 
             
            ** with a '/' (meaning that the authority section is omitted from the URI)
         | 
| 2739 2854 | 
             
            ** then the path is interpreted as a relative path. 
         | 
| 2740 | 
            -
            ** ^On windows, the first component of an absolute path 
         | 
| 2741 | 
            -
            ** is a drive specification (e.g. "C:").
         | 
| 2855 | 
            +
            ** ^(On windows, the first component of an absolute path 
         | 
| 2856 | 
            +
            ** is a drive specification (e.g. "C:").)^
         | 
| 2742 2857 | 
             
            **
         | 
| 2743 2858 | 
             
            ** [[core URI query parameters]]
         | 
| 2744 2859 | 
             
            ** The query component of a URI may contain parameters that are interpreted
         | 
| 2745 2860 | 
             
            ** either by SQLite itself, or by a [VFS | custom VFS implementation].
         | 
| 2746 | 
            -
            ** SQLite  | 
| 2861 | 
            +
            ** SQLite and its built-in [VFSes] interpret the
         | 
| 2862 | 
            +
            ** following query parameters:
         | 
| 2747 2863 | 
             
            **
         | 
| 2748 2864 | 
             
            ** <ul>
         | 
| 2749 2865 | 
             
            **   <li> <b>vfs</b>: ^The "vfs" parameter may be used to specify the name of
         | 
| @@ -2778,11 +2894,9 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*); | |
| 2778 2894 | 
             
            **     a URI filename, its value overrides any behavior requested by setting
         | 
| 2779 2895 | 
             
            **     SQLITE_OPEN_PRIVATECACHE or SQLITE_OPEN_SHAREDCACHE flag.
         | 
| 2780 2896 | 
             
            **
         | 
| 2781 | 
            -
            **  <li> <b>psow</b>: ^The psow parameter  | 
| 2782 | 
            -
            **     "1") or "false" (or "off" or "no" or "0") to indicate that the
         | 
| 2897 | 
            +
            **  <li> <b>psow</b>: ^The psow parameter indicates whether or not the
         | 
| 2783 2898 | 
             
            **     [powersafe overwrite] property does or does not apply to the
         | 
| 2784 | 
            -
            **     storage media on which the database file resides. | 
| 2785 | 
            -
            **     parameter only works for the built-in unix and Windows VFSes.
         | 
| 2899 | 
            +
            **     storage media on which the database file resides.
         | 
| 2786 2900 | 
             
            **
         | 
| 2787 2901 | 
             
            **  <li> <b>nolock</b>: ^The nolock parameter is a boolean query parameter
         | 
| 2788 2902 | 
             
            **     which if set disables file locking in rollback journal modes.  This
         | 
| @@ -2858,15 +2972,15 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*); | |
| 2858 2972 | 
             
            **
         | 
| 2859 2973 | 
             
            ** See also: [sqlite3_temp_directory]
         | 
| 2860 2974 | 
             
            */
         | 
| 2861 | 
            -
            SQLITE_API int sqlite3_open(
         | 
| 2975 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_open(
         | 
| 2862 2976 | 
             
              const char *filename,   /* Database filename (UTF-8) */
         | 
| 2863 2977 | 
             
              sqlite3 **ppDb          /* OUT: SQLite db handle */
         | 
| 2864 2978 | 
             
            );
         | 
| 2865 | 
            -
            SQLITE_API int sqlite3_open16(
         | 
| 2979 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_open16(
         | 
| 2866 2980 | 
             
              const void *filename,   /* Database filename (UTF-16) */
         | 
| 2867 2981 | 
             
              sqlite3 **ppDb          /* OUT: SQLite db handle */
         | 
| 2868 2982 | 
             
            );
         | 
| 2869 | 
            -
            SQLITE_API int sqlite3_open_v2(
         | 
| 2983 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_open_v2(
         | 
| 2870 2984 | 
             
              const char *filename,   /* Database filename (UTF-8) */
         | 
| 2871 2985 | 
             
              sqlite3 **ppDb,         /* OUT: SQLite db handle */
         | 
| 2872 2986 | 
             
              int flags,              /* Flags */
         | 
| @@ -2912,19 +3026,22 @@ SQLITE_API int sqlite3_open_v2( | |
| 2912 3026 | 
             
            ** VFS method, then the behavior of this routine is undefined and probably
         | 
| 2913 3027 | 
             
            ** undesirable.
         | 
| 2914 3028 | 
             
            */
         | 
| 2915 | 
            -
            SQLITE_API const char *sqlite3_uri_parameter(const char *zFilename, const char *zParam);
         | 
| 2916 | 
            -
            SQLITE_API int sqlite3_uri_boolean(const char *zFile, const char *zParam, int bDefault);
         | 
| 2917 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_uri_int64(const char*, const char*, sqlite3_int64);
         | 
| 3029 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_uri_parameter(const char *zFilename, const char *zParam);
         | 
| 3030 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_uri_boolean(const char *zFile, const char *zParam, int bDefault);
         | 
| 3031 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_uri_int64(const char*, const char*, sqlite3_int64);
         | 
| 2918 3032 |  | 
| 2919 3033 |  | 
| 2920 3034 | 
             
            /*
         | 
| 2921 3035 | 
             
            ** CAPI3REF: Error Codes And Messages
         | 
| 2922 | 
            -
            **
         | 
| 2923 | 
            -
            ** | 
| 2924 | 
            -
            **  | 
| 2925 | 
            -
            **  | 
| 2926 | 
            -
            **  | 
| 2927 | 
            -
            **  | 
| 3036 | 
            +
            ** METHOD: sqlite3
         | 
| 3037 | 
            +
            **
         | 
| 3038 | 
            +
            ** ^If the most recent sqlite3_* API call associated with 
         | 
| 3039 | 
            +
            ** [database connection] D failed, then the sqlite3_errcode(D) interface
         | 
| 3040 | 
            +
            ** returns the numeric [result code] or [extended result code] for that
         | 
| 3041 | 
            +
            ** API call.
         | 
| 3042 | 
            +
            ** If the most recent API call was successful,
         | 
| 3043 | 
            +
            ** then the return value from sqlite3_errcode() is undefined.
         | 
| 3044 | 
            +
            ** ^The sqlite3_extended_errcode()
         | 
| 2928 3045 | 
             
            ** interface is the same except that it always returns the 
         | 
| 2929 3046 | 
             
            ** [extended result code] even when extended result codes are
         | 
| 2930 3047 | 
             
            ** disabled.
         | 
| @@ -2955,40 +3072,41 @@ SQLITE_API sqlite3_int64 sqlite3_uri_int64(const char*, const char*, sqlite3_int | |
| 2955 3072 | 
             
            ** was invoked incorrectly by the application.  In that case, the
         | 
| 2956 3073 | 
             
            ** error code and message may or may not be set.
         | 
| 2957 3074 | 
             
            */
         | 
| 2958 | 
            -
            SQLITE_API int sqlite3_errcode(sqlite3 *db);
         | 
| 2959 | 
            -
            SQLITE_API int sqlite3_extended_errcode(sqlite3 *db);
         | 
| 2960 | 
            -
            SQLITE_API const char *sqlite3_errmsg(sqlite3*);
         | 
| 2961 | 
            -
            SQLITE_API const void *sqlite3_errmsg16(sqlite3*);
         | 
| 2962 | 
            -
            SQLITE_API const char *sqlite3_errstr(int);
         | 
| 3075 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_errcode(sqlite3 *db);
         | 
| 3076 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_extended_errcode(sqlite3 *db);
         | 
| 3077 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_errmsg(sqlite3*);
         | 
| 3078 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_errmsg16(sqlite3*);
         | 
| 3079 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_errstr(int);
         | 
| 2963 3080 |  | 
| 2964 3081 | 
             
            /*
         | 
| 2965 | 
            -
            ** CAPI3REF:  | 
| 3082 | 
            +
            ** CAPI3REF: Prepared Statement Object
         | 
| 2966 3083 | 
             
            ** KEYWORDS: {prepared statement} {prepared statements}
         | 
| 2967 3084 | 
             
            **
         | 
| 2968 | 
            -
            ** An instance of this object represents a single SQL statement | 
| 2969 | 
            -
            **  | 
| 2970 | 
            -
            ** | 
| 3085 | 
            +
            ** An instance of this object represents a single SQL statement that
         | 
| 3086 | 
            +
            ** has been compiled into binary form and is ready to be evaluated.
         | 
| 3087 | 
            +
            **
         | 
| 3088 | 
            +
            ** Think of each SQL statement as a separate computer program.  The
         | 
| 3089 | 
            +
            ** original SQL text is source code.  A prepared statement object 
         | 
| 3090 | 
            +
            ** is the compiled object code.  All SQL must be converted into a
         | 
| 3091 | 
            +
            ** prepared statement before it can be run.
         | 
| 2971 3092 | 
             
            **
         | 
| 2972 | 
            -
            ** The life of a statement object goes  | 
| 3093 | 
            +
            ** The life-cycle of a prepared statement object usually goes like this:
         | 
| 2973 3094 | 
             
            **
         | 
| 2974 3095 | 
             
            ** <ol>
         | 
| 2975 | 
            -
            ** <li> Create the object using [sqlite3_prepare_v2()] | 
| 2976 | 
            -
            ** | 
| 2977 | 
            -
            ** <li> Bind values to [host parameters] using the sqlite3_bind_*()
         | 
| 3096 | 
            +
            ** <li> Create the prepared statement object using [sqlite3_prepare_v2()].
         | 
| 3097 | 
            +
            ** <li> Bind values to [parameters] using the sqlite3_bind_*()
         | 
| 2978 3098 | 
             
            **      interfaces.
         | 
| 2979 3099 | 
             
            ** <li> Run the SQL by calling [sqlite3_step()] one or more times.
         | 
| 2980 | 
            -
            ** <li> Reset the statement using [sqlite3_reset()] then go back
         | 
| 3100 | 
            +
            ** <li> Reset the prepared statement using [sqlite3_reset()] then go back
         | 
| 2981 3101 | 
             
            **      to step 2.  Do this zero or more times.
         | 
| 2982 3102 | 
             
            ** <li> Destroy the object using [sqlite3_finalize()].
         | 
| 2983 3103 | 
             
            ** </ol>
         | 
| 2984 | 
            -
            **
         | 
| 2985 | 
            -
            ** Refer to documentation on individual methods above for additional
         | 
| 2986 | 
            -
            ** information.
         | 
| 2987 3104 | 
             
            */
         | 
| 2988 3105 | 
             
            typedef struct sqlite3_stmt sqlite3_stmt;
         | 
| 2989 3106 |  | 
| 2990 3107 | 
             
            /*
         | 
| 2991 3108 | 
             
            ** CAPI3REF: Run-time Limits
         | 
| 3109 | 
            +
            ** METHOD: sqlite3
         | 
| 2992 3110 | 
             
            **
         | 
| 2993 3111 | 
             
            ** ^(This interface allows the size of various constructs to be limited
         | 
| 2994 3112 | 
             
            ** on a connection by connection basis.  The first parameter is the
         | 
| @@ -3026,7 +3144,7 @@ typedef struct sqlite3_stmt sqlite3_stmt; | |
| 3026 3144 | 
             
            **
         | 
| 3027 3145 | 
             
            ** New run-time limit categories may be added in future releases.
         | 
| 3028 3146 | 
             
            */
         | 
| 3029 | 
            -
            SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal);
         | 
| 3147 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_limit(sqlite3*, int id, int newVal);
         | 
| 3030 3148 |  | 
| 3031 3149 | 
             
            /*
         | 
| 3032 3150 | 
             
            ** CAPI3REF: Run-Time Limit Categories
         | 
| @@ -3078,6 +3196,10 @@ SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal); | |
| 3078 3196 | 
             
            **
         | 
| 3079 3197 | 
             
            ** [[SQLITE_LIMIT_TRIGGER_DEPTH]] ^(<dt>SQLITE_LIMIT_TRIGGER_DEPTH</dt>
         | 
| 3080 3198 | 
             
            ** <dd>The maximum depth of recursion for triggers.</dd>)^
         | 
| 3199 | 
            +
            **
         | 
| 3200 | 
            +
            ** [[SQLITE_LIMIT_WORKER_THREADS]] ^(<dt>SQLITE_LIMIT_WORKER_THREADS</dt>
         | 
| 3201 | 
            +
            ** <dd>The maximum number of auxiliary worker threads that a single
         | 
| 3202 | 
            +
            ** [prepared statement] may start.</dd>)^
         | 
| 3081 3203 | 
             
            ** </dl>
         | 
| 3082 3204 | 
             
            */
         | 
| 3083 3205 | 
             
            #define SQLITE_LIMIT_LENGTH                    0
         | 
| @@ -3091,10 +3213,13 @@ SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal); | |
| 3091 3213 | 
             
            #define SQLITE_LIMIT_LIKE_PATTERN_LENGTH       8
         | 
| 3092 3214 | 
             
            #define SQLITE_LIMIT_VARIABLE_NUMBER           9
         | 
| 3093 3215 | 
             
            #define SQLITE_LIMIT_TRIGGER_DEPTH            10
         | 
| 3216 | 
            +
            #define SQLITE_LIMIT_WORKER_THREADS           11
         | 
| 3094 3217 |  | 
| 3095 3218 | 
             
            /*
         | 
| 3096 3219 | 
             
            ** CAPI3REF: Compiling An SQL Statement
         | 
| 3097 3220 | 
             
            ** KEYWORDS: {SQL statement compiler}
         | 
| 3221 | 
            +
            ** METHOD: sqlite3
         | 
| 3222 | 
            +
            ** CONSTRUCTOR: sqlite3_stmt
         | 
| 3098 3223 | 
             
            **
         | 
| 3099 3224 | 
             
            ** To execute an SQL query, it must first be compiled into a byte-code
         | 
| 3100 3225 | 
             
            ** program using one of these routines.
         | 
| @@ -3108,16 +3233,14 @@ SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal); | |
| 3108 3233 | 
             
            ** interfaces use UTF-8, and sqlite3_prepare16() and sqlite3_prepare16_v2()
         | 
| 3109 3234 | 
             
            ** use UTF-16.
         | 
| 3110 3235 | 
             
            **
         | 
| 3111 | 
            -
            ** ^If the nByte argument is  | 
| 3112 | 
            -
            ** first zero terminator. ^If nByte is  | 
| 3113 | 
            -
            ** number of | 
| 3114 | 
            -
            **  | 
| 3115 | 
            -
            ** the  | 
| 3116 | 
            -
            **  | 
| 3117 | 
            -
            **  | 
| 3118 | 
            -
            **  | 
| 3119 | 
            -
            ** the nul-terminator bytes as this saves SQLite from having to
         | 
| 3120 | 
            -
            ** make a copy of the input string.
         | 
| 3236 | 
            +
            ** ^If the nByte argument is negative, then zSql is read up to the
         | 
| 3237 | 
            +
            ** first zero terminator. ^If nByte is positive, then it is the
         | 
| 3238 | 
            +
            ** number of bytes read from zSql.  ^If nByte is zero, then no prepared
         | 
| 3239 | 
            +
            ** statement is generated.
         | 
| 3240 | 
            +
            ** If the caller knows that the supplied string is nul-terminated, then
         | 
| 3241 | 
            +
            ** there is a small performance advantage to passing an nByte parameter that
         | 
| 3242 | 
            +
            ** is the number of bytes in the input string <i>including</i>
         | 
| 3243 | 
            +
            ** the nul-terminator.
         | 
| 3121 3244 | 
             
            **
         | 
| 3122 3245 | 
             
            ** ^If pzTail is not NULL then *pzTail is made to point to the first byte
         | 
| 3123 3246 | 
             
            ** past the end of the first SQL statement in zSql.  These routines only
         | 
| @@ -3173,28 +3296,28 @@ SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal); | |
| 3173 3296 | 
             
            ** </li>
         | 
| 3174 3297 | 
             
            ** </ol>
         | 
| 3175 3298 | 
             
            */
         | 
| 3176 | 
            -
            SQLITE_API int sqlite3_prepare(
         | 
| 3299 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_prepare(
         | 
| 3177 3300 | 
             
              sqlite3 *db,            /* Database handle */
         | 
| 3178 3301 | 
             
              const char *zSql,       /* SQL statement, UTF-8 encoded */
         | 
| 3179 3302 | 
             
              int nByte,              /* Maximum length of zSql in bytes. */
         | 
| 3180 3303 | 
             
              sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
         | 
| 3181 3304 | 
             
              const char **pzTail     /* OUT: Pointer to unused portion of zSql */
         | 
| 3182 3305 | 
             
            );
         | 
| 3183 | 
            -
            SQLITE_API int sqlite3_prepare_v2(
         | 
| 3306 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_prepare_v2(
         | 
| 3184 3307 | 
             
              sqlite3 *db,            /* Database handle */
         | 
| 3185 3308 | 
             
              const char *zSql,       /* SQL statement, UTF-8 encoded */
         | 
| 3186 3309 | 
             
              int nByte,              /* Maximum length of zSql in bytes. */
         | 
| 3187 3310 | 
             
              sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
         | 
| 3188 3311 | 
             
              const char **pzTail     /* OUT: Pointer to unused portion of zSql */
         | 
| 3189 3312 | 
             
            );
         | 
| 3190 | 
            -
            SQLITE_API int sqlite3_prepare16(
         | 
| 3313 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_prepare16(
         | 
| 3191 3314 | 
             
              sqlite3 *db,            /* Database handle */
         | 
| 3192 3315 | 
             
              const void *zSql,       /* SQL statement, UTF-16 encoded */
         | 
| 3193 3316 | 
             
              int nByte,              /* Maximum length of zSql in bytes. */
         | 
| 3194 3317 | 
             
              sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
         | 
| 3195 3318 | 
             
              const void **pzTail     /* OUT: Pointer to unused portion of zSql */
         | 
| 3196 3319 | 
             
            );
         | 
| 3197 | 
            -
            SQLITE_API int sqlite3_prepare16_v2(
         | 
| 3320 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_prepare16_v2(
         | 
| 3198 3321 | 
             
              sqlite3 *db,            /* Database handle */
         | 
| 3199 3322 | 
             
              const void *zSql,       /* SQL statement, UTF-16 encoded */
         | 
| 3200 3323 | 
             
              int nByte,              /* Maximum length of zSql in bytes. */
         | 
| @@ -3204,15 +3327,17 @@ SQLITE_API int sqlite3_prepare16_v2( | |
| 3204 3327 |  | 
| 3205 3328 | 
             
            /*
         | 
| 3206 3329 | 
             
            ** CAPI3REF: Retrieving Statement SQL
         | 
| 3330 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3207 3331 | 
             
            **
         | 
| 3208 3332 | 
             
            ** ^This interface can be used to retrieve a saved copy of the original
         | 
| 3209 3333 | 
             
            ** SQL text used to create a [prepared statement] if that statement was
         | 
| 3210 3334 | 
             
            ** compiled using either [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()].
         | 
| 3211 3335 | 
             
            */
         | 
| 3212 | 
            -
            SQLITE_API const char *sqlite3_sql(sqlite3_stmt *pStmt);
         | 
| 3336 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_sql(sqlite3_stmt *pStmt);
         | 
| 3213 3337 |  | 
| 3214 3338 | 
             
            /*
         | 
| 3215 3339 | 
             
            ** CAPI3REF: Determine If An SQL Statement Writes The Database
         | 
| 3340 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3216 3341 | 
             
            **
         | 
| 3217 3342 | 
             
            ** ^The sqlite3_stmt_readonly(X) interface returns true (non-zero) if
         | 
| 3218 3343 | 
             
            ** and only if the [prepared statement] X makes no direct changes to
         | 
| @@ -3240,10 +3365,11 @@ SQLITE_API const char *sqlite3_sql(sqlite3_stmt *pStmt); | |
| 3240 3365 | 
             
            ** change the configuration of a database connection, they do not make 
         | 
| 3241 3366 | 
             
            ** changes to the content of the database files on disk.
         | 
| 3242 3367 | 
             
            */
         | 
| 3243 | 
            -
            SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
         | 
| 3368 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
         | 
| 3244 3369 |  | 
| 3245 3370 | 
             
            /*
         | 
| 3246 3371 | 
             
            ** CAPI3REF: Determine If A Prepared Statement Has Been Reset
         | 
| 3372 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3247 3373 | 
             
            **
         | 
| 3248 3374 | 
             
            ** ^The sqlite3_stmt_busy(S) interface returns true (non-zero) if the
         | 
| 3249 3375 | 
             
            ** [prepared statement] S has been stepped at least once using 
         | 
| @@ -3259,7 +3385,7 @@ SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt); | |
| 3259 3385 | 
             
            ** for example, in diagnostic routines to search for prepared 
         | 
| 3260 3386 | 
             
            ** statements that are holding a transaction open.
         | 
| 3261 3387 | 
             
            */
         | 
| 3262 | 
            -
            SQLITE_API int sqlite3_stmt_busy(sqlite3_stmt*);
         | 
| 3388 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_stmt_busy(sqlite3_stmt*);
         | 
| 3263 3389 |  | 
| 3264 3390 | 
             
            /*
         | 
| 3265 3391 | 
             
            ** CAPI3REF: Dynamically Typed Value Object
         | 
| @@ -3274,7 +3400,9 @@ SQLITE_API int sqlite3_stmt_busy(sqlite3_stmt*); | |
| 3274 3400 | 
             
            ** Some interfaces require a protected sqlite3_value.  Other interfaces
         | 
| 3275 3401 | 
             
            ** will accept either a protected or an unprotected sqlite3_value.
         | 
| 3276 3402 | 
             
            ** Every interface that accepts sqlite3_value arguments specifies
         | 
| 3277 | 
            -
            ** whether or not it requires a protected sqlite3_value.
         | 
| 3403 | 
            +
            ** whether or not it requires a protected sqlite3_value.  The
         | 
| 3404 | 
            +
            ** [sqlite3_value_dup()] interface can be used to construct a new 
         | 
| 3405 | 
            +
            ** protected sqlite3_value from an unprotected sqlite3_value.
         | 
| 3278 3406 | 
             
            **
         | 
| 3279 3407 | 
             
            ** The terms "protected" and "unprotected" refer to whether or not
         | 
| 3280 3408 | 
             
            ** a mutex is held.  An internal mutex is held for a protected
         | 
| @@ -3318,6 +3446,7 @@ typedef struct sqlite3_context sqlite3_context; | |
| 3318 3446 | 
             
            ** CAPI3REF: Binding Values To Prepared Statements
         | 
| 3319 3447 | 
             
            ** KEYWORDS: {host parameter} {host parameters} {host parameter name}
         | 
| 3320 3448 | 
             
            ** KEYWORDS: {SQL parameter} {SQL parameters} {parameter binding}
         | 
| 3449 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3321 3450 | 
             
            **
         | 
| 3322 3451 | 
             
            ** ^(In the SQL statement text input to [sqlite3_prepare_v2()] and its variants,
         | 
| 3323 3452 | 
             
            ** literals may be replaced by a [parameter] that matches one of following
         | 
| @@ -3364,18 +3493,18 @@ typedef struct sqlite3_context sqlite3_context; | |
| 3364 3493 | 
             
            ** If the fourth parameter to sqlite3_bind_blob() is negative, then
         | 
| 3365 3494 | 
             
            ** the behavior is undefined.
         | 
| 3366 3495 | 
             
            ** If a non-negative fourth parameter is provided to sqlite3_bind_text()
         | 
| 3367 | 
            -
            ** or sqlite3_bind_text16()  | 
| 3496 | 
            +
            ** or sqlite3_bind_text16() or sqlite3_bind_text64() then
         | 
| 3497 | 
            +
            ** that parameter must be the byte offset
         | 
| 3368 3498 | 
             
            ** where the NUL terminator would occur assuming the string were NUL
         | 
| 3369 3499 | 
             
            ** terminated.  If any NUL characters occur at byte offsets less than 
         | 
| 3370 3500 | 
             
            ** the value of the fourth parameter then the resulting string value will
         | 
| 3371 3501 | 
             
            ** contain embedded NULs.  The result of expressions involving strings
         | 
| 3372 3502 | 
             
            ** with embedded NULs is undefined.
         | 
| 3373 3503 | 
             
            **
         | 
| 3374 | 
            -
            ** ^The fifth argument to  | 
| 3375 | 
            -
            **  | 
| 3504 | 
            +
            ** ^The fifth argument to the BLOB and string binding interfaces
         | 
| 3505 | 
            +
            ** is a destructor used to dispose of the BLOB or
         | 
| 3376 3506 | 
             
            ** string after SQLite has finished with it.  ^The destructor is called
         | 
| 3377 | 
            -
            ** to dispose of the BLOB or string even if the call to  | 
| 3378 | 
            -
            ** sqlite3_bind_text(), or sqlite3_bind_text16() fails.  
         | 
| 3507 | 
            +
            ** to dispose of the BLOB or string even if the call to bind API fails.
         | 
| 3379 3508 | 
             
            ** ^If the fifth argument is
         | 
| 3380 3509 | 
             
            ** the special value [SQLITE_STATIC], then SQLite assumes that the
         | 
| 3381 3510 | 
             
            ** information is in static, unmanaged space and does not need to be freed.
         | 
| @@ -3383,6 +3512,14 @@ typedef struct sqlite3_context sqlite3_context; | |
| 3383 3512 | 
             
            ** SQLite makes its own private copy of the data immediately, before
         | 
| 3384 3513 | 
             
            ** the sqlite3_bind_*() routine returns.
         | 
| 3385 3514 | 
             
            **
         | 
| 3515 | 
            +
            ** ^The sixth argument to sqlite3_bind_text64() must be one of
         | 
| 3516 | 
            +
            ** [SQLITE_UTF8], [SQLITE_UTF16], [SQLITE_UTF16BE], or [SQLITE_UTF16LE]
         | 
| 3517 | 
            +
            ** to specify the encoding of the text in the third parameter.  If
         | 
| 3518 | 
            +
            ** the sixth argument to sqlite3_bind_text64() is not one of the
         | 
| 3519 | 
            +
            ** allowed values shown above, or if the text encoding is different
         | 
| 3520 | 
            +
            ** from the encoding specified by the sixth parameter, then the behavior
         | 
| 3521 | 
            +
            ** is undefined.
         | 
| 3522 | 
            +
            **
         | 
| 3386 3523 | 
             
            ** ^The sqlite3_bind_zeroblob() routine binds a BLOB of length N that
         | 
| 3387 3524 | 
             
            ** is filled with zeroes.  ^A zeroblob uses a fixed amount of memory
         | 
| 3388 3525 | 
             
            ** (just an integer to hold its size) while it is being processed.
         | 
| @@ -3403,24 +3540,33 @@ typedef struct sqlite3_context sqlite3_context; | |
| 3403 3540 | 
             
            **
         | 
| 3404 3541 | 
             
            ** ^The sqlite3_bind_* routines return [SQLITE_OK] on success or an
         | 
| 3405 3542 | 
             
            ** [error code] if anything goes wrong.
         | 
| 3543 | 
            +
            ** ^[SQLITE_TOOBIG] might be returned if the size of a string or BLOB
         | 
| 3544 | 
            +
            ** exceeds limits imposed by [sqlite3_limit]([SQLITE_LIMIT_LENGTH]) or
         | 
| 3545 | 
            +
            ** [SQLITE_MAX_LENGTH].
         | 
| 3406 3546 | 
             
            ** ^[SQLITE_RANGE] is returned if the parameter
         | 
| 3407 3547 | 
             
            ** index is out of range.  ^[SQLITE_NOMEM] is returned if malloc() fails.
         | 
| 3408 3548 | 
             
            **
         | 
| 3409 3549 | 
             
            ** See also: [sqlite3_bind_parameter_count()],
         | 
| 3410 3550 | 
             
            ** [sqlite3_bind_parameter_name()], and [sqlite3_bind_parameter_index()].
         | 
| 3411 3551 | 
             
            */
         | 
| 3412 | 
            -
            SQLITE_API int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void(*)(void*));
         | 
| 3413 | 
            -
            SQLITE_API int  | 
| 3414 | 
            -
             | 
| 3415 | 
            -
            SQLITE_API int  | 
| 3416 | 
            -
            SQLITE_API int  | 
| 3417 | 
            -
            SQLITE_API int  | 
| 3418 | 
            -
            SQLITE_API int  | 
| 3419 | 
            -
            SQLITE_API int  | 
| 3420 | 
            -
            SQLITE_API int  | 
| 3552 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void(*)(void*));
         | 
| 3553 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_blob64(sqlite3_stmt*, int, const void*, sqlite3_uint64,
         | 
| 3554 | 
            +
                                    void(*)(void*));
         | 
| 3555 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_double(sqlite3_stmt*, int, double);
         | 
| 3556 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_int(sqlite3_stmt*, int, int);
         | 
| 3557 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_int64(sqlite3_stmt*, int, sqlite3_int64);
         | 
| 3558 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_null(sqlite3_stmt*, int);
         | 
| 3559 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_text(sqlite3_stmt*,int,const char*,int,void(*)(void*));
         | 
| 3560 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_text16(sqlite3_stmt*, int, const void*, int, void(*)(void*));
         | 
| 3561 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_text64(sqlite3_stmt*, int, const char*, sqlite3_uint64,
         | 
| 3562 | 
            +
                                     void(*)(void*), unsigned char encoding);
         | 
| 3563 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_value(sqlite3_stmt*, int, const sqlite3_value*);
         | 
| 3564 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_zeroblob(sqlite3_stmt*, int, int n);
         | 
| 3565 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_zeroblob64(sqlite3_stmt*, int, sqlite3_uint64);
         | 
| 3421 3566 |  | 
| 3422 3567 | 
             
            /*
         | 
| 3423 3568 | 
             
            ** CAPI3REF: Number Of SQL Parameters
         | 
| 3569 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3424 3570 | 
             
            **
         | 
| 3425 3571 | 
             
            ** ^This routine can be used to find the number of [SQL parameters]
         | 
| 3426 3572 | 
             
            ** in a [prepared statement].  SQL parameters are tokens of the
         | 
| @@ -3437,10 +3583,11 @@ SQLITE_API int sqlite3_bind_zeroblob(sqlite3_stmt*, int, int n); | |
| 3437 3583 | 
             
            ** [sqlite3_bind_parameter_name()], and
         | 
| 3438 3584 | 
             
            ** [sqlite3_bind_parameter_index()].
         | 
| 3439 3585 | 
             
            */
         | 
| 3440 | 
            -
            SQLITE_API int sqlite3_bind_parameter_count(sqlite3_stmt*);
         | 
| 3586 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_parameter_count(sqlite3_stmt*);
         | 
| 3441 3587 |  | 
| 3442 3588 | 
             
            /*
         | 
| 3443 3589 | 
             
            ** CAPI3REF: Name Of A Host Parameter
         | 
| 3590 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3444 3591 | 
             
            **
         | 
| 3445 3592 | 
             
            ** ^The sqlite3_bind_parameter_name(P,N) interface returns
         | 
| 3446 3593 | 
             
            ** the name of the N-th [SQL parameter] in the [prepared statement] P.
         | 
| @@ -3464,10 +3611,11 @@ SQLITE_API int sqlite3_bind_parameter_count(sqlite3_stmt*); | |
| 3464 3611 | 
             
            ** [sqlite3_bind_parameter_count()], and
         | 
| 3465 3612 | 
             
            ** [sqlite3_bind_parameter_index()].
         | 
| 3466 3613 | 
             
            */
         | 
| 3467 | 
            -
            SQLITE_API const char *sqlite3_bind_parameter_name(sqlite3_stmt*, int);
         | 
| 3614 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_bind_parameter_name(sqlite3_stmt*, int);
         | 
| 3468 3615 |  | 
| 3469 3616 | 
             
            /*
         | 
| 3470 3617 | 
             
            ** CAPI3REF: Index Of A Parameter With A Given Name
         | 
| 3618 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3471 3619 | 
             
            **
         | 
| 3472 3620 | 
             
            ** ^Return the index of an SQL parameter given its name.  ^The
         | 
| 3473 3621 | 
             
            ** index value returned is suitable for use as the second
         | 
| @@ -3480,19 +3628,21 @@ SQLITE_API const char *sqlite3_bind_parameter_name(sqlite3_stmt*, int); | |
| 3480 3628 | 
             
            ** [sqlite3_bind_parameter_count()], and
         | 
| 3481 3629 | 
             
            ** [sqlite3_bind_parameter_index()].
         | 
| 3482 3630 | 
             
            */
         | 
| 3483 | 
            -
            SQLITE_API int sqlite3_bind_parameter_index(sqlite3_stmt*, const char *zName);
         | 
| 3631 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_bind_parameter_index(sqlite3_stmt*, const char *zName);
         | 
| 3484 3632 |  | 
| 3485 3633 | 
             
            /*
         | 
| 3486 3634 | 
             
            ** CAPI3REF: Reset All Bindings On A Prepared Statement
         | 
| 3635 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3487 3636 | 
             
            **
         | 
| 3488 3637 | 
             
            ** ^Contrary to the intuition of many, [sqlite3_reset()] does not reset
         | 
| 3489 3638 | 
             
            ** the [sqlite3_bind_blob | bindings] on a [prepared statement].
         | 
| 3490 3639 | 
             
            ** ^Use this routine to reset all host parameters to NULL.
         | 
| 3491 3640 | 
             
            */
         | 
| 3492 | 
            -
            SQLITE_API int sqlite3_clear_bindings(sqlite3_stmt*);
         | 
| 3641 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_clear_bindings(sqlite3_stmt*);
         | 
| 3493 3642 |  | 
| 3494 3643 | 
             
            /*
         | 
| 3495 3644 | 
             
            ** CAPI3REF: Number Of Columns In A Result Set
         | 
| 3645 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3496 3646 | 
             
            **
         | 
| 3497 3647 | 
             
            ** ^Return the number of columns in the result set returned by the
         | 
| 3498 3648 | 
             
            ** [prepared statement]. ^This routine returns 0 if pStmt is an SQL
         | 
| @@ -3500,10 +3650,11 @@ SQLITE_API int sqlite3_clear_bindings(sqlite3_stmt*); | |
| 3500 3650 | 
             
            **
         | 
| 3501 3651 | 
             
            ** See also: [sqlite3_data_count()]
         | 
| 3502 3652 | 
             
            */
         | 
| 3503 | 
            -
            SQLITE_API int sqlite3_column_count(sqlite3_stmt *pStmt);
         | 
| 3653 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_column_count(sqlite3_stmt *pStmt);
         | 
| 3504 3654 |  | 
| 3505 3655 | 
             
            /*
         | 
| 3506 3656 | 
             
            ** CAPI3REF: Column Names In A Result Set
         | 
| 3657 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3507 3658 | 
             
            **
         | 
| 3508 3659 | 
             
            ** ^These routines return the name assigned to a particular column
         | 
| 3509 3660 | 
             
            ** in the result set of a [SELECT] statement.  ^The sqlite3_column_name()
         | 
| @@ -3528,11 +3679,12 @@ SQLITE_API int sqlite3_column_count(sqlite3_stmt *pStmt); | |
| 3528 3679 | 
             
            ** then the name of the column is unspecified and may change from
         | 
| 3529 3680 | 
             
            ** one release of SQLite to the next.
         | 
| 3530 3681 | 
             
            */
         | 
| 3531 | 
            -
            SQLITE_API const char *sqlite3_column_name(sqlite3_stmt*, int N);
         | 
| 3532 | 
            -
            SQLITE_API const void *sqlite3_column_name16(sqlite3_stmt*, int N);
         | 
| 3682 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_column_name(sqlite3_stmt*, int N);
         | 
| 3683 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_name16(sqlite3_stmt*, int N);
         | 
| 3533 3684 |  | 
| 3534 3685 | 
             
            /*
         | 
| 3535 3686 | 
             
            ** CAPI3REF: Source Of Data In A Query Result
         | 
| 3687 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3536 3688 | 
             
            **
         | 
| 3537 3689 | 
             
            ** ^These routines provide a means to determine the database, table, and
         | 
| 3538 3690 | 
             
            ** table column that is the origin of a particular result column in
         | 
| @@ -3576,15 +3728,16 @@ SQLITE_API const void *sqlite3_column_name16(sqlite3_stmt*, int N); | |
| 3576 3728 | 
             
            ** for the same [prepared statement] and result column
         | 
| 3577 3729 | 
             
            ** at the same time then the results are undefined.
         | 
| 3578 3730 | 
             
            */
         | 
| 3579 | 
            -
            SQLITE_API const char *sqlite3_column_database_name(sqlite3_stmt*,int);
         | 
| 3580 | 
            -
            SQLITE_API const void *sqlite3_column_database_name16(sqlite3_stmt*,int);
         | 
| 3581 | 
            -
            SQLITE_API const char *sqlite3_column_table_name(sqlite3_stmt*,int);
         | 
| 3582 | 
            -
            SQLITE_API const void *sqlite3_column_table_name16(sqlite3_stmt*,int);
         | 
| 3583 | 
            -
            SQLITE_API const char *sqlite3_column_origin_name(sqlite3_stmt*,int);
         | 
| 3584 | 
            -
            SQLITE_API const void *sqlite3_column_origin_name16(sqlite3_stmt*,int);
         | 
| 3731 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_column_database_name(sqlite3_stmt*,int);
         | 
| 3732 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_database_name16(sqlite3_stmt*,int);
         | 
| 3733 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_column_table_name(sqlite3_stmt*,int);
         | 
| 3734 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_table_name16(sqlite3_stmt*,int);
         | 
| 3735 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_column_origin_name(sqlite3_stmt*,int);
         | 
| 3736 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_origin_name16(sqlite3_stmt*,int);
         | 
| 3585 3737 |  | 
| 3586 3738 | 
             
            /*
         | 
| 3587 3739 | 
             
            ** CAPI3REF: Declared Datatype Of A Query Result
         | 
| 3740 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3588 3741 | 
             
            **
         | 
| 3589 3742 | 
             
            ** ^(The first parameter is a [prepared statement].
         | 
| 3590 3743 | 
             
            ** If this statement is a [SELECT] statement and the Nth column of the
         | 
| @@ -3612,11 +3765,12 @@ SQLITE_API const void *sqlite3_column_origin_name16(sqlite3_stmt*,int); | |
| 3612 3765 | 
             
            ** is associated with individual values, not with the containers
         | 
| 3613 3766 | 
             
            ** used to hold those values.
         | 
| 3614 3767 | 
             
            */
         | 
| 3615 | 
            -
            SQLITE_API const char *sqlite3_column_decltype(sqlite3_stmt*,int);
         | 
| 3616 | 
            -
            SQLITE_API const void *sqlite3_column_decltype16(sqlite3_stmt*,int);
         | 
| 3768 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_column_decltype(sqlite3_stmt*,int);
         | 
| 3769 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_decltype16(sqlite3_stmt*,int);
         | 
| 3617 3770 |  | 
| 3618 3771 | 
             
            /*
         | 
| 3619 3772 | 
             
            ** CAPI3REF: Evaluate An SQL Statement
         | 
| 3773 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3620 3774 | 
             
            **
         | 
| 3621 3775 | 
             
            ** After a [prepared statement] has been prepared using either
         | 
| 3622 3776 | 
             
            ** [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()] or one of the legacy
         | 
| @@ -3692,10 +3846,11 @@ SQLITE_API const void *sqlite3_column_decltype16(sqlite3_stmt*,int); | |
| 3692 3846 | 
             
            ** then the more specific [error codes] are returned directly
         | 
| 3693 3847 | 
             
            ** by sqlite3_step().  The use of the "v2" interface is recommended.
         | 
| 3694 3848 | 
             
            */
         | 
| 3695 | 
            -
            SQLITE_API int sqlite3_step(sqlite3_stmt*);
         | 
| 3849 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_step(sqlite3_stmt*);
         | 
| 3696 3850 |  | 
| 3697 3851 | 
             
            /*
         | 
| 3698 3852 | 
             
            ** CAPI3REF: Number of columns in a result set
         | 
| 3853 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3699 3854 | 
             
            **
         | 
| 3700 3855 | 
             
            ** ^The sqlite3_data_count(P) interface returns the number of columns in the
         | 
| 3701 3856 | 
             
            ** current row of the result set of [prepared statement] P.
         | 
| @@ -3712,7 +3867,7 @@ SQLITE_API int sqlite3_step(sqlite3_stmt*); | |
| 3712 3867 | 
             
            **
         | 
| 3713 3868 | 
             
            ** See also: [sqlite3_column_count()]
         | 
| 3714 3869 | 
             
            */
         | 
| 3715 | 
            -
            SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
         | 
| 3870 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
         | 
| 3716 3871 |  | 
| 3717 3872 | 
             
            /*
         | 
| 3718 3873 | 
             
            ** CAPI3REF: Fundamental Datatypes
         | 
| @@ -3749,8 +3904,7 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3749 3904 | 
             
            /*
         | 
| 3750 3905 | 
             
            ** CAPI3REF: Result Values From A Query
         | 
| 3751 3906 | 
             
            ** KEYWORDS: {column access functions}
         | 
| 3752 | 
            -
            **
         | 
| 3753 | 
            -
            ** These routines form the "result set" interface.
         | 
| 3907 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3754 3908 | 
             
            **
         | 
| 3755 3909 | 
             
            ** ^These routines return information about a single column of the current
         | 
| 3756 3910 | 
             
            ** result row of a query.  ^In every case the first argument is a pointer
         | 
| @@ -3811,13 +3965,14 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3811 3965 | 
             
            ** even empty strings, are always zero-terminated.  ^The return
         | 
| 3812 3966 | 
             
            ** value from sqlite3_column_blob() for a zero-length BLOB is a NULL pointer.
         | 
| 3813 3967 | 
             
            **
         | 
| 3814 | 
            -
            ** ^The object returned by [sqlite3_column_value()] is an
         | 
| 3815 | 
            -
            ** [unprotected sqlite3_value] object.   | 
| 3816 | 
            -
            ** may only be used with | 
| 3968 | 
            +
            ** <b>Warning:</b> ^The object returned by [sqlite3_column_value()] is an
         | 
| 3969 | 
            +
            ** [unprotected sqlite3_value] object.  In a multithreaded environment,
         | 
| 3970 | 
            +
            ** an unprotected sqlite3_value object may only be used safely with
         | 
| 3971 | 
            +
            ** [sqlite3_bind_value()] and [sqlite3_result_value()].
         | 
| 3817 3972 | 
             
            ** If the [unprotected sqlite3_value] object returned by
         | 
| 3818 3973 | 
             
            ** [sqlite3_column_value()] is used in any other way, including calls
         | 
| 3819 3974 | 
             
            ** to routines like [sqlite3_value_int()], [sqlite3_value_text()],
         | 
| 3820 | 
            -
            ** or [sqlite3_value_bytes()],  | 
| 3975 | 
            +
            ** or [sqlite3_value_bytes()], the behavior is not threadsafe.
         | 
| 3821 3976 | 
             
            **
         | 
| 3822 3977 | 
             
            ** These routines attempt to convert the value where appropriate.  ^For
         | 
| 3823 3978 | 
             
            ** example, if the internal representation is FLOAT and a text result
         | 
| @@ -3848,12 +4003,6 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3848 4003 | 
             
            ** </table>
         | 
| 3849 4004 | 
             
            ** </blockquote>)^
         | 
| 3850 4005 | 
             
            **
         | 
| 3851 | 
            -
            ** The table above makes reference to standard C library functions atoi()
         | 
| 3852 | 
            -
            ** and atof().  SQLite does not really use these functions.  It has its
         | 
| 3853 | 
            -
            ** own equivalent internal routines.  The atoi() and atof() names are
         | 
| 3854 | 
            -
            ** used in the table for brevity and because they are familiar to most
         | 
| 3855 | 
            -
            ** C programmers.
         | 
| 3856 | 
            -
            **
         | 
| 3857 4006 | 
             
            ** Note that when type conversions occur, pointers returned by prior
         | 
| 3858 4007 | 
             
            ** calls to sqlite3_column_blob(), sqlite3_column_text(), and/or
         | 
| 3859 4008 | 
             
            ** sqlite3_column_text16() may be invalidated.
         | 
| @@ -3878,7 +4027,7 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3878 4027 | 
             
            ** of conversion are done in place when it is possible, but sometimes they
         | 
| 3879 4028 | 
             
            ** are not possible and in those cases prior pointers are invalidated.
         | 
| 3880 4029 | 
             
            **
         | 
| 3881 | 
            -
            ** The safest  | 
| 4030 | 
            +
            ** The safest policy is to invoke these routines
         | 
| 3882 4031 | 
             
            ** in one of the following ways:
         | 
| 3883 4032 | 
             
            **
         | 
| 3884 4033 | 
             
            ** <ul>
         | 
| @@ -3898,7 +4047,7 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3898 4047 | 
             
            ** ^The pointers returned are valid until a type conversion occurs as
         | 
| 3899 4048 | 
             
            ** described above, or until [sqlite3_step()] or [sqlite3_reset()] or
         | 
| 3900 4049 | 
             
            ** [sqlite3_finalize()] is called.  ^The memory space used to hold strings
         | 
| 3901 | 
            -
            ** and BLOBs is freed automatically.  Do < | 
| 4050 | 
            +
            ** and BLOBs is freed automatically.  Do <em>not</em> pass the pointers returned
         | 
| 3902 4051 | 
             
            ** from [sqlite3_column_blob()], [sqlite3_column_text()], etc. into
         | 
| 3903 4052 | 
             
            ** [sqlite3_free()].
         | 
| 3904 4053 | 
             
            **
         | 
| @@ -3908,19 +4057,20 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt); | |
| 3908 4057 | 
             
            ** pointer.  Subsequent calls to [sqlite3_errcode()] will return
         | 
| 3909 4058 | 
             
            ** [SQLITE_NOMEM].)^
         | 
| 3910 4059 | 
             
            */
         | 
| 3911 | 
            -
            SQLITE_API const void *sqlite3_column_blob(sqlite3_stmt*, int iCol);
         | 
| 3912 | 
            -
            SQLITE_API int sqlite3_column_bytes(sqlite3_stmt*, int iCol);
         | 
| 3913 | 
            -
            SQLITE_API int sqlite3_column_bytes16(sqlite3_stmt*, int iCol);
         | 
| 3914 | 
            -
            SQLITE_API double sqlite3_column_double(sqlite3_stmt*, int iCol);
         | 
| 3915 | 
            -
            SQLITE_API int sqlite3_column_int(sqlite3_stmt*, int iCol);
         | 
| 3916 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol);
         | 
| 3917 | 
            -
            SQLITE_API const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);
         | 
| 3918 | 
            -
            SQLITE_API const void *sqlite3_column_text16(sqlite3_stmt*, int iCol);
         | 
| 3919 | 
            -
            SQLITE_API int sqlite3_column_type(sqlite3_stmt*, int iCol);
         | 
| 3920 | 
            -
            SQLITE_API sqlite3_value *sqlite3_column_value(sqlite3_stmt*, int iCol);
         | 
| 4060 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_blob(sqlite3_stmt*, int iCol);
         | 
| 4061 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_column_bytes(sqlite3_stmt*, int iCol);
         | 
| 4062 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_column_bytes16(sqlite3_stmt*, int iCol);
         | 
| 4063 | 
            +
            SQLITE_API double SQLITE_STDCALL sqlite3_column_double(sqlite3_stmt*, int iCol);
         | 
| 4064 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_column_int(sqlite3_stmt*, int iCol);
         | 
| 4065 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_column_int64(sqlite3_stmt*, int iCol);
         | 
| 4066 | 
            +
            SQLITE_API const unsigned char *SQLITE_STDCALL sqlite3_column_text(sqlite3_stmt*, int iCol);
         | 
| 4067 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_column_text16(sqlite3_stmt*, int iCol);
         | 
| 4068 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_column_type(sqlite3_stmt*, int iCol);
         | 
| 4069 | 
            +
            SQLITE_API sqlite3_value *SQLITE_STDCALL sqlite3_column_value(sqlite3_stmt*, int iCol);
         | 
| 3921 4070 |  | 
| 3922 4071 | 
             
            /*
         | 
| 3923 4072 | 
             
            ** CAPI3REF: Destroy A Prepared Statement Object
         | 
| 4073 | 
            +
            ** DESTRUCTOR: sqlite3_stmt
         | 
| 3924 4074 | 
             
            **
         | 
| 3925 4075 | 
             
            ** ^The sqlite3_finalize() function is called to delete a [prepared statement].
         | 
| 3926 4076 | 
             
            ** ^If the most recent evaluation of the statement encountered no errors
         | 
| @@ -3944,10 +4094,11 @@ SQLITE_API sqlite3_value *sqlite3_column_value(sqlite3_stmt*, int iCol); | |
| 3944 4094 | 
             
            ** statement after it has been finalized can result in undefined and
         | 
| 3945 4095 | 
             
            ** undesirable behavior such as segfaults and heap corruption.
         | 
| 3946 4096 | 
             
            */
         | 
| 3947 | 
            -
            SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt);
         | 
| 4097 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_finalize(sqlite3_stmt *pStmt);
         | 
| 3948 4098 |  | 
| 3949 4099 | 
             
            /*
         | 
| 3950 4100 | 
             
            ** CAPI3REF: Reset A Prepared Statement Object
         | 
| 4101 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 3951 4102 | 
             
            **
         | 
| 3952 4103 | 
             
            ** The sqlite3_reset() function is called to reset a [prepared statement]
         | 
| 3953 4104 | 
             
            ** object back to its initial state, ready to be re-executed.
         | 
| @@ -3970,13 +4121,14 @@ SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt); | |
| 3970 4121 | 
             
            ** ^The [sqlite3_reset(S)] interface does not change the values
         | 
| 3971 4122 | 
             
            ** of any [sqlite3_bind_blob|bindings] on the [prepared statement] S.
         | 
| 3972 4123 | 
             
            */
         | 
| 3973 | 
            -
            SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
         | 
| 4124 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_reset(sqlite3_stmt *pStmt);
         | 
| 3974 4125 |  | 
| 3975 4126 | 
             
            /*
         | 
| 3976 4127 | 
             
            ** CAPI3REF: Create Or Redefine SQL Functions
         | 
| 3977 4128 | 
             
            ** KEYWORDS: {function creation routines}
         | 
| 3978 4129 | 
             
            ** KEYWORDS: {application-defined SQL function}
         | 
| 3979 4130 | 
             
            ** KEYWORDS: {application-defined SQL functions}
         | 
| 4131 | 
            +
            ** METHOD: sqlite3
         | 
| 3980 4132 | 
             
            **
         | 
| 3981 4133 | 
             
            ** ^These functions (collectively known as "function creation routines")
         | 
| 3982 4134 | 
             
            ** are used to add SQL functions or aggregates or to redefine the behavior
         | 
| @@ -4069,7 +4221,7 @@ SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt); | |
| 4069 4221 | 
             
            ** close the database connection nor finalize or reset the prepared
         | 
| 4070 4222 | 
             
            ** statement in which the function is running.
         | 
| 4071 4223 | 
             
            */
         | 
| 4072 | 
            -
            SQLITE_API int sqlite3_create_function(
         | 
| 4224 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_function(
         | 
| 4073 4225 | 
             
              sqlite3 *db,
         | 
| 4074 4226 | 
             
              const char *zFunctionName,
         | 
| 4075 4227 | 
             
              int nArg,
         | 
| @@ -4079,7 +4231,7 @@ SQLITE_API int sqlite3_create_function( | |
| 4079 4231 | 
             
              void (*xStep)(sqlite3_context*,int,sqlite3_value**),
         | 
| 4080 4232 | 
             
              void (*xFinal)(sqlite3_context*)
         | 
| 4081 4233 | 
             
            );
         | 
| 4082 | 
            -
            SQLITE_API int sqlite3_create_function16(
         | 
| 4234 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_function16(
         | 
| 4083 4235 | 
             
              sqlite3 *db,
         | 
| 4084 4236 | 
             
              const void *zFunctionName,
         | 
| 4085 4237 | 
             
              int nArg,
         | 
| @@ -4089,7 +4241,7 @@ SQLITE_API int sqlite3_create_function16( | |
| 4089 4241 | 
             
              void (*xStep)(sqlite3_context*,int,sqlite3_value**),
         | 
| 4090 4242 | 
             
              void (*xFinal)(sqlite3_context*)
         | 
| 4091 4243 | 
             
            );
         | 
| 4092 | 
            -
            SQLITE_API int sqlite3_create_function_v2(
         | 
| 4244 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_function_v2(
         | 
| 4093 4245 | 
             
              sqlite3 *db,
         | 
| 4094 4246 | 
             
              const char *zFunctionName,
         | 
| 4095 4247 | 
             
              int nArg,
         | 
| @@ -4107,9 +4259,9 @@ SQLITE_API int sqlite3_create_function_v2( | |
| 4107 4259 | 
             
            ** These constant define integer codes that represent the various
         | 
| 4108 4260 | 
             
            ** text encodings supported by SQLite.
         | 
| 4109 4261 | 
             
            */
         | 
| 4110 | 
            -
            #define SQLITE_UTF8           1
         | 
| 4111 | 
            -
            #define SQLITE_UTF16LE        2
         | 
| 4112 | 
            -
            #define SQLITE_UTF16BE        3
         | 
| 4262 | 
            +
            #define SQLITE_UTF8           1    /* IMP: R-37514-35566 */
         | 
| 4263 | 
            +
            #define SQLITE_UTF16LE        2    /* IMP: R-03371-37637 */
         | 
| 4264 | 
            +
            #define SQLITE_UTF16BE        3    /* IMP: R-51971-34154 */
         | 
| 4113 4265 | 
             
            #define SQLITE_UTF16          4    /* Use native byte order */
         | 
| 4114 4266 | 
             
            #define SQLITE_ANY            5    /* Deprecated */
         | 
| 4115 4267 | 
             
            #define SQLITE_UTF16_ALIGNED  8    /* sqlite3_create_collation only */
         | 
| @@ -4131,25 +4283,26 @@ SQLITE_API int sqlite3_create_function_v2( | |
| 4131 4283 | 
             
            ** These functions are [deprecated].  In order to maintain
         | 
| 4132 4284 | 
             
            ** backwards compatibility with older code, these functions continue 
         | 
| 4133 4285 | 
             
            ** to be supported.  However, new applications should avoid
         | 
| 4134 | 
            -
            ** the use of these functions.  To  | 
| 4135 | 
            -
            **  | 
| 4286 | 
            +
            ** the use of these functions.  To encourage programmers to avoid
         | 
| 4287 | 
            +
            ** these functions, we will not explain what they do.
         | 
| 4136 4288 | 
             
            */
         | 
| 4137 4289 | 
             
            #ifndef SQLITE_OMIT_DEPRECATED
         | 
| 4138 | 
            -
            SQLITE_API SQLITE_DEPRECATED int sqlite3_aggregate_count(sqlite3_context*);
         | 
| 4139 | 
            -
            SQLITE_API SQLITE_DEPRECATED int sqlite3_expired(sqlite3_stmt*);
         | 
| 4140 | 
            -
            SQLITE_API SQLITE_DEPRECATED int sqlite3_transfer_bindings(sqlite3_stmt*, sqlite3_stmt*);
         | 
| 4141 | 
            -
            SQLITE_API SQLITE_DEPRECATED int sqlite3_global_recover(void);
         | 
| 4142 | 
            -
            SQLITE_API SQLITE_DEPRECATED void sqlite3_thread_cleanup(void);
         | 
| 4143 | 
            -
            SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void(*)(void*,sqlite3_int64,int),
         | 
| 4290 | 
            +
            SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_aggregate_count(sqlite3_context*);
         | 
| 4291 | 
            +
            SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_expired(sqlite3_stmt*);
         | 
| 4292 | 
            +
            SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_transfer_bindings(sqlite3_stmt*, sqlite3_stmt*);
         | 
| 4293 | 
            +
            SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_global_recover(void);
         | 
| 4294 | 
            +
            SQLITE_API SQLITE_DEPRECATED void SQLITE_STDCALL sqlite3_thread_cleanup(void);
         | 
| 4295 | 
            +
            SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_memory_alarm(void(*)(void*,sqlite3_int64,int),
         | 
| 4144 4296 | 
             
                                  void*,sqlite3_int64);
         | 
| 4145 4297 | 
             
            #endif
         | 
| 4146 4298 |  | 
| 4147 4299 | 
             
            /*
         | 
| 4148 | 
            -
            ** CAPI3REF: Obtaining SQL  | 
| 4300 | 
            +
            ** CAPI3REF: Obtaining SQL Values
         | 
| 4301 | 
            +
            ** METHOD: sqlite3_value
         | 
| 4149 4302 | 
             
            **
         | 
| 4150 4303 | 
             
            ** The C-language implementation of SQL functions and aggregates uses
         | 
| 4151 4304 | 
             
            ** this set of interface routines to access the parameter values on
         | 
| 4152 | 
            -
            ** the function or aggregate.
         | 
| 4305 | 
            +
            ** the function or aggregate.  
         | 
| 4153 4306 | 
             
            **
         | 
| 4154 4307 | 
             
            ** The xFunc (for scalar functions) or xStep (for aggregates) parameters
         | 
| 4155 4308 | 
             
            ** to [sqlite3_create_function()] and [sqlite3_create_function16()]
         | 
| @@ -4164,7 +4317,7 @@ SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void(*)(void*,sqlite3_int6 | |
| 4164 4317 | 
             
            ** object results in undefined behavior.
         | 
| 4165 4318 | 
             
            **
         | 
| 4166 4319 | 
             
            ** ^These routines work just like the corresponding [column access functions]
         | 
| 4167 | 
            -
            ** except that | 
| 4320 | 
            +
            ** except that these routines take a single [protected sqlite3_value] object
         | 
| 4168 4321 | 
             
            ** pointer instead of a [sqlite3_stmt*] pointer and an integer column number.
         | 
| 4169 4322 | 
             
            **
         | 
| 4170 4323 | 
             
            ** ^The sqlite3_value_text16() interface extracts a UTF-16 string
         | 
| @@ -4189,21 +4342,39 @@ SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void(*)(void*,sqlite3_int6 | |
| 4189 4342 | 
             
            ** These routines must be called from the same thread as
         | 
| 4190 4343 | 
             
            ** the SQL function that supplied the [sqlite3_value*] parameters.
         | 
| 4191 4344 | 
             
            */
         | 
| 4192 | 
            -
            SQLITE_API const void *sqlite3_value_blob(sqlite3_value*);
         | 
| 4193 | 
            -
            SQLITE_API int sqlite3_value_bytes(sqlite3_value*);
         | 
| 4194 | 
            -
            SQLITE_API int sqlite3_value_bytes16(sqlite3_value*);
         | 
| 4195 | 
            -
            SQLITE_API double sqlite3_value_double(sqlite3_value*);
         | 
| 4196 | 
            -
            SQLITE_API int sqlite3_value_int(sqlite3_value*);
         | 
| 4197 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_value_int64(sqlite3_value*);
         | 
| 4198 | 
            -
            SQLITE_API const unsigned char *sqlite3_value_text(sqlite3_value*);
         | 
| 4199 | 
            -
            SQLITE_API const void *sqlite3_value_text16(sqlite3_value*);
         | 
| 4200 | 
            -
            SQLITE_API const void *sqlite3_value_text16le(sqlite3_value*);
         | 
| 4201 | 
            -
            SQLITE_API const void *sqlite3_value_text16be(sqlite3_value*);
         | 
| 4202 | 
            -
            SQLITE_API int sqlite3_value_type(sqlite3_value*);
         | 
| 4203 | 
            -
            SQLITE_API int sqlite3_value_numeric_type(sqlite3_value*);
         | 
| 4345 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_value_blob(sqlite3_value*);
         | 
| 4346 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_value_bytes(sqlite3_value*);
         | 
| 4347 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_value_bytes16(sqlite3_value*);
         | 
| 4348 | 
            +
            SQLITE_API double SQLITE_STDCALL sqlite3_value_double(sqlite3_value*);
         | 
| 4349 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_value_int(sqlite3_value*);
         | 
| 4350 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_value_int64(sqlite3_value*);
         | 
| 4351 | 
            +
            SQLITE_API const unsigned char *SQLITE_STDCALL sqlite3_value_text(sqlite3_value*);
         | 
| 4352 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_value_text16(sqlite3_value*);
         | 
| 4353 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_value_text16le(sqlite3_value*);
         | 
| 4354 | 
            +
            SQLITE_API const void *SQLITE_STDCALL sqlite3_value_text16be(sqlite3_value*);
         | 
| 4355 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_value_type(sqlite3_value*);
         | 
| 4356 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_value_numeric_type(sqlite3_value*);
         | 
| 4357 | 
            +
             | 
| 4358 | 
            +
            /*
         | 
| 4359 | 
            +
            ** CAPI3REF: Copy And Free SQL Values
         | 
| 4360 | 
            +
            ** METHOD: sqlite3_value
         | 
| 4361 | 
            +
            **
         | 
| 4362 | 
            +
            ** ^The sqlite3_value_dup(V) interface makes a copy of the [sqlite3_value]
         | 
| 4363 | 
            +
            ** object D and returns a pointer to that copy.  ^The [sqlite3_value] returned
         | 
| 4364 | 
            +
            ** is a [protected sqlite3_value] object even if the input is not.
         | 
| 4365 | 
            +
            ** ^The sqlite3_value_dup(V) interface returns NULL if V is NULL or if a
         | 
| 4366 | 
            +
            ** memory allocation fails.
         | 
| 4367 | 
            +
            **
         | 
| 4368 | 
            +
            ** ^The sqlite3_value_free(V) interface frees an [sqlite3_value] object
         | 
| 4369 | 
            +
            ** previously obtained from [sqlite3_value_dup()].  ^If V is a NULL pointer
         | 
| 4370 | 
            +
            ** then sqlite3_value_free(V) is a harmless no-op.
         | 
| 4371 | 
            +
            */
         | 
| 4372 | 
            +
            SQLITE_API SQLITE_EXPERIMENTAL sqlite3_value *SQLITE_STDCALL sqlite3_value_dup(const sqlite3_value*);
         | 
| 4373 | 
            +
            SQLITE_API SQLITE_EXPERIMENTAL void SQLITE_STDCALL sqlite3_value_free(sqlite3_value*);
         | 
| 4204 4374 |  | 
| 4205 4375 | 
             
            /*
         | 
| 4206 4376 | 
             
            ** CAPI3REF: Obtain Aggregate Function Context
         | 
| 4377 | 
            +
            ** METHOD: sqlite3_context
         | 
| 4207 4378 | 
             
            **
         | 
| 4208 4379 | 
             
            ** Implementations of aggregate SQL functions use this
         | 
| 4209 4380 | 
             
            ** routine to allocate memory for storing their state.
         | 
| @@ -4244,10 +4415,11 @@ SQLITE_API int sqlite3_value_numeric_type(sqlite3_value*); | |
| 4244 4415 | 
             
            ** This routine must be called from the same thread in which
         | 
| 4245 4416 | 
             
            ** the aggregate SQL function is running.
         | 
| 4246 4417 | 
             
            */
         | 
| 4247 | 
            -
            SQLITE_API void *sqlite3_aggregate_context(sqlite3_context*, int nBytes);
         | 
| 4418 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_aggregate_context(sqlite3_context*, int nBytes);
         | 
| 4248 4419 |  | 
| 4249 4420 | 
             
            /*
         | 
| 4250 4421 | 
             
            ** CAPI3REF: User Data For Functions
         | 
| 4422 | 
            +
            ** METHOD: sqlite3_context
         | 
| 4251 4423 | 
             
            **
         | 
| 4252 4424 | 
             
            ** ^The sqlite3_user_data() interface returns a copy of
         | 
| 4253 4425 | 
             
            ** the pointer that was the pUserData parameter (the 5th parameter)
         | 
| @@ -4258,10 +4430,11 @@ SQLITE_API void *sqlite3_aggregate_context(sqlite3_context*, int nBytes); | |
| 4258 4430 | 
             
            ** This routine must be called from the same thread in which
         | 
| 4259 4431 | 
             
            ** the application-defined function is running.
         | 
| 4260 4432 | 
             
            */
         | 
| 4261 | 
            -
            SQLITE_API void *sqlite3_user_data(sqlite3_context*);
         | 
| 4433 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_user_data(sqlite3_context*);
         | 
| 4262 4434 |  | 
| 4263 4435 | 
             
            /*
         | 
| 4264 4436 | 
             
            ** CAPI3REF: Database Connection For Functions
         | 
| 4437 | 
            +
            ** METHOD: sqlite3_context
         | 
| 4265 4438 | 
             
            **
         | 
| 4266 4439 | 
             
            ** ^The sqlite3_context_db_handle() interface returns a copy of
         | 
| 4267 4440 | 
             
            ** the pointer to the [database connection] (the 1st parameter)
         | 
| @@ -4269,10 +4442,11 @@ SQLITE_API void *sqlite3_user_data(sqlite3_context*); | |
| 4269 4442 | 
             
            ** and [sqlite3_create_function16()] routines that originally
         | 
| 4270 4443 | 
             
            ** registered the application defined function.
         | 
| 4271 4444 | 
             
            */
         | 
| 4272 | 
            -
            SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
         | 
| 4445 | 
            +
            SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_context_db_handle(sqlite3_context*);
         | 
| 4273 4446 |  | 
| 4274 4447 | 
             
            /*
         | 
| 4275 4448 | 
             
            ** CAPI3REF: Function Auxiliary Data
         | 
| 4449 | 
            +
            ** METHOD: sqlite3_context
         | 
| 4276 4450 | 
             
            **
         | 
| 4277 4451 | 
             
            ** These functions may be used by (non-aggregate) SQL functions to
         | 
| 4278 4452 | 
             
            ** associate metadata with argument values. If the same value is passed to
         | 
| @@ -4321,8 +4495,8 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*); | |
| 4321 4495 | 
             
            ** These routines must be called from the same thread in which
         | 
| 4322 4496 | 
             
            ** the SQL function is running.
         | 
| 4323 4497 | 
             
            */
         | 
| 4324 | 
            -
            SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
         | 
| 4325 | 
            -
            SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
         | 
| 4498 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_get_auxdata(sqlite3_context*, int N);
         | 
| 4499 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
         | 
| 4326 4500 |  | 
| 4327 4501 |  | 
| 4328 4502 | 
             
            /*
         | 
| @@ -4345,6 +4519,7 @@ typedef void (*sqlite3_destructor_type)(void*); | |
| 4345 4519 |  | 
| 4346 4520 | 
             
            /*
         | 
| 4347 4521 | 
             
            ** CAPI3REF: Setting The Result Of An SQL Function
         | 
| 4522 | 
            +
            ** METHOD: sqlite3_context
         | 
| 4348 4523 | 
             
            **
         | 
| 4349 4524 | 
             
            ** These routines are used by the xFunc or xFinal callbacks that
         | 
| 4350 4525 | 
             
            ** implement SQL functions and aggregates.  See
         | 
| @@ -4360,9 +4535,9 @@ typedef void (*sqlite3_destructor_type)(void*); | |
| 4360 4535 | 
             
            ** to by the second parameter and which is N bytes long where N is the
         | 
| 4361 4536 | 
             
            ** third parameter.
         | 
| 4362 4537 | 
             
            **
         | 
| 4363 | 
            -
            ** ^The sqlite3_result_zeroblob()  | 
| 4364 | 
            -
            ** the application-defined function to be | 
| 4365 | 
            -
            ** bytes and N bytes in size | 
| 4538 | 
            +
            ** ^The sqlite3_result_zeroblob(C,N) and sqlite3_result_zeroblob64(C,N)
         | 
| 4539 | 
            +
            ** interfaces set the result of the application-defined function to be
         | 
| 4540 | 
            +
            ** a BLOB containing all zero bytes and N bytes in size.
         | 
| 4366 4541 | 
             
            **
         | 
| 4367 4542 | 
             
            ** ^The sqlite3_result_double() interface sets the result from
         | 
| 4368 4543 | 
             
            ** an application-defined function to be a floating point value specified
         | 
| @@ -4411,6 +4586,10 @@ typedef void (*sqlite3_destructor_type)(void*); | |
| 4411 4586 | 
             
            ** set the return value of the application-defined function to be
         | 
| 4412 4587 | 
             
            ** a text string which is represented as UTF-8, UTF-16 native byte order,
         | 
| 4413 4588 | 
             
            ** UTF-16 little endian, or UTF-16 big endian, respectively.
         | 
| 4589 | 
            +
            ** ^The sqlite3_result_text64() interface sets the return value of an
         | 
| 4590 | 
            +
            ** application-defined function to be a text string in an encoding
         | 
| 4591 | 
            +
            ** specified by the fifth (and last) parameter, which must be one
         | 
| 4592 | 
            +
            ** of [SQLITE_UTF8], [SQLITE_UTF16], [SQLITE_UTF16BE], or [SQLITE_UTF16LE].
         | 
| 4414 4593 | 
             
            ** ^SQLite takes the text result from the application from
         | 
| 4415 4594 | 
             
            ** the 2nd parameter of the sqlite3_result_text* interfaces.
         | 
| 4416 4595 | 
             
            ** ^If the 3rd parameter to the sqlite3_result_text* interfaces
         | 
| @@ -4440,7 +4619,7 @@ typedef void (*sqlite3_destructor_type)(void*); | |
| 4440 4619 | 
             
            ** from [sqlite3_malloc()] before it returns.
         | 
| 4441 4620 | 
             
            **
         | 
| 4442 4621 | 
             
            ** ^The sqlite3_result_value() interface sets the result of
         | 
| 4443 | 
            -
            ** the application-defined function to be a copy the
         | 
| 4622 | 
            +
            ** the application-defined function to be a copy of the
         | 
| 4444 4623 | 
             
            ** [unprotected sqlite3_value] object specified by the 2nd parameter.  ^The
         | 
| 4445 4624 | 
             
            ** sqlite3_result_value() interface makes a copy of the [sqlite3_value]
         | 
| 4446 4625 | 
             
            ** so that the [sqlite3_value] specified in the parameter may change or
         | 
| @@ -4453,25 +4632,31 @@ typedef void (*sqlite3_destructor_type)(void*); | |
| 4453 4632 | 
             
            ** than the one containing the application-defined function that received
         | 
| 4454 4633 | 
             
            ** the [sqlite3_context] pointer, the results are undefined.
         | 
| 4455 4634 | 
             
            */
         | 
| 4456 | 
            -
            SQLITE_API void sqlite3_result_blob(sqlite3_context*, const void*, int, void(*)(void*));
         | 
| 4457 | 
            -
            SQLITE_API void  | 
| 4458 | 
            -
             | 
| 4459 | 
            -
            SQLITE_API void  | 
| 4460 | 
            -
            SQLITE_API void  | 
| 4461 | 
            -
            SQLITE_API void  | 
| 4462 | 
            -
            SQLITE_API void  | 
| 4463 | 
            -
            SQLITE_API void  | 
| 4464 | 
            -
            SQLITE_API void  | 
| 4465 | 
            -
            SQLITE_API void  | 
| 4466 | 
            -
            SQLITE_API void  | 
| 4467 | 
            -
            SQLITE_API void  | 
| 4468 | 
            -
            SQLITE_API void  | 
| 4469 | 
            -
            SQLITE_API void  | 
| 4470 | 
            -
             | 
| 4471 | 
            -
            SQLITE_API void  | 
| 4635 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_blob(sqlite3_context*, const void*, int, void(*)(void*));
         | 
| 4636 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_blob64(sqlite3_context*,const void*,
         | 
| 4637 | 
            +
                                       sqlite3_uint64,void(*)(void*));
         | 
| 4638 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_double(sqlite3_context*, double);
         | 
| 4639 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_error(sqlite3_context*, const char*, int);
         | 
| 4640 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_error16(sqlite3_context*, const void*, int);
         | 
| 4641 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_error_toobig(sqlite3_context*);
         | 
| 4642 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_error_nomem(sqlite3_context*);
         | 
| 4643 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_error_code(sqlite3_context*, int);
         | 
| 4644 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_int(sqlite3_context*, int);
         | 
| 4645 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_int64(sqlite3_context*, sqlite3_int64);
         | 
| 4646 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_null(sqlite3_context*);
         | 
| 4647 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_text(sqlite3_context*, const char*, int, void(*)(void*));
         | 
| 4648 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_text64(sqlite3_context*, const char*,sqlite3_uint64,
         | 
| 4649 | 
            +
                                       void(*)(void*), unsigned char encoding);
         | 
| 4650 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_text16(sqlite3_context*, const void*, int, void(*)(void*));
         | 
| 4651 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_text16le(sqlite3_context*, const void*, int,void(*)(void*));
         | 
| 4652 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_text16be(sqlite3_context*, const void*, int,void(*)(void*));
         | 
| 4653 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_value(sqlite3_context*, sqlite3_value*);
         | 
| 4654 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_result_zeroblob(sqlite3_context*, int n);
         | 
| 4655 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_result_zeroblob64(sqlite3_context*, sqlite3_uint64 n);
         | 
| 4472 4656 |  | 
| 4473 4657 | 
             
            /*
         | 
| 4474 4658 | 
             
            ** CAPI3REF: Define New Collating Sequences
         | 
| 4659 | 
            +
            ** METHOD: sqlite3
         | 
| 4475 4660 | 
             
            **
         | 
| 4476 4661 | 
             
            ** ^These functions add, remove, or modify a [collation] associated
         | 
| 4477 4662 | 
             
            ** with the [database connection] specified as the first argument.
         | 
| @@ -4549,14 +4734,14 @@ SQLITE_API void sqlite3_result_zeroblob(sqlite3_context*, int n); | |
| 4549 4734 | 
             
            **
         | 
| 4550 4735 | 
             
            ** See also:  [sqlite3_collation_needed()] and [sqlite3_collation_needed16()].
         | 
| 4551 4736 | 
             
            */
         | 
| 4552 | 
            -
            SQLITE_API int sqlite3_create_collation(
         | 
| 4737 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_collation(
         | 
| 4553 4738 | 
             
              sqlite3*, 
         | 
| 4554 4739 | 
             
              const char *zName, 
         | 
| 4555 4740 | 
             
              int eTextRep, 
         | 
| 4556 4741 | 
             
              void *pArg,
         | 
| 4557 4742 | 
             
              int(*xCompare)(void*,int,const void*,int,const void*)
         | 
| 4558 4743 | 
             
            );
         | 
| 4559 | 
            -
            SQLITE_API int sqlite3_create_collation_v2(
         | 
| 4744 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_collation_v2(
         | 
| 4560 4745 | 
             
              sqlite3*, 
         | 
| 4561 4746 | 
             
              const char *zName, 
         | 
| 4562 4747 | 
             
              int eTextRep, 
         | 
| @@ -4564,7 +4749,7 @@ SQLITE_API int sqlite3_create_collation_v2( | |
| 4564 4749 | 
             
              int(*xCompare)(void*,int,const void*,int,const void*),
         | 
| 4565 4750 | 
             
              void(*xDestroy)(void*)
         | 
| 4566 4751 | 
             
            );
         | 
| 4567 | 
            -
            SQLITE_API int sqlite3_create_collation16(
         | 
| 4752 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_collation16(
         | 
| 4568 4753 | 
             
              sqlite3*, 
         | 
| 4569 4754 | 
             
              const void *zName,
         | 
| 4570 4755 | 
             
              int eTextRep, 
         | 
| @@ -4574,6 +4759,7 @@ SQLITE_API int sqlite3_create_collation16( | |
| 4574 4759 |  | 
| 4575 4760 | 
             
            /*
         | 
| 4576 4761 | 
             
            ** CAPI3REF: Collation Needed Callbacks
         | 
| 4762 | 
            +
            ** METHOD: sqlite3
         | 
| 4577 4763 | 
             
            **
         | 
| 4578 4764 | 
             
            ** ^To avoid having to register all collation sequences before a database
         | 
| 4579 4765 | 
             
            ** can be used, a single callback function may be registered with the
         | 
| @@ -4598,12 +4784,12 @@ SQLITE_API int sqlite3_create_collation16( | |
| 4598 4784 | 
             
            ** [sqlite3_create_collation()], [sqlite3_create_collation16()], or
         | 
| 4599 4785 | 
             
            ** [sqlite3_create_collation_v2()].
         | 
| 4600 4786 | 
             
            */
         | 
| 4601 | 
            -
            SQLITE_API int sqlite3_collation_needed(
         | 
| 4787 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_collation_needed(
         | 
| 4602 4788 | 
             
              sqlite3*, 
         | 
| 4603 4789 | 
             
              void*, 
         | 
| 4604 4790 | 
             
              void(*)(void*,sqlite3*,int eTextRep,const char*)
         | 
| 4605 4791 | 
             
            );
         | 
| 4606 | 
            -
            SQLITE_API int sqlite3_collation_needed16(
         | 
| 4792 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_collation_needed16(
         | 
| 4607 4793 | 
             
              sqlite3*, 
         | 
| 4608 4794 | 
             
              void*,
         | 
| 4609 4795 | 
             
              void(*)(void*,sqlite3*,int eTextRep,const void*)
         | 
| @@ -4617,11 +4803,11 @@ SQLITE_API int sqlite3_collation_needed16( | |
| 4617 4803 | 
             
            ** The code to implement this API is not available in the public release
         | 
| 4618 4804 | 
             
            ** of SQLite.
         | 
| 4619 4805 | 
             
            */
         | 
| 4620 | 
            -
            SQLITE_API int sqlite3_key(
         | 
| 4806 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_key(
         | 
| 4621 4807 | 
             
              sqlite3 *db,                   /* Database to be rekeyed */
         | 
| 4622 4808 | 
             
              const void *pKey, int nKey     /* The key */
         | 
| 4623 4809 | 
             
            );
         | 
| 4624 | 
            -
            SQLITE_API int sqlite3_key_v2(
         | 
| 4810 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_key_v2(
         | 
| 4625 4811 | 
             
              sqlite3 *db,                   /* Database to be rekeyed */
         | 
| 4626 4812 | 
             
              const char *zDbName,           /* Name of the database */
         | 
| 4627 4813 | 
             
              const void *pKey, int nKey     /* The key */
         | 
| @@ -4635,11 +4821,11 @@ SQLITE_API int sqlite3_key_v2( | |
| 4635 4821 | 
             
            ** The code to implement this API is not available in the public release
         | 
| 4636 4822 | 
             
            ** of SQLite.
         | 
| 4637 4823 | 
             
            */
         | 
| 4638 | 
            -
            SQLITE_API int sqlite3_rekey(
         | 
| 4824 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_rekey(
         | 
| 4639 4825 | 
             
              sqlite3 *db,                   /* Database to be rekeyed */
         | 
| 4640 4826 | 
             
              const void *pKey, int nKey     /* The new key */
         | 
| 4641 4827 | 
             
            );
         | 
| 4642 | 
            -
            SQLITE_API int sqlite3_rekey_v2(
         | 
| 4828 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_rekey_v2(
         | 
| 4643 4829 | 
             
              sqlite3 *db,                   /* Database to be rekeyed */
         | 
| 4644 4830 | 
             
              const char *zDbName,           /* Name of the database */
         | 
| 4645 4831 | 
             
              const void *pKey, int nKey     /* The new key */
         | 
| @@ -4649,7 +4835,7 @@ SQLITE_API int sqlite3_rekey_v2( | |
| 4649 4835 | 
             
            ** Specify the activation key for a SEE database.  Unless 
         | 
| 4650 4836 | 
             
            ** activated, none of the SEE routines will work.
         | 
| 4651 4837 | 
             
            */
         | 
| 4652 | 
            -
            SQLITE_API void sqlite3_activate_see(
         | 
| 4838 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_activate_see(
         | 
| 4653 4839 | 
             
              const char *zPassPhrase        /* Activation phrase */
         | 
| 4654 4840 | 
             
            );
         | 
| 4655 4841 | 
             
            #endif
         | 
| @@ -4659,7 +4845,7 @@ SQLITE_API void sqlite3_activate_see( | |
| 4659 4845 | 
             
            ** Specify the activation key for a CEROD database.  Unless 
         | 
| 4660 4846 | 
             
            ** activated, none of the CEROD routines will work.
         | 
| 4661 4847 | 
             
            */
         | 
| 4662 | 
            -
            SQLITE_API void sqlite3_activate_cerod(
         | 
| 4848 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_activate_cerod(
         | 
| 4663 4849 | 
             
              const char *zPassPhrase        /* Activation phrase */
         | 
| 4664 4850 | 
             
            );
         | 
| 4665 4851 | 
             
            #endif
         | 
| @@ -4681,7 +4867,7 @@ SQLITE_API void sqlite3_activate_cerod( | |
| 4681 4867 | 
             
            ** all, then the behavior of sqlite3_sleep() may deviate from the description
         | 
| 4682 4868 | 
             
            ** in the previous paragraphs.
         | 
| 4683 4869 | 
             
            */
         | 
| 4684 | 
            -
            SQLITE_API int sqlite3_sleep(int);
         | 
| 4870 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_sleep(int);
         | 
| 4685 4871 |  | 
| 4686 4872 | 
             
            /*
         | 
| 4687 4873 | 
             
            ** CAPI3REF: Name Of The Folder Holding Temporary Files
         | 
| @@ -4781,6 +4967,7 @@ SQLITE_API SQLITE_EXTERN char *sqlite3_data_directory; | |
| 4781 4967 | 
             
            /*
         | 
| 4782 4968 | 
             
            ** CAPI3REF: Test For Auto-Commit Mode
         | 
| 4783 4969 | 
             
            ** KEYWORDS: {autocommit mode}
         | 
| 4970 | 
            +
            ** METHOD: sqlite3
         | 
| 4784 4971 | 
             
            **
         | 
| 4785 4972 | 
             
            ** ^The sqlite3_get_autocommit() interface returns non-zero or
         | 
| 4786 4973 | 
             
            ** zero if the given database connection is or is not in autocommit mode,
         | 
| @@ -4799,10 +4986,11 @@ SQLITE_API SQLITE_EXTERN char *sqlite3_data_directory; | |
| 4799 4986 | 
             
            ** connection while this routine is running, then the return value
         | 
| 4800 4987 | 
             
            ** is undefined.
         | 
| 4801 4988 | 
             
            */
         | 
| 4802 | 
            -
            SQLITE_API int sqlite3_get_autocommit(sqlite3*);
         | 
| 4989 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_get_autocommit(sqlite3*);
         | 
| 4803 4990 |  | 
| 4804 4991 | 
             
            /*
         | 
| 4805 4992 | 
             
            ** CAPI3REF: Find The Database Handle Of A Prepared Statement
         | 
| 4993 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 4806 4994 | 
             
            **
         | 
| 4807 4995 | 
             
            ** ^The sqlite3_db_handle interface returns the [database connection] handle
         | 
| 4808 4996 | 
             
            ** to which a [prepared statement] belongs.  ^The [database connection]
         | 
| @@ -4811,10 +4999,11 @@ SQLITE_API int sqlite3_get_autocommit(sqlite3*); | |
| 4811 4999 | 
             
            ** to the [sqlite3_prepare_v2()] call (or its variants) that was used to
         | 
| 4812 5000 | 
             
            ** create the statement in the first place.
         | 
| 4813 5001 | 
             
            */
         | 
| 4814 | 
            -
            SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt*);
         | 
| 5002 | 
            +
            SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_db_handle(sqlite3_stmt*);
         | 
| 4815 5003 |  | 
| 4816 5004 | 
             
            /*
         | 
| 4817 5005 | 
             
            ** CAPI3REF: Return The Filename For A Database Connection
         | 
| 5006 | 
            +
            ** METHOD: sqlite3
         | 
| 4818 5007 | 
             
            **
         | 
| 4819 5008 | 
             
            ** ^The sqlite3_db_filename(D,N) interface returns a pointer to a filename
         | 
| 4820 5009 | 
             
            ** associated with database N of connection D.  ^The main database file
         | 
| @@ -4827,19 +5016,21 @@ SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt*); | |
| 4827 5016 | 
             
            ** will be an absolute pathname, even if the filename used
         | 
| 4828 5017 | 
             
            ** to open the database originally was a URI or relative pathname.
         | 
| 4829 5018 | 
             
            */
         | 
| 4830 | 
            -
            SQLITE_API const char *sqlite3_db_filename(sqlite3 *db, const char *zDbName);
         | 
| 5019 | 
            +
            SQLITE_API const char *SQLITE_STDCALL sqlite3_db_filename(sqlite3 *db, const char *zDbName);
         | 
| 4831 5020 |  | 
| 4832 5021 | 
             
            /*
         | 
| 4833 5022 | 
             
            ** CAPI3REF: Determine if a database is read-only
         | 
| 5023 | 
            +
            ** METHOD: sqlite3
         | 
| 4834 5024 | 
             
            **
         | 
| 4835 5025 | 
             
            ** ^The sqlite3_db_readonly(D,N) interface returns 1 if the database N
         | 
| 4836 5026 | 
             
            ** of connection D is read-only, 0 if it is read/write, or -1 if N is not
         | 
| 4837 5027 | 
             
            ** the name of a database on connection D.
         | 
| 4838 5028 | 
             
            */
         | 
| 4839 | 
            -
            SQLITE_API int sqlite3_db_readonly(sqlite3 *db, const char *zDbName);
         | 
| 5029 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_db_readonly(sqlite3 *db, const char *zDbName);
         | 
| 4840 5030 |  | 
| 4841 5031 | 
             
            /*
         | 
| 4842 5032 | 
             
            ** CAPI3REF: Find the next prepared statement
         | 
| 5033 | 
            +
            ** METHOD: sqlite3
         | 
| 4843 5034 | 
             
            **
         | 
| 4844 5035 | 
             
            ** ^This interface returns a pointer to the next [prepared statement] after
         | 
| 4845 5036 | 
             
            ** pStmt associated with the [database connection] pDb.  ^If pStmt is NULL
         | 
| @@ -4851,10 +5042,11 @@ SQLITE_API int sqlite3_db_readonly(sqlite3 *db, const char *zDbName); | |
| 4851 5042 | 
             
            ** [sqlite3_next_stmt(D,S)] must refer to an open database
         | 
| 4852 5043 | 
             
            ** connection and in particular must not be a NULL pointer.
         | 
| 4853 5044 | 
             
            */
         | 
| 4854 | 
            -
            SQLITE_API sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt);
         | 
| 5045 | 
            +
            SQLITE_API sqlite3_stmt *SQLITE_STDCALL sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt);
         | 
| 4855 5046 |  | 
| 4856 5047 | 
             
            /*
         | 
| 4857 5048 | 
             
            ** CAPI3REF: Commit And Rollback Notification Callbacks
         | 
| 5049 | 
            +
            ** METHOD: sqlite3
         | 
| 4858 5050 | 
             
            **
         | 
| 4859 5051 | 
             
            ** ^The sqlite3_commit_hook() interface registers a callback
         | 
| 4860 5052 | 
             
            ** function to be invoked whenever a transaction is [COMMIT | committed].
         | 
| @@ -4899,11 +5091,12 @@ SQLITE_API sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt); | |
| 4899 5091 | 
             
            **
         | 
| 4900 5092 | 
             
            ** See also the [sqlite3_update_hook()] interface.
         | 
| 4901 5093 | 
             
            */
         | 
| 4902 | 
            -
            SQLITE_API void *sqlite3_commit_hook(sqlite3*, int(*)(void*), void*);
         | 
| 4903 | 
            -
            SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
         | 
| 5094 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_commit_hook(sqlite3*, int(*)(void*), void*);
         | 
| 5095 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
         | 
| 4904 5096 |  | 
| 4905 5097 | 
             
            /*
         | 
| 4906 5098 | 
             
            ** CAPI3REF: Data Change Notification Callbacks
         | 
| 5099 | 
            +
            ** METHOD: sqlite3
         | 
| 4907 5100 | 
             
            **
         | 
| 4908 5101 | 
             
            ** ^The sqlite3_update_hook() interface registers a callback function
         | 
| 4909 5102 | 
             
            ** with the [database connection] identified by the first argument
         | 
| @@ -4950,7 +5143,7 @@ SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*); | |
| 4950 5143 | 
             
            ** See also the [sqlite3_commit_hook()] and [sqlite3_rollback_hook()]
         | 
| 4951 5144 | 
             
            ** interfaces.
         | 
| 4952 5145 | 
             
            */
         | 
| 4953 | 
            -
            SQLITE_API void *sqlite3_update_hook(
         | 
| 5146 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_update_hook(
         | 
| 4954 5147 | 
             
              sqlite3*, 
         | 
| 4955 5148 | 
             
              void(*)(void *,int ,char const *,char const *,sqlite3_int64),
         | 
| 4956 5149 | 
             
              void*
         | 
| @@ -4980,12 +5173,17 @@ SQLITE_API void *sqlite3_update_hook( | |
| 4980 5173 | 
             
            ** future releases of SQLite.  Applications that care about shared
         | 
| 4981 5174 | 
             
            ** cache setting should set it explicitly.
         | 
| 4982 5175 | 
             
            **
         | 
| 5176 | 
            +
            ** Note: This method is disabled on MacOS X 10.7 and iOS version 5.0
         | 
| 5177 | 
            +
            ** and will always return SQLITE_MISUSE. On those systems, 
         | 
| 5178 | 
            +
            ** shared cache mode should be enabled per-database connection via 
         | 
| 5179 | 
            +
            ** [sqlite3_open_v2()] with [SQLITE_OPEN_SHAREDCACHE].
         | 
| 5180 | 
            +
            **
         | 
| 4983 5181 | 
             
            ** This interface is threadsafe on processors where writing a
         | 
| 4984 5182 | 
             
            ** 32-bit integer is atomic.
         | 
| 4985 5183 | 
             
            **
         | 
| 4986 5184 | 
             
            ** See Also:  [SQLite Shared-Cache Mode]
         | 
| 4987 5185 | 
             
            */
         | 
| 4988 | 
            -
            SQLITE_API int sqlite3_enable_shared_cache(int);
         | 
| 5186 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_enable_shared_cache(int);
         | 
| 4989 5187 |  | 
| 4990 5188 | 
             
            /*
         | 
| 4991 5189 | 
             
            ** CAPI3REF: Attempt To Free Heap Memory
         | 
| @@ -5001,10 +5199,11 @@ SQLITE_API int sqlite3_enable_shared_cache(int); | |
| 5001 5199 | 
             
            **
         | 
| 5002 5200 | 
             
            ** See also: [sqlite3_db_release_memory()]
         | 
| 5003 5201 | 
             
            */
         | 
| 5004 | 
            -
            SQLITE_API int sqlite3_release_memory(int);
         | 
| 5202 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_release_memory(int);
         | 
| 5005 5203 |  | 
| 5006 5204 | 
             
            /*
         | 
| 5007 5205 | 
             
            ** CAPI3REF: Free Memory Used By A Database Connection
         | 
| 5206 | 
            +
            ** METHOD: sqlite3
         | 
| 5008 5207 | 
             
            **
         | 
| 5009 5208 | 
             
            ** ^The sqlite3_db_release_memory(D) interface attempts to free as much heap
         | 
| 5010 5209 | 
             
            ** memory as possible from database connection D. Unlike the
         | 
| @@ -5014,7 +5213,7 @@ SQLITE_API int sqlite3_release_memory(int); | |
| 5014 5213 | 
             
            **
         | 
| 5015 5214 | 
             
            ** See also: [sqlite3_release_memory()]
         | 
| 5016 5215 | 
             
            */
         | 
| 5017 | 
            -
            SQLITE_API int sqlite3_db_release_memory(sqlite3*);
         | 
| 5216 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_db_release_memory(sqlite3*);
         | 
| 5018 5217 |  | 
| 5019 5218 | 
             
            /*
         | 
| 5020 5219 | 
             
            ** CAPI3REF: Impose A Limit On Heap Size
         | 
| @@ -5066,7 +5265,7 @@ SQLITE_API int sqlite3_db_release_memory(sqlite3*); | |
| 5066 5265 | 
             
            ** The circumstances under which SQLite will enforce the soft heap limit may
         | 
| 5067 5266 | 
             
            ** changes in future releases of SQLite.
         | 
| 5068 5267 | 
             
            */
         | 
| 5069 | 
            -
            SQLITE_API sqlite3_int64 sqlite3_soft_heap_limit64(sqlite3_int64 N);
         | 
| 5268 | 
            +
            SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_soft_heap_limit64(sqlite3_int64 N);
         | 
| 5070 5269 |  | 
| 5071 5270 | 
             
            /*
         | 
| 5072 5271 | 
             
            ** CAPI3REF: Deprecated Soft Heap Limit Interface
         | 
| @@ -5077,26 +5276,34 @@ SQLITE_API sqlite3_int64 sqlite3_soft_heap_limit64(sqlite3_int64 N); | |
| 5077 5276 | 
             
            ** only.  All new applications should use the
         | 
| 5078 5277 | 
             
            ** [sqlite3_soft_heap_limit64()] interface rather than this one.
         | 
| 5079 5278 | 
             
            */
         | 
| 5080 | 
            -
            SQLITE_API SQLITE_DEPRECATED void sqlite3_soft_heap_limit(int N);
         | 
| 5279 | 
            +
            SQLITE_API SQLITE_DEPRECATED void SQLITE_STDCALL sqlite3_soft_heap_limit(int N);
         | 
| 5081 5280 |  | 
| 5082 5281 |  | 
| 5083 5282 | 
             
            /*
         | 
| 5084 5283 | 
             
            ** CAPI3REF: Extract Metadata About A Column Of A Table
         | 
| 5085 | 
            -
            **
         | 
| 5086 | 
            -
            ** | 
| 5087 | 
            -
            **  | 
| 5088 | 
            -
            **  | 
| 5284 | 
            +
            ** METHOD: sqlite3
         | 
| 5285 | 
            +
            **
         | 
| 5286 | 
            +
            ** ^(The sqlite3_table_column_metadata(X,D,T,C,....) routine returns
         | 
| 5287 | 
            +
            ** information about column C of table T in database D
         | 
| 5288 | 
            +
            ** on [database connection] X.)^  ^The sqlite3_table_column_metadata()
         | 
| 5289 | 
            +
            ** interface returns SQLITE_OK and fills in the non-NULL pointers in
         | 
| 5290 | 
            +
            ** the final five arguments with appropriate values if the specified
         | 
| 5291 | 
            +
            ** column exists.  ^The sqlite3_table_column_metadata() interface returns
         | 
| 5292 | 
            +
            ** SQLITE_ERROR and if the specified column does not exist.
         | 
| 5293 | 
            +
            ** ^If the column-name parameter to sqlite3_table_column_metadata() is a
         | 
| 5294 | 
            +
            ** NULL pointer, then this routine simply checks for the existance of the
         | 
| 5295 | 
            +
            ** table and returns SQLITE_OK if the table exists and SQLITE_ERROR if it
         | 
| 5296 | 
            +
            ** does not.
         | 
| 5089 5297 | 
             
            **
         | 
| 5090 5298 | 
             
            ** ^The column is identified by the second, third and fourth parameters to
         | 
| 5091 | 
            -
            ** this function. ^The second parameter is either the name of the database
         | 
| 5299 | 
            +
            ** this function. ^(The second parameter is either the name of the database
         | 
| 5092 5300 | 
             
            ** (i.e. "main", "temp", or an attached database) containing the specified
         | 
| 5093 | 
            -
            ** table or NULL. ^If it is NULL, then all attached databases are searched
         | 
| 5301 | 
            +
            ** table or NULL.)^ ^If it is NULL, then all attached databases are searched
         | 
| 5094 5302 | 
             
            ** for the table using the same algorithm used by the database engine to
         | 
| 5095 5303 | 
             
            ** resolve unqualified table references.
         | 
| 5096 5304 | 
             
            **
         | 
| 5097 5305 | 
             
            ** ^The third and fourth parameters to this function are the table and column
         | 
| 5098 | 
            -
            ** name of the desired column, respectively. | 
| 5099 | 
            -
            ** may be NULL.
         | 
| 5306 | 
            +
            ** name of the desired column, respectively.
         | 
| 5100 5307 | 
             
            **
         | 
| 5101 5308 | 
             
            ** ^Metadata is returned by writing to the memory locations passed as the 5th
         | 
| 5102 5309 | 
             
            ** and subsequent parameters to this function. ^Any of these arguments may be
         | 
| @@ -5115,16 +5322,17 @@ SQLITE_API SQLITE_DEPRECATED void sqlite3_soft_heap_limit(int N); | |
| 5115 5322 | 
             
            ** </blockquote>)^
         | 
| 5116 5323 | 
             
            **
         | 
| 5117 5324 | 
             
            ** ^The memory pointed to by the character pointers returned for the
         | 
| 5118 | 
            -
            ** declaration type and collation sequence is valid  | 
| 5325 | 
            +
            ** declaration type and collation sequence is valid until the next
         | 
| 5119 5326 | 
             
            ** call to any SQLite API function.
         | 
| 5120 5327 | 
             
            **
         | 
| 5121 5328 | 
             
            ** ^If the specified table is actually a view, an [error code] is returned.
         | 
| 5122 5329 | 
             
            **
         | 
| 5123 | 
            -
            ** ^If the specified column is "rowid", "oid" or "_rowid_" and  | 
| 5330 | 
            +
            ** ^If the specified column is "rowid", "oid" or "_rowid_" and the table 
         | 
| 5331 | 
            +
            ** is not a [WITHOUT ROWID] table and an
         | 
| 5124 5332 | 
             
            ** [INTEGER PRIMARY KEY] column has been explicitly declared, then the output
         | 
| 5125 5333 | 
             
            ** parameters are set for the explicitly declared column. ^(If there is no
         | 
| 5126 | 
            -
            **  | 
| 5127 | 
            -
            **  | 
| 5334 | 
            +
            ** [INTEGER PRIMARY KEY] column, then the outputs
         | 
| 5335 | 
            +
            ** for the [rowid] are set as follows:
         | 
| 5128 5336 | 
             
            **
         | 
| 5129 5337 | 
             
            ** <pre>
         | 
| 5130 5338 | 
             
            **     data type: "INTEGER"
         | 
| @@ -5134,15 +5342,11 @@ SQLITE_API SQLITE_DEPRECATED void sqlite3_soft_heap_limit(int N); | |
| 5134 5342 | 
             
            **     auto increment: 0
         | 
| 5135 5343 | 
             
            ** </pre>)^
         | 
| 5136 5344 | 
             
            **
         | 
| 5137 | 
            -
            ** ^ | 
| 5138 | 
            -
            **  | 
| 5139 | 
            -
            **  | 
| 5140 | 
            -
            ** in the [database connection] (to be retrieved using sqlite3_errmsg()).)^
         | 
| 5141 | 
            -
            **
         | 
| 5142 | 
            -
            ** ^This API is only available if the library was compiled with the
         | 
| 5143 | 
            -
            ** [SQLITE_ENABLE_COLUMN_METADATA] C-preprocessor symbol defined.
         | 
| 5345 | 
            +
            ** ^This function causes all database schemas to be read from disk and
         | 
| 5346 | 
            +
            ** parsed, if that has not already been done, and returns an error if
         | 
| 5347 | 
            +
            ** any errors are encountered while loading the schema.
         | 
| 5144 5348 | 
             
            */
         | 
| 5145 | 
            -
            SQLITE_API int sqlite3_table_column_metadata(
         | 
| 5349 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_table_column_metadata(
         | 
| 5146 5350 | 
             
              sqlite3 *db,                /* Connection handle */
         | 
| 5147 5351 | 
             
              const char *zDbName,        /* Database name or NULL */
         | 
| 5148 5352 | 
             
              const char *zTableName,     /* Table name */
         | 
| @@ -5156,6 +5360,7 @@ SQLITE_API int sqlite3_table_column_metadata( | |
| 5156 5360 |  | 
| 5157 5361 | 
             
            /*
         | 
| 5158 5362 | 
             
            ** CAPI3REF: Load An Extension
         | 
| 5363 | 
            +
            ** METHOD: sqlite3
         | 
| 5159 5364 | 
             
            **
         | 
| 5160 5365 | 
             
            ** ^This interface loads an SQLite extension library from the named file.
         | 
| 5161 5366 | 
             
            **
         | 
| @@ -5188,7 +5393,7 @@ SQLITE_API int sqlite3_table_column_metadata( | |
| 5188 5393 | 
             
            **
         | 
| 5189 5394 | 
             
            ** See also the [load_extension() SQL function].
         | 
| 5190 5395 | 
             
            */
         | 
| 5191 | 
            -
            SQLITE_API int sqlite3_load_extension(
         | 
| 5396 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_load_extension(
         | 
| 5192 5397 | 
             
              sqlite3 *db,          /* Load the extension into this database connection */
         | 
| 5193 5398 | 
             
              const char *zFile,    /* Name of the shared library containing extension */
         | 
| 5194 5399 | 
             
              const char *zProc,    /* Entry point.  Derived from zFile if 0 */
         | 
| @@ -5197,6 +5402,7 @@ SQLITE_API int sqlite3_load_extension( | |
| 5197 5402 |  | 
| 5198 5403 | 
             
            /*
         | 
| 5199 5404 | 
             
            ** CAPI3REF: Enable Or Disable Extension Loading
         | 
| 5405 | 
            +
            ** METHOD: sqlite3
         | 
| 5200 5406 | 
             
            **
         | 
| 5201 5407 | 
             
            ** ^So as not to open security holes in older applications that are
         | 
| 5202 5408 | 
             
            ** unprepared to deal with [extension loading], and as a means of disabling
         | 
| @@ -5208,7 +5414,7 @@ SQLITE_API int sqlite3_load_extension( | |
| 5208 5414 | 
             
            ** to turn extension loading on and call it with onoff==0 to turn
         | 
| 5209 5415 | 
             
            ** it back off again.
         | 
| 5210 5416 | 
             
            */
         | 
| 5211 | 
            -
            SQLITE_API int sqlite3_enable_load_extension(sqlite3 *db, int onoff);
         | 
| 5417 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_enable_load_extension(sqlite3 *db, int onoff);
         | 
| 5212 5418 |  | 
| 5213 5419 | 
             
            /*
         | 
| 5214 5420 | 
             
            ** CAPI3REF: Automatically Load Statically Linked Extensions
         | 
| @@ -5246,7 +5452,7 @@ SQLITE_API int sqlite3_enable_load_extension(sqlite3 *db, int onoff); | |
| 5246 5452 | 
             
            ** See also: [sqlite3_reset_auto_extension()]
         | 
| 5247 5453 | 
             
            ** and [sqlite3_cancel_auto_extension()]
         | 
| 5248 5454 | 
             
            */
         | 
| 5249 | 
            -
            SQLITE_API int sqlite3_auto_extension(void (*xEntryPoint)(void));
         | 
| 5455 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_auto_extension(void (*xEntryPoint)(void));
         | 
| 5250 5456 |  | 
| 5251 5457 | 
             
            /*
         | 
| 5252 5458 | 
             
            ** CAPI3REF: Cancel Automatic Extension Loading
         | 
| @@ -5258,7 +5464,7 @@ SQLITE_API int sqlite3_auto_extension(void (*xEntryPoint)(void)); | |
| 5258 5464 | 
             
            ** unregistered and it returns 0 if X was not on the list of initialization
         | 
| 5259 5465 | 
             
            ** routines.
         | 
| 5260 5466 | 
             
            */
         | 
| 5261 | 
            -
            SQLITE_API int sqlite3_cancel_auto_extension(void (*xEntryPoint)(void));
         | 
| 5467 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_cancel_auto_extension(void (*xEntryPoint)(void));
         | 
| 5262 5468 |  | 
| 5263 5469 | 
             
            /*
         | 
| 5264 5470 | 
             
            ** CAPI3REF: Reset Automatic Extension Loading
         | 
| @@ -5266,7 +5472,7 @@ SQLITE_API int sqlite3_cancel_auto_extension(void (*xEntryPoint)(void)); | |
| 5266 5472 | 
             
            ** ^This interface disables all automatic extensions previously
         | 
| 5267 5473 | 
             
            ** registered using [sqlite3_auto_extension()].
         | 
| 5268 5474 | 
             
            */
         | 
| 5269 | 
            -
            SQLITE_API void sqlite3_reset_auto_extension(void);
         | 
| 5475 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_reset_auto_extension(void);
         | 
| 5270 5476 |  | 
| 5271 5477 | 
             
            /*
         | 
| 5272 5478 | 
             
            ** The interface to the virtual-table mechanism is currently considered
         | 
| @@ -5446,6 +5652,7 @@ struct sqlite3_index_info { | |
| 5446 5652 |  | 
| 5447 5653 | 
             
            /*
         | 
| 5448 5654 | 
             
            ** CAPI3REF: Register A Virtual Table Implementation
         | 
| 5655 | 
            +
            ** METHOD: sqlite3
         | 
| 5449 5656 | 
             
            **
         | 
| 5450 5657 | 
             
            ** ^These routines are used to register a new [virtual table module] name.
         | 
| 5451 5658 | 
             
            ** ^Module names must be registered before
         | 
| @@ -5469,13 +5676,13 @@ struct sqlite3_index_info { | |
| 5469 5676 | 
             
            ** interface is equivalent to sqlite3_create_module_v2() with a NULL
         | 
| 5470 5677 | 
             
            ** destructor.
         | 
| 5471 5678 | 
             
            */
         | 
| 5472 | 
            -
            SQLITE_API int sqlite3_create_module(
         | 
| 5679 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_module(
         | 
| 5473 5680 | 
             
              sqlite3 *db,               /* SQLite connection to register module with */
         | 
| 5474 5681 | 
             
              const char *zName,         /* Name of the module */
         | 
| 5475 5682 | 
             
              const sqlite3_module *p,   /* Methods for the module */
         | 
| 5476 5683 | 
             
              void *pClientData          /* Client data for xCreate/xConnect */
         | 
| 5477 5684 | 
             
            );
         | 
| 5478 | 
            -
            SQLITE_API int sqlite3_create_module_v2(
         | 
| 5685 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_create_module_v2(
         | 
| 5479 5686 | 
             
              sqlite3 *db,               /* SQLite connection to register module with */
         | 
| 5480 5687 | 
             
              const char *zName,         /* Name of the module */
         | 
| 5481 5688 | 
             
              const sqlite3_module *p,   /* Methods for the module */
         | 
| @@ -5503,7 +5710,7 @@ SQLITE_API int sqlite3_create_module_v2( | |
| 5503 5710 | 
             
            */
         | 
| 5504 5711 | 
             
            struct sqlite3_vtab {
         | 
| 5505 5712 | 
             
              const sqlite3_module *pModule;  /* The module for this virtual table */
         | 
| 5506 | 
            -
              int nRef;                       /*  | 
| 5713 | 
            +
              int nRef;                       /* Number of open cursors */
         | 
| 5507 5714 | 
             
              char *zErrMsg;                  /* Error message from sqlite3_mprintf() */
         | 
| 5508 5715 | 
             
              /* Virtual table implementations will typically add additional fields */
         | 
| 5509 5716 | 
             
            };
         | 
| @@ -5538,10 +5745,11 @@ struct sqlite3_vtab_cursor { | |
| 5538 5745 | 
             
            ** to declare the format (the names and datatypes of the columns) of
         | 
| 5539 5746 | 
             
            ** the virtual tables they implement.
         | 
| 5540 5747 | 
             
            */
         | 
| 5541 | 
            -
            SQLITE_API int sqlite3_declare_vtab(sqlite3*, const char *zSQL);
         | 
| 5748 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_declare_vtab(sqlite3*, const char *zSQL);
         | 
| 5542 5749 |  | 
| 5543 5750 | 
             
            /*
         | 
| 5544 5751 | 
             
            ** CAPI3REF: Overload A Function For A Virtual Table
         | 
| 5752 | 
            +
            ** METHOD: sqlite3
         | 
| 5545 5753 | 
             
            **
         | 
| 5546 5754 | 
             
            ** ^(Virtual tables can provide alternative implementations of functions
         | 
| 5547 5755 | 
             
            ** using the [xFindFunction] method of the [virtual table module].  
         | 
| @@ -5556,7 +5764,7 @@ SQLITE_API int sqlite3_declare_vtab(sqlite3*, const char *zSQL); | |
| 5556 5764 | 
             
            ** purpose is to be a placeholder function that can be overloaded
         | 
| 5557 5765 | 
             
            ** by a [virtual table].
         | 
| 5558 5766 | 
             
            */
         | 
| 5559 | 
            -
            SQLITE_API int sqlite3_overload_function(sqlite3*, const char *zFuncName, int nArg);
         | 
| 5767 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_overload_function(sqlite3*, const char *zFuncName, int nArg);
         | 
| 5560 5768 |  | 
| 5561 5769 | 
             
            /*
         | 
| 5562 5770 | 
             
            ** The interface to the virtual-table mechanism defined above (back up
         | 
| @@ -5584,6 +5792,8 @@ typedef struct sqlite3_blob sqlite3_blob; | |
| 5584 5792 |  | 
| 5585 5793 | 
             
            /*
         | 
| 5586 5794 | 
             
            ** CAPI3REF: Open A BLOB For Incremental I/O
         | 
| 5795 | 
            +
            ** METHOD: sqlite3
         | 
| 5796 | 
            +
            ** CONSTRUCTOR: sqlite3_blob
         | 
| 5587 5797 | 
             
            **
         | 
| 5588 5798 | 
             
            ** ^(This interfaces opens a [BLOB handle | handle] to the BLOB located
         | 
| 5589 5799 | 
             
            ** in row iRow, column zColumn, table zTable in database zDb;
         | 
| @@ -5593,26 +5803,42 @@ typedef struct sqlite3_blob sqlite3_blob; | |
| 5593 5803 | 
             
            **     SELECT zColumn FROM zDb.zTable WHERE [rowid] = iRow;
         | 
| 5594 5804 | 
             
            ** </pre>)^
         | 
| 5595 5805 | 
             
            **
         | 
| 5806 | 
            +
            ** ^(Parameter zDb is not the filename that contains the database, but 
         | 
| 5807 | 
            +
            ** rather the symbolic name of the database. For attached databases, this is
         | 
| 5808 | 
            +
            ** the name that appears after the AS keyword in the [ATTACH] statement.
         | 
| 5809 | 
            +
            ** For the main database file, the database name is "main". For TEMP
         | 
| 5810 | 
            +
            ** tables, the database name is "temp".)^
         | 
| 5811 | 
            +
            **
         | 
| 5596 5812 | 
             
            ** ^If the flags parameter is non-zero, then the BLOB is opened for read
         | 
| 5597 | 
            -
            ** and write access. ^If  | 
| 5598 | 
            -
            **  | 
| 5599 | 
            -
            ** | 
| 5600 | 
            -
            **  | 
| 5601 | 
            -
            **
         | 
| 5602 | 
            -
            **  | 
| 5603 | 
            -
            ** the  | 
| 5604 | 
            -
            **  | 
| 5605 | 
            -
            ** | 
| 5606 | 
            -
            **  | 
| 5607 | 
            -
            **
         | 
| 5608 | 
            -
            ** ^( | 
| 5609 | 
            -
            **  | 
| 5610 | 
            -
            **  | 
| 5611 | 
            -
            ** ^ | 
| 5612 | 
            -
            **  | 
| 5613 | 
            -
            **  | 
| 5614 | 
            -
            **  | 
| 5615 | 
            -
            **  | 
| 5813 | 
            +
            ** and write access. ^If the flags parameter is zero, the BLOB is opened for
         | 
| 5814 | 
            +
            ** read-only access.
         | 
| 5815 | 
            +
            **
         | 
| 5816 | 
            +
            ** ^(On success, [SQLITE_OK] is returned and the new [BLOB handle] is stored
         | 
| 5817 | 
            +
            ** in *ppBlob. Otherwise an [error code] is returned and, unless the error
         | 
| 5818 | 
            +
            ** code is SQLITE_MISUSE, *ppBlob is set to NULL.)^ ^This means that, provided
         | 
| 5819 | 
            +
            ** the API is not misused, it is always safe to call [sqlite3_blob_close()] 
         | 
| 5820 | 
            +
            ** on *ppBlob after this function it returns.
         | 
| 5821 | 
            +
            **
         | 
| 5822 | 
            +
            ** This function fails with SQLITE_ERROR if any of the following are true:
         | 
| 5823 | 
            +
            ** <ul>
         | 
| 5824 | 
            +
            **   <li> ^(Database zDb does not exist)^, 
         | 
| 5825 | 
            +
            **   <li> ^(Table zTable does not exist within database zDb)^, 
         | 
| 5826 | 
            +
            **   <li> ^(Table zTable is a WITHOUT ROWID table)^, 
         | 
| 5827 | 
            +
            **   <li> ^(Column zColumn does not exist)^,
         | 
| 5828 | 
            +
            **   <li> ^(Row iRow is not present in the table)^,
         | 
| 5829 | 
            +
            **   <li> ^(The specified column of row iRow contains a value that is not
         | 
| 5830 | 
            +
            **         a TEXT or BLOB value)^,
         | 
| 5831 | 
            +
            **   <li> ^(Column zColumn is part of an index, PRIMARY KEY or UNIQUE 
         | 
| 5832 | 
            +
            **         constraint and the blob is being opened for read/write access)^,
         | 
| 5833 | 
            +
            **   <li> ^([foreign key constraints | Foreign key constraints] are enabled, 
         | 
| 5834 | 
            +
            **         column zColumn is part of a [child key] definition and the blob is
         | 
| 5835 | 
            +
            **         being opened for read/write access)^.
         | 
| 5836 | 
            +
            ** </ul>
         | 
| 5837 | 
            +
            **
         | 
| 5838 | 
            +
            ** ^Unless it returns SQLITE_MISUSE, this function sets the 
         | 
| 5839 | 
            +
            ** [database connection] error code and message accessible via 
         | 
| 5840 | 
            +
            ** [sqlite3_errcode()] and [sqlite3_errmsg()] and related functions. 
         | 
| 5841 | 
            +
            **
         | 
| 5616 5842 | 
             
            **
         | 
| 5617 5843 | 
             
            ** ^(If the row that a BLOB handle points to is modified by an
         | 
| 5618 5844 | 
             
            ** [UPDATE], [DELETE], or by [ON CONFLICT] side-effects
         | 
| @@ -5630,18 +5856,14 @@ typedef struct sqlite3_blob sqlite3_blob; | |
| 5630 5856 | 
             
            ** interface.  Use the [UPDATE] SQL command to change the size of a
         | 
| 5631 5857 | 
             
            ** blob.
         | 
| 5632 5858 | 
             
            **
         | 
| 5633 | 
            -
            ** ^The [sqlite3_blob_open()] interface will fail for a [WITHOUT ROWID]
         | 
| 5634 | 
            -
            ** table.  Incremental BLOB I/O is not possible on [WITHOUT ROWID] tables.
         | 
| 5635 | 
            -
            **
         | 
| 5636 5859 | 
             
            ** ^The [sqlite3_bind_zeroblob()] and [sqlite3_result_zeroblob()] interfaces
         | 
| 5637 | 
            -
            ** and the built-in [zeroblob] SQL function  | 
| 5638 | 
            -
            **  | 
| 5639 | 
            -
            ** this interface.
         | 
| 5860 | 
            +
            ** and the built-in [zeroblob] SQL function may be used to create a 
         | 
| 5861 | 
            +
            ** zero-filled blob to read or write using the incremental-blob interface.
         | 
| 5640 5862 | 
             
            **
         | 
| 5641 5863 | 
             
            ** To avoid a resource leak, every open [BLOB handle] should eventually
         | 
| 5642 5864 | 
             
            ** be released by a call to [sqlite3_blob_close()].
         | 
| 5643 5865 | 
             
            */
         | 
| 5644 | 
            -
            SQLITE_API int sqlite3_blob_open(
         | 
| 5866 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_open(
         | 
| 5645 5867 | 
             
              sqlite3*,
         | 
| 5646 5868 | 
             
              const char *zDb,
         | 
| 5647 5869 | 
             
              const char *zTable,
         | 
| @@ -5653,6 +5875,7 @@ SQLITE_API int sqlite3_blob_open( | |
| 5653 5875 |  | 
| 5654 5876 | 
             
            /*
         | 
| 5655 5877 | 
             
            ** CAPI3REF: Move a BLOB Handle to a New Row
         | 
| 5878 | 
            +
            ** METHOD: sqlite3_blob
         | 
| 5656 5879 | 
             
            **
         | 
| 5657 5880 | 
             
            ** ^This function is used to move an existing blob handle so that it points
         | 
| 5658 5881 | 
             
            ** to a different row of the same database table. ^The new row is identified
         | 
| @@ -5673,34 +5896,34 @@ SQLITE_API int sqlite3_blob_open( | |
| 5673 5896 | 
             
            **
         | 
| 5674 5897 | 
             
            ** ^This function sets the database handle error code and message.
         | 
| 5675 5898 | 
             
            */
         | 
| 5676 | 
            -
            SQLITE_API  | 
| 5899 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64);
         | 
| 5677 5900 |  | 
| 5678 5901 | 
             
            /*
         | 
| 5679 5902 | 
             
            ** CAPI3REF: Close A BLOB Handle
         | 
| 5903 | 
            +
            ** DESTRUCTOR: sqlite3_blob
         | 
| 5680 5904 | 
             
            **
         | 
| 5681 | 
            -
            ** ^ | 
| 5682 | 
            -
            **
         | 
| 5683 | 
            -
            **  | 
| 5684 | 
            -
            ** if there are no other BLOBs, no pending prepared statements, and the
         | 
| 5685 | 
            -
            ** database connection is in [autocommit mode].
         | 
| 5686 | 
            -
            ** ^If any writes were made to the BLOB, they might be held in cache
         | 
| 5687 | 
            -
            ** until the close operation if they will fit.
         | 
| 5688 | 
            -
            **
         | 
| 5689 | 
            -
            ** ^(Closing the BLOB often forces the changes
         | 
| 5690 | 
            -
            ** out to disk and so if any I/O errors occur, they will likely occur
         | 
| 5691 | 
            -
            ** at the time when the BLOB is closed.  Any errors that occur during
         | 
| 5692 | 
            -
            ** closing are reported as a non-zero return value.)^
         | 
| 5905 | 
            +
            ** ^This function closes an open [BLOB handle]. ^(The BLOB handle is closed
         | 
| 5906 | 
            +
            ** unconditionally.  Even if this routine returns an error code, the 
         | 
| 5907 | 
            +
            ** handle is still closed.)^
         | 
| 5693 5908 | 
             
            **
         | 
| 5694 | 
            -
            ** ^ | 
| 5695 | 
            -
            **  | 
| 5909 | 
            +
            ** ^If the blob handle being closed was opened for read-write access, and if
         | 
| 5910 | 
            +
            ** the database is in auto-commit mode and there are no other open read-write
         | 
| 5911 | 
            +
            ** blob handles or active write statements, the current transaction is
         | 
| 5912 | 
            +
            ** committed. ^If an error occurs while committing the transaction, an error
         | 
| 5913 | 
            +
            ** code is returned and the transaction rolled back.
         | 
| 5696 5914 | 
             
            **
         | 
| 5697 | 
            -
            **  | 
| 5698 | 
            -
            **  | 
| 5915 | 
            +
            ** Calling this function with an argument that is not a NULL pointer or an
         | 
| 5916 | 
            +
            ** open blob handle results in undefined behaviour. ^Calling this routine 
         | 
| 5917 | 
            +
            ** with a null pointer (such as would be returned by a failed call to 
         | 
| 5918 | 
            +
            ** [sqlite3_blob_open()]) is a harmless no-op. ^Otherwise, if this function
         | 
| 5919 | 
            +
            ** is passed a valid open blob handle, the values returned by the 
         | 
| 5920 | 
            +
            ** sqlite3_errcode() and sqlite3_errmsg() functions are set before returning.
         | 
| 5699 5921 | 
             
            */
         | 
| 5700 | 
            -
            SQLITE_API int sqlite3_blob_close(sqlite3_blob *);
         | 
| 5922 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_close(sqlite3_blob *);
         | 
| 5701 5923 |  | 
| 5702 5924 | 
             
            /*
         | 
| 5703 5925 | 
             
            ** CAPI3REF: Return The Size Of An Open BLOB
         | 
| 5926 | 
            +
            ** METHOD: sqlite3_blob
         | 
| 5704 5927 | 
             
            **
         | 
| 5705 5928 | 
             
            ** ^Returns the size in bytes of the BLOB accessible via the 
         | 
| 5706 5929 | 
             
            ** successfully opened [BLOB handle] in its only argument.  ^The
         | 
| @@ -5712,10 +5935,11 @@ SQLITE_API int sqlite3_blob_close(sqlite3_blob *); | |
| 5712 5935 | 
             
            ** been closed by [sqlite3_blob_close()].  Passing any other pointer in
         | 
| 5713 5936 | 
             
            ** to this routine results in undefined and probably undesirable behavior.
         | 
| 5714 5937 | 
             
            */
         | 
| 5715 | 
            -
            SQLITE_API int sqlite3_blob_bytes(sqlite3_blob *);
         | 
| 5938 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_bytes(sqlite3_blob *);
         | 
| 5716 5939 |  | 
| 5717 5940 | 
             
            /*
         | 
| 5718 5941 | 
             
            ** CAPI3REF: Read Data From A BLOB Incrementally
         | 
| 5942 | 
            +
            ** METHOD: sqlite3_blob
         | 
| 5719 5943 | 
             
            **
         | 
| 5720 5944 | 
             
            ** ^(This function is used to read data from an open [BLOB handle] into a
         | 
| 5721 5945 | 
             
            ** caller-supplied buffer. N bytes of data are copied into buffer Z
         | 
| @@ -5740,26 +5964,33 @@ SQLITE_API int sqlite3_blob_bytes(sqlite3_blob *); | |
| 5740 5964 | 
             
            **
         | 
| 5741 5965 | 
             
            ** See also: [sqlite3_blob_write()].
         | 
| 5742 5966 | 
             
            */
         | 
| 5743 | 
            -
            SQLITE_API int sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset);
         | 
| 5967 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset);
         | 
| 5744 5968 |  | 
| 5745 5969 | 
             
            /*
         | 
| 5746 5970 | 
             
            ** CAPI3REF: Write Data Into A BLOB Incrementally
         | 
| 5971 | 
            +
            ** METHOD: sqlite3_blob
         | 
| 5747 5972 | 
             
            **
         | 
| 5748 | 
            -
            ** ^This function is used to write data into an open [BLOB handle] from a
         | 
| 5749 | 
            -
            ** caller-supplied buffer.  | 
| 5750 | 
            -
            ** into the open BLOB, starting at offset iOffset.
         | 
| 5973 | 
            +
            ** ^(This function is used to write data into an open [BLOB handle] from a
         | 
| 5974 | 
            +
            ** caller-supplied buffer. N bytes of data are copied from the buffer Z
         | 
| 5975 | 
            +
            ** into the open BLOB, starting at offset iOffset.)^
         | 
| 5976 | 
            +
            **
         | 
| 5977 | 
            +
            ** ^(On success, sqlite3_blob_write() returns SQLITE_OK.
         | 
| 5978 | 
            +
            ** Otherwise, an  [error code] or an [extended error code] is returned.)^
         | 
| 5979 | 
            +
            ** ^Unless SQLITE_MISUSE is returned, this function sets the 
         | 
| 5980 | 
            +
            ** [database connection] error code and message accessible via 
         | 
| 5981 | 
            +
            ** [sqlite3_errcode()] and [sqlite3_errmsg()] and related functions. 
         | 
| 5751 5982 | 
             
            **
         | 
| 5752 5983 | 
             
            ** ^If the [BLOB handle] passed as the first argument was not opened for
         | 
| 5753 5984 | 
             
            ** writing (the flags parameter to [sqlite3_blob_open()] was zero),
         | 
| 5754 5985 | 
             
            ** this function returns [SQLITE_READONLY].
         | 
| 5755 5986 | 
             
            **
         | 
| 5756 | 
            -
            **  | 
| 5987 | 
            +
            ** This function may only modify the contents of the BLOB; it is
         | 
| 5757 5988 | 
             
            ** not possible to increase the size of a BLOB using this API.
         | 
| 5758 5989 | 
             
            ** ^If offset iOffset is less than N bytes from the end of the BLOB,
         | 
| 5759 | 
            -
            ** [SQLITE_ERROR] is returned and no data is written. | 
| 5760 | 
            -
            **  | 
| 5761 | 
            -
            **  | 
| 5762 | 
            -
            **  | 
| 5990 | 
            +
            ** [SQLITE_ERROR] is returned and no data is written. The size of the 
         | 
| 5991 | 
            +
            ** BLOB (and hence the maximum value of N+iOffset) can be determined 
         | 
| 5992 | 
            +
            ** using the [sqlite3_blob_bytes()] interface. ^If N or iOffset are less 
         | 
| 5993 | 
            +
            ** than zero [SQLITE_ERROR] is returned and no data is written.
         | 
| 5763 5994 | 
             
            **
         | 
| 5764 5995 | 
             
            ** ^An attempt to write to an expired [BLOB handle] fails with an
         | 
| 5765 5996 | 
             
            ** error code of [SQLITE_ABORT].  ^Writes to the BLOB that occurred
         | 
| @@ -5768,9 +5999,6 @@ SQLITE_API int sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset); | |
| 5768 5999 | 
             
            ** have been overwritten by the statement that expired the BLOB handle
         | 
| 5769 6000 | 
             
            ** or by other independent statements.
         | 
| 5770 6001 | 
             
            **
         | 
| 5771 | 
            -
            ** ^(On success, sqlite3_blob_write() returns SQLITE_OK.
         | 
| 5772 | 
            -
            ** Otherwise, an  [error code] or an [extended error code] is returned.)^
         | 
| 5773 | 
            -
            **
         | 
| 5774 6002 | 
             
            ** This routine only works on a [BLOB handle] which has been created
         | 
| 5775 6003 | 
             
            ** by a prior successful call to [sqlite3_blob_open()] and which has not
         | 
| 5776 6004 | 
             
            ** been closed by [sqlite3_blob_close()].  Passing any other pointer in
         | 
| @@ -5778,7 +6006,7 @@ SQLITE_API int sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset); | |
| 5778 6006 | 
             
            **
         | 
| 5779 6007 | 
             
            ** See also: [sqlite3_blob_read()].
         | 
| 5780 6008 | 
             
            */
         | 
| 5781 | 
            -
            SQLITE_API int sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOffset);
         | 
| 6009 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOffset);
         | 
| 5782 6010 |  | 
| 5783 6011 | 
             
            /*
         | 
| 5784 6012 | 
             
            ** CAPI3REF: Virtual File System Objects
         | 
| @@ -5809,9 +6037,9 @@ SQLITE_API int sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOff | |
| 5809 6037 | 
             
            ** ^(If the default VFS is unregistered, another VFS is chosen as
         | 
| 5810 6038 | 
             
            ** the default.  The choice for the new VFS is arbitrary.)^
         | 
| 5811 6039 | 
             
            */
         | 
| 5812 | 
            -
            SQLITE_API sqlite3_vfs *sqlite3_vfs_find(const char *zVfsName);
         | 
| 5813 | 
            -
            SQLITE_API int sqlite3_vfs_register(sqlite3_vfs*, int makeDflt);
         | 
| 5814 | 
            -
            SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*);
         | 
| 6040 | 
            +
            SQLITE_API sqlite3_vfs *SQLITE_STDCALL sqlite3_vfs_find(const char *zVfsName);
         | 
| 6041 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_vfs_register(sqlite3_vfs*, int makeDflt);
         | 
| 6042 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_vfs_unregister(sqlite3_vfs*);
         | 
| 5815 6043 |  | 
| 5816 6044 | 
             
            /*
         | 
| 5817 6045 | 
             
            ** CAPI3REF: Mutexes
         | 
| @@ -5823,34 +6051,34 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5823 6051 | 
             
            **
         | 
| 5824 6052 | 
             
            ** The SQLite source code contains multiple implementations
         | 
| 5825 6053 | 
             
            ** of these mutex routines.  An appropriate implementation
         | 
| 5826 | 
            -
            ** is selected automatically at compile-time.   | 
| 6054 | 
            +
            ** is selected automatically at compile-time.  The following
         | 
| 5827 6055 | 
             
            ** implementations are available in the SQLite core:
         | 
| 5828 6056 | 
             
            **
         | 
| 5829 6057 | 
             
            ** <ul>
         | 
| 5830 6058 | 
             
            ** <li>   SQLITE_MUTEX_PTHREADS
         | 
| 5831 6059 | 
             
            ** <li>   SQLITE_MUTEX_W32
         | 
| 5832 6060 | 
             
            ** <li>   SQLITE_MUTEX_NOOP
         | 
| 5833 | 
            -
            ** </ul> | 
| 6061 | 
            +
            ** </ul>
         | 
| 5834 6062 | 
             
            **
         | 
| 5835 | 
            -
            **  | 
| 6063 | 
            +
            ** The SQLITE_MUTEX_NOOP implementation is a set of routines
         | 
| 5836 6064 | 
             
            ** that does no real locking and is appropriate for use in
         | 
| 5837 | 
            -
            ** a single-threaded application.   | 
| 6065 | 
            +
            ** a single-threaded application.  The SQLITE_MUTEX_PTHREADS and
         | 
| 5838 6066 | 
             
            ** SQLITE_MUTEX_W32 implementations are appropriate for use on Unix
         | 
| 5839 6067 | 
             
            ** and Windows.
         | 
| 5840 6068 | 
             
            **
         | 
| 5841 | 
            -
            **  | 
| 6069 | 
            +
            ** If SQLite is compiled with the SQLITE_MUTEX_APPDEF preprocessor
         | 
| 5842 6070 | 
             
            ** macro defined (with "-DSQLITE_MUTEX_APPDEF=1"), then no mutex
         | 
| 5843 6071 | 
             
            ** implementation is included with the library. In this case the
         | 
| 5844 6072 | 
             
            ** application must supply a custom mutex implementation using the
         | 
| 5845 6073 | 
             
            ** [SQLITE_CONFIG_MUTEX] option of the sqlite3_config() function
         | 
| 5846 6074 | 
             
            ** before calling sqlite3_initialize() or any other public sqlite3_
         | 
| 5847 | 
            -
            ** function that calls sqlite3_initialize(). | 
| 6075 | 
            +
            ** function that calls sqlite3_initialize().
         | 
| 5848 6076 | 
             
            **
         | 
| 5849 6077 | 
             
            ** ^The sqlite3_mutex_alloc() routine allocates a new
         | 
| 5850 | 
            -
            ** mutex and returns a pointer to it. ^ | 
| 5851 | 
            -
            **  | 
| 5852 | 
            -
            **  | 
| 5853 | 
            -
            **  | 
| 6078 | 
            +
            ** mutex and returns a pointer to it. ^The sqlite3_mutex_alloc()
         | 
| 6079 | 
            +
            ** routine returns NULL if it is unable to allocate the requested
         | 
| 6080 | 
            +
            ** mutex.  The argument to sqlite3_mutex_alloc() must one of these
         | 
| 6081 | 
            +
            ** integer constants:
         | 
| 5854 6082 | 
             
            **
         | 
| 5855 6083 | 
             
            ** <ul>
         | 
| 5856 6084 | 
             
            ** <li>  SQLITE_MUTEX_FAST
         | 
| @@ -5863,7 +6091,8 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5863 6091 | 
             
            ** <li>  SQLITE_MUTEX_STATIC_PMEM
         | 
| 5864 6092 | 
             
            ** <li>  SQLITE_MUTEX_STATIC_APP1
         | 
| 5865 6093 | 
             
            ** <li>  SQLITE_MUTEX_STATIC_APP2
         | 
| 5866 | 
            -
            **  | 
| 6094 | 
            +
            ** <li>  SQLITE_MUTEX_STATIC_APP3
         | 
| 6095 | 
            +
            ** </ul>
         | 
| 5867 6096 | 
             
            **
         | 
| 5868 6097 | 
             
            ** ^The first two constants (SQLITE_MUTEX_FAST and SQLITE_MUTEX_RECURSIVE)
         | 
| 5869 6098 | 
             
            ** cause sqlite3_mutex_alloc() to create
         | 
| @@ -5871,14 +6100,14 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5871 6100 | 
             
            ** is used but not necessarily so when SQLITE_MUTEX_FAST is used.
         | 
| 5872 6101 | 
             
            ** The mutex implementation does not need to make a distinction
         | 
| 5873 6102 | 
             
            ** between SQLITE_MUTEX_RECURSIVE and SQLITE_MUTEX_FAST if it does
         | 
| 5874 | 
            -
            ** not want to.   | 
| 5875 | 
            -
            ** cases where it really needs one.   | 
| 6103 | 
            +
            ** not want to.  SQLite will only request a recursive mutex in
         | 
| 6104 | 
            +
            ** cases where it really needs one.  If a faster non-recursive mutex
         | 
| 5876 6105 | 
             
            ** implementation is available on the host platform, the mutex subsystem
         | 
| 5877 6106 | 
             
            ** might return such a mutex in response to SQLITE_MUTEX_FAST.
         | 
| 5878 6107 | 
             
            **
         | 
| 5879 6108 | 
             
            ** ^The other allowed parameters to sqlite3_mutex_alloc() (anything other
         | 
| 5880 6109 | 
             
            ** than SQLITE_MUTEX_FAST and SQLITE_MUTEX_RECURSIVE) each return
         | 
| 5881 | 
            -
            ** a pointer to a static preexisting mutex.  ^ | 
| 6110 | 
            +
            ** a pointer to a static preexisting mutex.  ^Nine static mutexes are
         | 
| 5882 6111 | 
             
            ** used by the current version of SQLite.  Future versions of SQLite
         | 
| 5883 6112 | 
             
            ** may add additional static mutexes.  Static mutexes are for internal
         | 
| 5884 6113 | 
             
            ** use by SQLite only.  Applications that use SQLite mutexes should
         | 
| @@ -5887,16 +6116,13 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5887 6116 | 
             
            **
         | 
| 5888 6117 | 
             
            ** ^Note that if one of the dynamic mutex parameters (SQLITE_MUTEX_FAST
         | 
| 5889 6118 | 
             
            ** or SQLITE_MUTEX_RECURSIVE) is used then sqlite3_mutex_alloc()
         | 
| 5890 | 
            -
            ** returns a different mutex on every call.  ^ | 
| 6119 | 
            +
            ** returns a different mutex on every call.  ^For the static
         | 
| 5891 6120 | 
             
            ** mutex types, the same mutex is returned on every call that has
         | 
| 5892 6121 | 
             
            ** the same type number.
         | 
| 5893 6122 | 
             
            **
         | 
| 5894 6123 | 
             
            ** ^The sqlite3_mutex_free() routine deallocates a previously
         | 
| 5895 | 
            -
            ** allocated dynamic mutex.   | 
| 5896 | 
            -
            **  | 
| 5897 | 
            -
            ** use when they are deallocated.  Attempting to deallocate a static
         | 
| 5898 | 
            -
            ** mutex results in undefined behavior.  ^SQLite never deallocates
         | 
| 5899 | 
            -
            ** a static mutex.
         | 
| 6124 | 
            +
            ** allocated dynamic mutex.  Attempting to deallocate a static
         | 
| 6125 | 
            +
            ** mutex results in undefined behavior.
         | 
| 5900 6126 | 
             
            **
         | 
| 5901 6127 | 
             
            ** ^The sqlite3_mutex_enter() and sqlite3_mutex_try() routines attempt
         | 
| 5902 6128 | 
             
            ** to enter a mutex.  ^If another thread is already within the mutex,
         | 
| @@ -5904,23 +6130,21 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5904 6130 | 
             
            ** SQLITE_BUSY.  ^The sqlite3_mutex_try() interface returns [SQLITE_OK]
         | 
| 5905 6131 | 
             
            ** upon successful entry.  ^(Mutexes created using
         | 
| 5906 6132 | 
             
            ** SQLITE_MUTEX_RECURSIVE can be entered multiple times by the same thread.
         | 
| 5907 | 
            -
            ** In such cases the | 
| 6133 | 
            +
            ** In such cases, the
         | 
| 5908 6134 | 
             
            ** mutex must be exited an equal number of times before another thread
         | 
| 5909 | 
            -
            ** can enter.)^   | 
| 5910 | 
            -
            **  | 
| 5911 | 
            -
            ** SQLite will never exhibit
         | 
| 5912 | 
            -
            ** such behavior in its own use of mutexes.)^
         | 
| 6135 | 
            +
            ** can enter.)^  If the same thread tries to enter any mutex other
         | 
| 6136 | 
            +
            ** than an SQLITE_MUTEX_RECURSIVE more than once, the behavior is undefined.
         | 
| 5913 6137 | 
             
            **
         | 
| 5914 6138 | 
             
            ** ^(Some systems (for example, Windows 95) do not support the operation
         | 
| 5915 6139 | 
             
            ** implemented by sqlite3_mutex_try().  On those systems, sqlite3_mutex_try()
         | 
| 5916 | 
            -
            ** will always return SQLITE_BUSY. | 
| 5917 | 
            -
            ** sqlite3_mutex_try() as an optimization so this is acceptable  | 
| 6140 | 
            +
            ** will always return SQLITE_BUSY. The SQLite core only ever uses
         | 
| 6141 | 
            +
            ** sqlite3_mutex_try() as an optimization so this is acceptable 
         | 
| 6142 | 
            +
            ** behavior.)^
         | 
| 5918 6143 | 
             
            **
         | 
| 5919 6144 | 
             
            ** ^The sqlite3_mutex_leave() routine exits a mutex that was
         | 
| 5920 | 
            -
            ** previously entered by the same thread.    | 
| 6145 | 
            +
            ** previously entered by the same thread.   The behavior
         | 
| 5921 6146 | 
             
            ** is undefined if the mutex is not currently entered by the
         | 
| 5922 | 
            -
            ** calling thread or is not currently allocated. | 
| 5923 | 
            -
            ** never do either.)^
         | 
| 6147 | 
            +
            ** calling thread or is not currently allocated.
         | 
| 5924 6148 | 
             
            **
         | 
| 5925 6149 | 
             
            ** ^If the argument to sqlite3_mutex_enter(), sqlite3_mutex_try(), or
         | 
| 5926 6150 | 
             
            ** sqlite3_mutex_leave() is a NULL pointer, then all three routines
         | 
| @@ -5928,11 +6152,11 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*); | |
| 5928 6152 | 
             
            **
         | 
| 5929 6153 | 
             
            ** See also: [sqlite3_mutex_held()] and [sqlite3_mutex_notheld()].
         | 
| 5930 6154 | 
             
            */
         | 
| 5931 | 
            -
            SQLITE_API sqlite3_mutex *sqlite3_mutex_alloc(int);
         | 
| 5932 | 
            -
            SQLITE_API void sqlite3_mutex_free(sqlite3_mutex*);
         | 
| 5933 | 
            -
            SQLITE_API void sqlite3_mutex_enter(sqlite3_mutex*);
         | 
| 5934 | 
            -
            SQLITE_API int sqlite3_mutex_try(sqlite3_mutex*);
         | 
| 5935 | 
            -
            SQLITE_API void sqlite3_mutex_leave(sqlite3_mutex*);
         | 
| 6155 | 
            +
            SQLITE_API sqlite3_mutex *SQLITE_STDCALL sqlite3_mutex_alloc(int);
         | 
| 6156 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_mutex_free(sqlite3_mutex*);
         | 
| 6157 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_mutex_enter(sqlite3_mutex*);
         | 
| 6158 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_mutex_try(sqlite3_mutex*);
         | 
| 6159 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_mutex_leave(sqlite3_mutex*);
         | 
| 5936 6160 |  | 
| 5937 6161 | 
             
            /*
         | 
| 5938 6162 | 
             
            ** CAPI3REF: Mutex Methods Object
         | 
| @@ -5941,9 +6165,9 @@ SQLITE_API void sqlite3_mutex_leave(sqlite3_mutex*); | |
| 5941 6165 | 
             
            ** used to allocate and use mutexes.
         | 
| 5942 6166 | 
             
            **
         | 
| 5943 6167 | 
             
            ** Usually, the default mutex implementations provided by SQLite are
         | 
| 5944 | 
            -
            ** sufficient, however the  | 
| 6168 | 
            +
            ** sufficient, however the application has the option of substituting a custom
         | 
| 5945 6169 | 
             
            ** implementation for specialized deployments or systems for which SQLite
         | 
| 5946 | 
            -
            ** does not provide a suitable implementation. In this case, the  | 
| 6170 | 
            +
            ** does not provide a suitable implementation. In this case, the application
         | 
| 5947 6171 | 
             
            ** creates and populates an instance of this structure to pass
         | 
| 5948 6172 | 
             
            ** to sqlite3_config() along with the [SQLITE_CONFIG_MUTEX] option.
         | 
| 5949 6173 | 
             
            ** Additionally, an instance of this structure can be used as an
         | 
| @@ -5984,13 +6208,13 @@ SQLITE_API void sqlite3_mutex_leave(sqlite3_mutex*); | |
| 5984 6208 | 
             
            ** (i.e. it is acceptable to provide an implementation that segfaults if
         | 
| 5985 6209 | 
             
            ** it is passed a NULL pointer).
         | 
| 5986 6210 | 
             
            **
         | 
| 5987 | 
            -
            ** The xMutexInit() method must be threadsafe.   | 
| 6211 | 
            +
            ** The xMutexInit() method must be threadsafe.  It must be harmless to
         | 
| 5988 6212 | 
             
            ** invoke xMutexInit() multiple times within the same process and without
         | 
| 5989 6213 | 
             
            ** intervening calls to xMutexEnd().  Second and subsequent calls to
         | 
| 5990 6214 | 
             
            ** xMutexInit() must be no-ops.
         | 
| 5991 6215 | 
             
            **
         | 
| 5992 | 
            -
            **  | 
| 5993 | 
            -
            ** and its associates).   | 
| 6216 | 
            +
            ** xMutexInit() must not use SQLite memory allocation ([sqlite3_malloc()]
         | 
| 6217 | 
            +
            ** and its associates).  Similarly, xMutexAlloc() must not use SQLite memory
         | 
| 5994 6218 | 
             
            ** allocation for a static mutex.  ^However xMutexAlloc() may use SQLite
         | 
| 5995 6219 | 
             
            ** memory allocation for a fast or recursive mutex.
         | 
| 5996 6220 | 
             
            **
         | 
| @@ -6016,34 +6240,34 @@ struct sqlite3_mutex_methods { | |
| 6016 6240 | 
             
            ** CAPI3REF: Mutex Verification Routines
         | 
| 6017 6241 | 
             
            **
         | 
| 6018 6242 | 
             
            ** The sqlite3_mutex_held() and sqlite3_mutex_notheld() routines
         | 
| 6019 | 
            -
            ** are intended for use inside assert() statements.   | 
| 6243 | 
            +
            ** are intended for use inside assert() statements.  The SQLite core
         | 
| 6020 6244 | 
             
            ** never uses these routines except inside an assert() and applications
         | 
| 6021 | 
            -
            ** are advised to follow the lead of the core.   | 
| 6245 | 
            +
            ** are advised to follow the lead of the core.  The SQLite core only
         | 
| 6022 6246 | 
             
            ** provides implementations for these routines when it is compiled
         | 
| 6023 | 
            -
            ** with the SQLITE_DEBUG flag.   | 
| 6247 | 
            +
            ** with the SQLITE_DEBUG flag.  External mutex implementations
         | 
| 6024 6248 | 
             
            ** are only required to provide these routines if SQLITE_DEBUG is
         | 
| 6025 6249 | 
             
            ** defined and if NDEBUG is not defined.
         | 
| 6026 6250 | 
             
            **
         | 
| 6027 | 
            -
            **  | 
| 6251 | 
            +
            ** These routines should return true if the mutex in their argument
         | 
| 6028 6252 | 
             
            ** is held or not held, respectively, by the calling thread.
         | 
| 6029 6253 | 
             
            **
         | 
| 6030 | 
            -
            **  | 
| 6254 | 
            +
            ** The implementation is not required to provide versions of these
         | 
| 6031 6255 | 
             
            ** routines that actually work. If the implementation does not provide working
         | 
| 6032 6256 | 
             
            ** versions of these routines, it should at least provide stubs that always
         | 
| 6033 6257 | 
             
            ** return true so that one does not get spurious assertion failures.
         | 
| 6034 6258 | 
             
            **
         | 
| 6035 | 
            -
            **  | 
| 6259 | 
            +
            ** If the argument to sqlite3_mutex_held() is a NULL pointer then
         | 
| 6036 6260 | 
             
            ** the routine should return 1.   This seems counter-intuitive since
         | 
| 6037 6261 | 
             
            ** clearly the mutex cannot be held if it does not exist.  But
         | 
| 6038 6262 | 
             
            ** the reason the mutex does not exist is because the build is not
         | 
| 6039 6263 | 
             
            ** using mutexes.  And we do not want the assert() containing the
         | 
| 6040 6264 | 
             
            ** call to sqlite3_mutex_held() to fail, so a non-zero return is
         | 
| 6041 | 
            -
            ** the appropriate thing to do.   | 
| 6265 | 
            +
            ** the appropriate thing to do.  The sqlite3_mutex_notheld()
         | 
| 6042 6266 | 
             
            ** interface should also return 1 when given a NULL pointer.
         | 
| 6043 6267 | 
             
            */
         | 
| 6044 6268 | 
             
            #ifndef NDEBUG
         | 
| 6045 | 
            -
            SQLITE_API int sqlite3_mutex_held(sqlite3_mutex*);
         | 
| 6046 | 
            -
            SQLITE_API int sqlite3_mutex_notheld(sqlite3_mutex*);
         | 
| 6269 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_mutex_held(sqlite3_mutex*);
         | 
| 6270 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_mutex_notheld(sqlite3_mutex*);
         | 
| 6047 6271 | 
             
            #endif
         | 
| 6048 6272 |  | 
| 6049 6273 | 
             
            /*
         | 
| @@ -6069,9 +6293,13 @@ SQLITE_API int sqlite3_mutex_notheld(sqlite3_mutex*); | |
| 6069 6293 | 
             
            #define SQLITE_MUTEX_STATIC_APP1      8  /* For use by application */
         | 
| 6070 6294 | 
             
            #define SQLITE_MUTEX_STATIC_APP2      9  /* For use by application */
         | 
| 6071 6295 | 
             
            #define SQLITE_MUTEX_STATIC_APP3     10  /* For use by application */
         | 
| 6296 | 
            +
            #define SQLITE_MUTEX_STATIC_VFS1     11  /* For use by built-in VFS */
         | 
| 6297 | 
            +
            #define SQLITE_MUTEX_STATIC_VFS2     12  /* For use by extension VFS */
         | 
| 6298 | 
            +
            #define SQLITE_MUTEX_STATIC_VFS3     13  /* For use by application VFS */
         | 
| 6072 6299 |  | 
| 6073 6300 | 
             
            /*
         | 
| 6074 6301 | 
             
            ** CAPI3REF: Retrieve the mutex for a database connection
         | 
| 6302 | 
            +
            ** METHOD: sqlite3
         | 
| 6075 6303 | 
             
            **
         | 
| 6076 6304 | 
             
            ** ^This interface returns a pointer the [sqlite3_mutex] object that 
         | 
| 6077 6305 | 
             
            ** serializes access to the [database connection] given in the argument
         | 
| @@ -6079,10 +6307,11 @@ SQLITE_API int sqlite3_mutex_notheld(sqlite3_mutex*); | |
| 6079 6307 | 
             
            ** ^If the [threading mode] is Single-thread or Multi-thread then this
         | 
| 6080 6308 | 
             
            ** routine returns a NULL pointer.
         | 
| 6081 6309 | 
             
            */
         | 
| 6082 | 
            -
            SQLITE_API sqlite3_mutex *sqlite3_db_mutex(sqlite3*);
         | 
| 6310 | 
            +
            SQLITE_API sqlite3_mutex *SQLITE_STDCALL sqlite3_db_mutex(sqlite3*);
         | 
| 6083 6311 |  | 
| 6084 6312 | 
             
            /*
         | 
| 6085 6313 | 
             
            ** CAPI3REF: Low-Level Control Of Database Files
         | 
| 6314 | 
            +
            ** METHOD: sqlite3
         | 
| 6086 6315 | 
             
            **
         | 
| 6087 6316 | 
             
            ** ^The [sqlite3_file_control()] interface makes a direct call to the
         | 
| 6088 6317 | 
             
            ** xFileControl method for the [sqlite3_io_methods] object associated
         | 
| @@ -6113,7 +6342,7 @@ SQLITE_API sqlite3_mutex *sqlite3_db_mutex(sqlite3*); | |
| 6113 6342 | 
             
            **
         | 
| 6114 6343 | 
             
            ** See also: [SQLITE_FCNTL_LOCKSTATE]
         | 
| 6115 6344 | 
             
            */
         | 
| 6116 | 
            -
            SQLITE_API int sqlite3_file_control(sqlite3*, const char *zDbName, int op, void*);
         | 
| 6345 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_file_control(sqlite3*, const char *zDbName, int op, void*);
         | 
| 6117 6346 |  | 
| 6118 6347 | 
             
            /*
         | 
| 6119 6348 | 
             
            ** CAPI3REF: Testing Interface
         | 
| @@ -6132,7 +6361,7 @@ SQLITE_API int sqlite3_file_control(sqlite3*, const char *zDbName, int op, void* | |
| 6132 6361 | 
             
            ** Unlike most of the SQLite API, this function is not guaranteed to
         | 
| 6133 6362 | 
             
            ** operate consistently from one release to the next.
         | 
| 6134 6363 | 
             
            */
         | 
| 6135 | 
            -
            SQLITE_API int sqlite3_test_control(int op, ...);
         | 
| 6364 | 
            +
            SQLITE_API int SQLITE_CDECL sqlite3_test_control(int op, ...);
         | 
| 6136 6365 |  | 
| 6137 6366 | 
             
            /*
         | 
| 6138 6367 | 
             
            ** CAPI3REF: Testing Interface Operation Codes
         | 
| @@ -6160,17 +6389,19 @@ SQLITE_API int sqlite3_test_control(int op, ...); | |
| 6160 6389 | 
             
            #define SQLITE_TESTCTRL_ISKEYWORD               16
         | 
| 6161 6390 | 
             
            #define SQLITE_TESTCTRL_SCRATCHMALLOC           17
         | 
| 6162 6391 | 
             
            #define SQLITE_TESTCTRL_LOCALTIME_FAULT         18
         | 
| 6163 | 
            -
            #define SQLITE_TESTCTRL_EXPLAIN_STMT            19
         | 
| 6392 | 
            +
            #define SQLITE_TESTCTRL_EXPLAIN_STMT            19  /* NOT USED */
         | 
| 6164 6393 | 
             
            #define SQLITE_TESTCTRL_NEVER_CORRUPT           20
         | 
| 6165 6394 | 
             
            #define SQLITE_TESTCTRL_VDBE_COVERAGE           21
         | 
| 6166 6395 | 
             
            #define SQLITE_TESTCTRL_BYTEORDER               22
         | 
| 6167 6396 | 
             
            #define SQLITE_TESTCTRL_ISINIT                  23
         | 
| 6168 | 
            -
            #define  | 
| 6397 | 
            +
            #define SQLITE_TESTCTRL_SORTER_MMAP             24
         | 
| 6398 | 
            +
            #define SQLITE_TESTCTRL_IMPOSTER                25
         | 
| 6399 | 
            +
            #define SQLITE_TESTCTRL_LAST                    25
         | 
| 6169 6400 |  | 
| 6170 6401 | 
             
            /*
         | 
| 6171 6402 | 
             
            ** CAPI3REF: SQLite Runtime Status
         | 
| 6172 6403 | 
             
            **
         | 
| 6173 | 
            -
            ** ^ | 
| 6404 | 
            +
            ** ^These interfaces are used to retrieve runtime status information
         | 
| 6174 6405 | 
             
            ** about the performance of SQLite, and optionally to reset various
         | 
| 6175 6406 | 
             
            ** highwater marks.  ^The first argument is an integer code for
         | 
| 6176 6407 | 
             
            ** the specific parameter to measure.  ^(Recognized integer codes
         | 
| @@ -6184,19 +6415,22 @@ SQLITE_API int sqlite3_test_control(int op, ...); | |
| 6184 6415 | 
             
            ** ^(Other parameters record only the highwater mark and not the current
         | 
| 6185 6416 | 
             
            ** value.  For these latter parameters nothing is written into *pCurrent.)^
         | 
| 6186 6417 | 
             
            **
         | 
| 6187 | 
            -
            ** ^The sqlite3_status()  | 
| 6188 | 
            -
            ** non-zero [error code] on failure.
         | 
| 6418 | 
            +
            ** ^The sqlite3_status() and sqlite3_status64() routines return
         | 
| 6419 | 
            +
            ** SQLITE_OK on success and a non-zero [error code] on failure.
         | 
| 6189 6420 | 
             
            **
         | 
| 6190 | 
            -
            **  | 
| 6191 | 
            -
            **  | 
| 6192 | 
            -
            **  | 
| 6193 | 
            -
            ** *pHighwater reflect the status of SQLite at different points in time
         | 
| 6194 | 
            -
            ** and it is possible that another thread might change the parameter
         | 
| 6195 | 
            -
            ** in between the times when *pCurrent and *pHighwater are written.
         | 
| 6421 | 
            +
            ** If either the current value or the highwater mark is too large to
         | 
| 6422 | 
            +
            ** be represented by a 32-bit integer, then the values returned by
         | 
| 6423 | 
            +
            ** sqlite3_status() are undefined.
         | 
| 6196 6424 | 
             
            **
         | 
| 6197 6425 | 
             
            ** See also: [sqlite3_db_status()]
         | 
| 6198 6426 | 
             
            */
         | 
| 6199 | 
            -
            SQLITE_API int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag);
         | 
| 6427 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag);
         | 
| 6428 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_status64(
         | 
| 6429 | 
            +
              int op,
         | 
| 6430 | 
            +
              sqlite3_int64 *pCurrent,
         | 
| 6431 | 
            +
              sqlite3_int64 *pHighwater,
         | 
| 6432 | 
            +
              int resetFlag
         | 
| 6433 | 
            +
            );
         | 
| 6200 6434 |  | 
| 6201 6435 |  | 
| 6202 6436 | 
             
            /*
         | 
| @@ -6294,6 +6528,7 @@ SQLITE_API int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetF | |
| 6294 6528 |  | 
| 6295 6529 | 
             
            /*
         | 
| 6296 6530 | 
             
            ** CAPI3REF: Database Connection Status
         | 
| 6531 | 
            +
            ** METHOD: sqlite3
         | 
| 6297 6532 | 
             
            **
         | 
| 6298 6533 | 
             
            ** ^This interface is used to retrieve runtime status information 
         | 
| 6299 6534 | 
             
            ** about a single [database connection].  ^The first argument is the
         | 
| @@ -6314,7 +6549,7 @@ SQLITE_API int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetF | |
| 6314 6549 | 
             
            **
         | 
| 6315 6550 | 
             
            ** See also: [sqlite3_status()] and [sqlite3_stmt_status()].
         | 
| 6316 6551 | 
             
            */
         | 
| 6317 | 
            -
            SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int resetFlg);
         | 
| 6552 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int resetFlg);
         | 
| 6318 6553 |  | 
| 6319 6554 | 
             
            /*
         | 
| 6320 6555 | 
             
            ** CAPI3REF: Status Parameters for database connections
         | 
| @@ -6356,12 +6591,12 @@ SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int r | |
| 6356 6591 | 
             
            ** the current value is always zero.)^
         | 
| 6357 6592 | 
             
            **
         | 
| 6358 6593 | 
             
            ** [[SQLITE_DBSTATUS_CACHE_USED]] ^(<dt>SQLITE_DBSTATUS_CACHE_USED</dt>
         | 
| 6359 | 
            -
            ** <dd>This parameter returns the approximate number of  | 
| 6594 | 
            +
            ** <dd>This parameter returns the approximate number of bytes of heap
         | 
| 6360 6595 | 
             
            ** memory used by all pager caches associated with the database connection.)^
         | 
| 6361 6596 | 
             
            ** ^The highwater mark associated with SQLITE_DBSTATUS_CACHE_USED is always 0.
         | 
| 6362 6597 | 
             
            **
         | 
| 6363 6598 | 
             
            ** [[SQLITE_DBSTATUS_SCHEMA_USED]] ^(<dt>SQLITE_DBSTATUS_SCHEMA_USED</dt>
         | 
| 6364 | 
            -
            ** <dd>This parameter returns the approximate number of  | 
| 6599 | 
            +
            ** <dd>This parameter returns the approximate number of bytes of heap
         | 
| 6365 6600 | 
             
            ** memory used to store the schema for all databases associated
         | 
| 6366 6601 | 
             
            ** with the connection - main, temp, and any [ATTACH]-ed databases.)^ 
         | 
| 6367 6602 | 
             
            ** ^The full amount of memory used by the schemas is reported, even if the
         | 
| @@ -6370,7 +6605,7 @@ SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int r | |
| 6370 6605 | 
             
            ** ^The highwater mark associated with SQLITE_DBSTATUS_SCHEMA_USED is always 0.
         | 
| 6371 6606 | 
             
            **
         | 
| 6372 6607 | 
             
            ** [[SQLITE_DBSTATUS_STMT_USED]] ^(<dt>SQLITE_DBSTATUS_STMT_USED</dt>
         | 
| 6373 | 
            -
            ** <dd>This parameter returns the approximate number of  | 
| 6608 | 
            +
            ** <dd>This parameter returns the approximate number of bytes of heap
         | 
| 6374 6609 | 
             
            ** and lookaside memory used by all prepared statements associated with
         | 
| 6375 6610 | 
             
            ** the database connection.)^
         | 
| 6376 6611 | 
             
            ** ^The highwater mark associated with SQLITE_DBSTATUS_STMT_USED is always 0.
         | 
| @@ -6422,6 +6657,7 @@ SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int r | |
| 6422 6657 |  | 
| 6423 6658 | 
             
            /*
         | 
| 6424 6659 | 
             
            ** CAPI3REF: Prepared Statement Status
         | 
| 6660 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 6425 6661 | 
             
            **
         | 
| 6426 6662 | 
             
            ** ^(Each prepared statement maintains various
         | 
| 6427 6663 | 
             
            ** [SQLITE_STMTSTATUS counters] that measure the number
         | 
| @@ -6443,7 +6679,7 @@ SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int r | |
| 6443 6679 | 
             
            **
         | 
| 6444 6680 | 
             
            ** See also: [sqlite3_status()] and [sqlite3_db_status()].
         | 
| 6445 6681 | 
             
            */
         | 
| 6446 | 
            -
            SQLITE_API int sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
         | 
| 6682 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
         | 
| 6447 6683 |  | 
| 6448 6684 | 
             
            /*
         | 
| 6449 6685 | 
             
            ** CAPI3REF: Status Parameters for prepared statements
         | 
| @@ -6770,6 +7006,10 @@ typedef struct sqlite3_backup sqlite3_backup; | |
| 6770 7006 | 
             
            ** must be different or else sqlite3_backup_init(D,N,S,M) will fail with
         | 
| 6771 7007 | 
             
            ** an error.
         | 
| 6772 7008 | 
             
            **
         | 
| 7009 | 
            +
            ** ^A call to sqlite3_backup_init() will fail, returning SQLITE_ERROR, if 
         | 
| 7010 | 
            +
            ** there is already a read or read-write transaction open on the 
         | 
| 7011 | 
            +
            ** destination database.
         | 
| 7012 | 
            +
            **
         | 
| 6773 7013 | 
             
            ** ^If an error occurs within sqlite3_backup_init(D,N,S,M), then NULL is
         | 
| 6774 7014 | 
             
            ** returned and an error code and error message are stored in the
         | 
| 6775 7015 | 
             
            ** destination [database connection] D.
         | 
| @@ -6862,20 +7102,20 @@ typedef struct sqlite3_backup sqlite3_backup; | |
| 6862 7102 | 
             
            ** is not a permanent error and does not affect the return value of
         | 
| 6863 7103 | 
             
            ** sqlite3_backup_finish().
         | 
| 6864 7104 | 
             
            **
         | 
| 6865 | 
            -
            ** [[ | 
| 7105 | 
            +
            ** [[sqlite3_backup_remaining()]] [[sqlite3_backup_pagecount()]]
         | 
| 6866 7106 | 
             
            ** <b>sqlite3_backup_remaining() and sqlite3_backup_pagecount()</b>
         | 
| 6867 7107 | 
             
            **
         | 
| 6868 | 
            -
            ** ^ | 
| 6869 | 
            -
            **  | 
| 6870 | 
            -
            **  | 
| 6871 | 
            -
            **  | 
| 6872 | 
            -
            **  | 
| 6873 | 
            -
            **
         | 
| 6874 | 
            -
            **  | 
| 6875 | 
            -
            **  | 
| 6876 | 
            -
            **  | 
| 6877 | 
            -
            **  | 
| 6878 | 
            -
            **  | 
| 7108 | 
            +
            ** ^The sqlite3_backup_remaining() routine returns the number of pages still
         | 
| 7109 | 
            +
            ** to be backed up at the conclusion of the most recent sqlite3_backup_step().
         | 
| 7110 | 
            +
            ** ^The sqlite3_backup_pagecount() routine returns the total number of pages
         | 
| 7111 | 
            +
            ** in the source database at the conclusion of the most recent
         | 
| 7112 | 
            +
            ** sqlite3_backup_step().
         | 
| 7113 | 
            +
            ** ^(The values returned by these functions are only updated by
         | 
| 7114 | 
            +
            ** sqlite3_backup_step(). If the source database is modified in a way that
         | 
| 7115 | 
            +
            ** changes the size of the source database or the number of pages remaining,
         | 
| 7116 | 
            +
            ** those changes are not reflected in the output of sqlite3_backup_pagecount()
         | 
| 7117 | 
            +
            ** and sqlite3_backup_remaining() until after the next
         | 
| 7118 | 
            +
            ** sqlite3_backup_step().)^
         | 
| 6879 7119 | 
             
            **
         | 
| 6880 7120 | 
             
            ** <b>Concurrent Usage of Database Handles</b>
         | 
| 6881 7121 | 
             
            **
         | 
| @@ -6908,19 +7148,20 @@ typedef struct sqlite3_backup sqlite3_backup; | |
| 6908 7148 | 
             
            ** same time as another thread is invoking sqlite3_backup_step() it is
         | 
| 6909 7149 | 
             
            ** possible that they return invalid values.
         | 
| 6910 7150 | 
             
            */
         | 
| 6911 | 
            -
            SQLITE_API sqlite3_backup *sqlite3_backup_init(
         | 
| 7151 | 
            +
            SQLITE_API sqlite3_backup *SQLITE_STDCALL sqlite3_backup_init(
         | 
| 6912 7152 | 
             
              sqlite3 *pDest,                        /* Destination database handle */
         | 
| 6913 7153 | 
             
              const char *zDestName,                 /* Destination database name */
         | 
| 6914 7154 | 
             
              sqlite3 *pSource,                      /* Source database handle */
         | 
| 6915 7155 | 
             
              const char *zSourceName                /* Source database name */
         | 
| 6916 7156 | 
             
            );
         | 
| 6917 | 
            -
            SQLITE_API int sqlite3_backup_step(sqlite3_backup *p, int nPage);
         | 
| 6918 | 
            -
            SQLITE_API int sqlite3_backup_finish(sqlite3_backup *p);
         | 
| 6919 | 
            -
            SQLITE_API int sqlite3_backup_remaining(sqlite3_backup *p);
         | 
| 6920 | 
            -
            SQLITE_API int sqlite3_backup_pagecount(sqlite3_backup *p);
         | 
| 7157 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_backup_step(sqlite3_backup *p, int nPage);
         | 
| 7158 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_backup_finish(sqlite3_backup *p);
         | 
| 7159 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_backup_remaining(sqlite3_backup *p);
         | 
| 7160 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_backup_pagecount(sqlite3_backup *p);
         | 
| 6921 7161 |  | 
| 6922 7162 | 
             
            /*
         | 
| 6923 7163 | 
             
            ** CAPI3REF: Unlock Notification
         | 
| 7164 | 
            +
            ** METHOD: sqlite3
         | 
| 6924 7165 | 
             
            **
         | 
| 6925 7166 | 
             
            ** ^When running in shared-cache mode, a database operation may fail with
         | 
| 6926 7167 | 
             
            ** an [SQLITE_LOCKED] error if the required locks on the shared-cache or
         | 
| @@ -7033,7 +7274,7 @@ SQLITE_API int sqlite3_backup_pagecount(sqlite3_backup *p); | |
| 7033 7274 | 
             
            ** the special "DROP TABLE/INDEX" case, the extended error code is just 
         | 
| 7034 7275 | 
             
            ** SQLITE_LOCKED.)^
         | 
| 7035 7276 | 
             
            */
         | 
| 7036 | 
            -
            SQLITE_API int sqlite3_unlock_notify(
         | 
| 7277 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_unlock_notify(
         | 
| 7037 7278 | 
             
              sqlite3 *pBlocked,                          /* Waiting connection */
         | 
| 7038 7279 | 
             
              void (*xNotify)(void **apArg, int nArg),    /* Callback function to invoke */
         | 
| 7039 7280 | 
             
              void *pNotifyArg                            /* Argument to pass to xNotify */
         | 
| @@ -7048,8 +7289,8 @@ SQLITE_API int sqlite3_unlock_notify( | |
| 7048 7289 | 
             
            ** strings in a case-independent fashion, using the same definition of "case
         | 
| 7049 7290 | 
             
            ** independence" that SQLite uses internally when comparing identifiers.
         | 
| 7050 7291 | 
             
            */
         | 
| 7051 | 
            -
            SQLITE_API int sqlite3_stricmp(const char *, const char *);
         | 
| 7052 | 
            -
            SQLITE_API int sqlite3_strnicmp(const char *, const char *, int);
         | 
| 7292 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_stricmp(const char *, const char *);
         | 
| 7293 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_strnicmp(const char *, const char *, int);
         | 
| 7053 7294 |  | 
| 7054 7295 | 
             
            /*
         | 
| 7055 7296 | 
             
            ** CAPI3REF: String Globbing
         | 
| @@ -7064,7 +7305,7 @@ SQLITE_API int sqlite3_strnicmp(const char *, const char *, int); | |
| 7064 7305 | 
             
            ** Note that this routine returns zero on a match and non-zero if the strings
         | 
| 7065 7306 | 
             
            ** do not match, the same as [sqlite3_stricmp()] and [sqlite3_strnicmp()].
         | 
| 7066 7307 | 
             
            */
         | 
| 7067 | 
            -
            SQLITE_API int sqlite3_strglob(const char *zGlob, const char *zStr);
         | 
| 7308 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_strglob(const char *zGlob, const char *zStr);
         | 
| 7068 7309 |  | 
| 7069 7310 | 
             
            /*
         | 
| 7070 7311 | 
             
            ** CAPI3REF: Error Logging Interface
         | 
| @@ -7087,18 +7328,17 @@ SQLITE_API int sqlite3_strglob(const char *zGlob, const char *zStr); | |
| 7087 7328 | 
             
            ** a few hundred characters, it will be truncated to the length of the
         | 
| 7088 7329 | 
             
            ** buffer.
         | 
| 7089 7330 | 
             
            */
         | 
| 7090 | 
            -
            SQLITE_API void sqlite3_log(int iErrCode, const char *zFormat, ...);
         | 
| 7331 | 
            +
            SQLITE_API void SQLITE_CDECL sqlite3_log(int iErrCode, const char *zFormat, ...);
         | 
| 7091 7332 |  | 
| 7092 7333 | 
             
            /*
         | 
| 7093 7334 | 
             
            ** CAPI3REF: Write-Ahead Log Commit Hook
         | 
| 7335 | 
            +
            ** METHOD: sqlite3
         | 
| 7094 7336 | 
             
            **
         | 
| 7095 7337 | 
             
            ** ^The [sqlite3_wal_hook()] function is used to register a callback that
         | 
| 7096 | 
            -
            **  | 
| 7097 | 
            -
            ** [write-ahead log] (i.e. whenever a transaction is committed in
         | 
| 7098 | 
            -
            ** [journal_mode | journal_mode=WAL mode]). 
         | 
| 7338 | 
            +
            ** is invoked each time data is committed to a database in wal mode.
         | 
| 7099 7339 | 
             
            **
         | 
| 7100 | 
            -
            ** ^The callback is invoked by SQLite after the commit has taken place and 
         | 
| 7101 | 
            -
            ** the associated write-lock on the database released | 
| 7340 | 
            +
            ** ^(The callback is invoked by SQLite after the commit has taken place and 
         | 
| 7341 | 
            +
            ** the associated write-lock on the database released)^, so the implementation 
         | 
| 7102 7342 | 
             
            ** may read, write or [checkpoint] the database as required.
         | 
| 7103 7343 | 
             
            **
         | 
| 7104 7344 | 
             
            ** ^The first parameter passed to the callback function when it is invoked
         | 
| @@ -7124,7 +7364,7 @@ SQLITE_API void sqlite3_log(int iErrCode, const char *zFormat, ...); | |
| 7124 7364 | 
             
            ** [wal_autocheckpoint pragma] both invoke [sqlite3_wal_hook()] and will
         | 
| 7125 7365 | 
             
            ** those overwrite any prior [sqlite3_wal_hook()] settings.
         | 
| 7126 7366 | 
             
            */
         | 
| 7127 | 
            -
            SQLITE_API void *sqlite3_wal_hook(
         | 
| 7367 | 
            +
            SQLITE_API void *SQLITE_STDCALL sqlite3_wal_hook(
         | 
| 7128 7368 | 
             
              sqlite3*, 
         | 
| 7129 7369 | 
             
              int(*)(void *,sqlite3*,const char*,int),
         | 
| 7130 7370 | 
             
              void*
         | 
| @@ -7132,6 +7372,7 @@ SQLITE_API void *sqlite3_wal_hook( | |
| 7132 7372 |  | 
| 7133 7373 | 
             
            /*
         | 
| 7134 7374 | 
             
            ** CAPI3REF: Configure an auto-checkpoint
         | 
| 7375 | 
            +
            ** METHOD: sqlite3
         | 
| 7135 7376 | 
             
            **
         | 
| 7136 7377 | 
             
            ** ^The [sqlite3_wal_autocheckpoint(D,N)] is a wrapper around
         | 
| 7137 7378 | 
             
            ** [sqlite3_wal_hook()] that causes any database on [database connection] D
         | 
| @@ -7158,104 +7399,123 @@ SQLITE_API void *sqlite3_wal_hook( | |
| 7158 7399 | 
             
            ** is only necessary if the default setting is found to be suboptimal
         | 
| 7159 7400 | 
             
            ** for a particular application.
         | 
| 7160 7401 | 
             
            */
         | 
| 7161 | 
            -
            SQLITE_API int sqlite3_wal_autocheckpoint(sqlite3 *db, int N);
         | 
| 7402 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_wal_autocheckpoint(sqlite3 *db, int N);
         | 
| 7162 7403 |  | 
| 7163 7404 | 
             
            /*
         | 
| 7164 7405 | 
             
            ** CAPI3REF: Checkpoint a database
         | 
| 7406 | 
            +
            ** METHOD: sqlite3
         | 
| 7165 7407 | 
             
            **
         | 
| 7166 | 
            -
            ** ^The  | 
| 7167 | 
            -
            **  | 
| 7168 | 
            -
            ** empty string, then a checkpoint is run on all databases of
         | 
| 7169 | 
            -
            ** connection D.  ^If the database connection D is not in
         | 
| 7170 | 
            -
            ** [WAL | write-ahead log mode] then this interface is a harmless no-op.
         | 
| 7171 | 
            -
            ** ^The [sqlite3_wal_checkpoint(D,X)] interface initiates a
         | 
| 7172 | 
            -
            ** [sqlite3_wal_checkpoint_v2|PASSIVE] checkpoint.
         | 
| 7173 | 
            -
            ** Use the [sqlite3_wal_checkpoint_v2()] interface to get a FULL
         | 
| 7174 | 
            -
            ** or RESET checkpoint.
         | 
| 7408 | 
            +
            ** ^(The sqlite3_wal_checkpoint(D,X) is equivalent to
         | 
| 7409 | 
            +
            ** [sqlite3_wal_checkpoint_v2](D,X,[SQLITE_CHECKPOINT_PASSIVE],0,0).)^
         | 
| 7175 7410 | 
             
            **
         | 
| 7176 | 
            -
            **  | 
| 7177 | 
            -
            **  | 
| 7178 | 
            -
            **  | 
| 7179 | 
            -
            **  | 
| 7411 | 
            +
            ** In brief, sqlite3_wal_checkpoint(D,X) causes the content in the 
         | 
| 7412 | 
            +
            ** [write-ahead log] for database X on [database connection] D to be
         | 
| 7413 | 
            +
            ** transferred into the database file and for the write-ahead log to
         | 
| 7414 | 
            +
            ** be reset.  See the [checkpointing] documentation for addition
         | 
| 7415 | 
            +
            ** information.
         | 
| 7180 7416 | 
             
            **
         | 
| 7181 | 
            -
            **  | 
| 7417 | 
            +
            ** This interface used to be the only way to cause a checkpoint to
         | 
| 7418 | 
            +
            ** occur.  But then the newer and more powerful [sqlite3_wal_checkpoint_v2()]
         | 
| 7419 | 
            +
            ** interface was added.  This interface is retained for backwards
         | 
| 7420 | 
            +
            ** compatibility and as a convenience for applications that need to manually
         | 
| 7421 | 
            +
            ** start a callback but which do not need the full power (and corresponding
         | 
| 7422 | 
            +
            ** complication) of [sqlite3_wal_checkpoint_v2()].
         | 
| 7182 7423 | 
             
            */
         | 
| 7183 | 
            -
            SQLITE_API int sqlite3_wal_checkpoint(sqlite3 *db, const char *zDb);
         | 
| 7424 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_wal_checkpoint(sqlite3 *db, const char *zDb);
         | 
| 7184 7425 |  | 
| 7185 7426 | 
             
            /*
         | 
| 7186 7427 | 
             
            ** CAPI3REF: Checkpoint a database
         | 
| 7428 | 
            +
            ** METHOD: sqlite3
         | 
| 7187 7429 | 
             
            **
         | 
| 7188 | 
            -
            **  | 
| 7189 | 
            -
            **  | 
| 7190 | 
            -
            **  | 
| 7430 | 
            +
            ** ^(The sqlite3_wal_checkpoint_v2(D,X,M,L,C) interface runs a checkpoint
         | 
| 7431 | 
            +
            ** operation on database X of [database connection] D in mode M.  Status
         | 
| 7432 | 
            +
            ** information is written back into integers pointed to by L and C.)^
         | 
| 7433 | 
            +
            ** ^(The M parameter must be a valid [checkpoint mode]:)^
         | 
| 7191 7434 | 
             
            **
         | 
| 7192 7435 | 
             
            ** <dl>
         | 
| 7193 7436 | 
             
            ** <dt>SQLITE_CHECKPOINT_PASSIVE<dd>
         | 
| 7194 | 
            -
            **   Checkpoint as many frames as possible without waiting for any database 
         | 
| 7195 | 
            -
            **   readers or writers to finish | 
| 7196 | 
            -
            **    | 
| 7197 | 
            -
            **    | 
| 7198 | 
            -
            **    | 
| 7437 | 
            +
            **   ^Checkpoint as many frames as possible without waiting for any database 
         | 
| 7438 | 
            +
            **   readers or writers to finish, then sync the database file if all frames 
         | 
| 7439 | 
            +
            **   in the log were checkpointed. ^The [busy-handler callback]
         | 
| 7440 | 
            +
            **   is never invoked in the SQLITE_CHECKPOINT_PASSIVE mode.  
         | 
| 7441 | 
            +
            **   ^On the other hand, passive mode might leave the checkpoint unfinished
         | 
| 7442 | 
            +
            **   if there are concurrent readers or writers.
         | 
| 7199 7443 | 
             
            **
         | 
| 7200 7444 | 
             
            ** <dt>SQLITE_CHECKPOINT_FULL<dd>
         | 
| 7201 | 
            -
            **   This mode blocks (it invokes the
         | 
| 7445 | 
            +
            **   ^This mode blocks (it invokes the
         | 
| 7202 7446 | 
             
            **   [sqlite3_busy_handler|busy-handler callback]) until there is no
         | 
| 7203 7447 | 
             
            **   database writer and all readers are reading from the most recent database
         | 
| 7204 | 
            -
            **   snapshot. It then checkpoints all frames in the log file and syncs the
         | 
| 7205 | 
            -
            **   database file. This  | 
| 7206 | 
            -
            **   but  | 
| 7448 | 
            +
            **   snapshot. ^It then checkpoints all frames in the log file and syncs the
         | 
| 7449 | 
            +
            **   database file. ^This mode blocks new database writers while it is pending,
         | 
| 7450 | 
            +
            **   but new database readers are allowed to continue unimpeded.
         | 
| 7207 7451 | 
             
            **
         | 
| 7208 7452 | 
             
            ** <dt>SQLITE_CHECKPOINT_RESTART<dd>
         | 
| 7209 | 
            -
            **   This mode works the same way as SQLITE_CHECKPOINT_FULL | 
| 7210 | 
            -
            **   checkpointing the log file it blocks (calls the 
         | 
| 7211 | 
            -
            **   [ | 
| 7212 | 
            -
            **   until all readers are reading from the database file only. This ensures 
         | 
| 7213 | 
            -
            **   that the next  | 
| 7214 | 
            -
            **    | 
| 7215 | 
            -
            **   but not  | 
| 7453 | 
            +
            **   ^This mode works the same way as SQLITE_CHECKPOINT_FULL with the addition
         | 
| 7454 | 
            +
            **   that after checkpointing the log file it blocks (calls the 
         | 
| 7455 | 
            +
            **   [busy-handler callback])
         | 
| 7456 | 
            +
            **   until all readers are reading from the database file only. ^This ensures 
         | 
| 7457 | 
            +
            **   that the next writer will restart the log file from the beginning.
         | 
| 7458 | 
            +
            **   ^Like SQLITE_CHECKPOINT_FULL, this mode blocks new
         | 
| 7459 | 
            +
            **   database writer attempts while it is pending, but does not impede readers.
         | 
| 7460 | 
            +
            **
         | 
| 7461 | 
            +
            ** <dt>SQLITE_CHECKPOINT_TRUNCATE<dd>
         | 
| 7462 | 
            +
            **   ^This mode works the same way as SQLITE_CHECKPOINT_RESTART with the
         | 
| 7463 | 
            +
            **   addition that it also truncates the log file to zero bytes just prior
         | 
| 7464 | 
            +
            **   to a successful return.
         | 
| 7216 7465 | 
             
            ** </dl>
         | 
| 7217 7466 | 
             
            **
         | 
| 7218 | 
            -
            ** If pnLog is not NULL, then *pnLog is set to the total number of frames in
         | 
| 7219 | 
            -
            ** the log file  | 
| 7220 | 
            -
            ** the  | 
| 7221 | 
            -
            **  | 
| 7222 | 
            -
            **  | 
| 7223 | 
            -
            **  | 
| 7224 | 
            -
            **  | 
| 7225 | 
            -
            **
         | 
| 7226 | 
            -
            **  | 
| 7467 | 
            +
            ** ^If pnLog is not NULL, then *pnLog is set to the total number of frames in
         | 
| 7468 | 
            +
            ** the log file or to -1 if the checkpoint could not run because
         | 
| 7469 | 
            +
            ** of an error or because the database is not in [WAL mode]. ^If pnCkpt is not
         | 
| 7470 | 
            +
            ** NULL,then *pnCkpt is set to the total number of checkpointed frames in the
         | 
| 7471 | 
            +
            ** log file (including any that were already checkpointed before the function
         | 
| 7472 | 
            +
            ** was called) or to -1 if the checkpoint could not run due to an error or
         | 
| 7473 | 
            +
            ** because the database is not in WAL mode. ^Note that upon successful
         | 
| 7474 | 
            +
            ** completion of an SQLITE_CHECKPOINT_TRUNCATE, the log file will have been
         | 
| 7475 | 
            +
            ** truncated to zero bytes and so both *pnLog and *pnCkpt will be set to zero.
         | 
| 7476 | 
            +
            **
         | 
| 7477 | 
            +
            ** ^All calls obtain an exclusive "checkpoint" lock on the database file. ^If
         | 
| 7227 7478 | 
             
            ** any other process is running a checkpoint operation at the same time, the 
         | 
| 7228 | 
            -
            ** lock cannot be obtained and SQLITE_BUSY is returned. Even if there is a 
         | 
| 7479 | 
            +
            ** lock cannot be obtained and SQLITE_BUSY is returned. ^Even if there is a 
         | 
| 7229 7480 | 
             
            ** busy-handler configured, it will not be invoked in this case.
         | 
| 7230 7481 | 
             
            **
         | 
| 7231 | 
            -
            ** The SQLITE_CHECKPOINT_FULL and  | 
| 7232 | 
            -
            ** "writer" lock on the database file. If the writer lock cannot be | 
| 7233 | 
            -
            ** immediately, and a busy-handler is configured, it is invoked and | 
| 7234 | 
            -
            ** lock retried until either the busy-handler returns 0 or the lock | 
| 7235 | 
            -
            ** successfully obtained. The busy-handler is also invoked while waiting for
         | 
| 7236 | 
            -
            ** database readers as described above. If the busy-handler returns 0 before
         | 
| 7482 | 
            +
            ** ^The SQLITE_CHECKPOINT_FULL, RESTART and TRUNCATE modes also obtain the 
         | 
| 7483 | 
            +
            ** exclusive "writer" lock on the database file. ^If the writer lock cannot be
         | 
| 7484 | 
            +
            ** obtained immediately, and a busy-handler is configured, it is invoked and
         | 
| 7485 | 
            +
            ** the writer lock retried until either the busy-handler returns 0 or the lock
         | 
| 7486 | 
            +
            ** is successfully obtained. ^The busy-handler is also invoked while waiting for
         | 
| 7487 | 
            +
            ** database readers as described above. ^If the busy-handler returns 0 before
         | 
| 7237 7488 | 
             
            ** the writer lock is obtained or while waiting for database readers, the
         | 
| 7238 7489 | 
             
            ** checkpoint operation proceeds from that point in the same way as 
         | 
| 7239 7490 | 
             
            ** SQLITE_CHECKPOINT_PASSIVE - checkpointing as many frames as possible 
         | 
| 7240 | 
            -
            ** without blocking any further. SQLITE_BUSY is returned in this case.
         | 
| 7491 | 
            +
            ** without blocking any further. ^SQLITE_BUSY is returned in this case.
         | 
| 7241 7492 | 
             
            **
         | 
| 7242 | 
            -
            ** If parameter zDb is NULL or points to a zero length string, then the
         | 
| 7243 | 
            -
            ** specified operation is attempted on all WAL databases | 
| 7244 | 
            -
            **  | 
| 7493 | 
            +
            ** ^If parameter zDb is NULL or points to a zero length string, then the
         | 
| 7494 | 
            +
            ** specified operation is attempted on all WAL databases [attached] to 
         | 
| 7495 | 
            +
            ** [database connection] db.  In this case the
         | 
| 7496 | 
            +
            ** values written to output parameters *pnLog and *pnCkpt are undefined. ^If 
         | 
| 7245 7497 | 
             
            ** an SQLITE_BUSY error is encountered when processing one or more of the 
         | 
| 7246 7498 | 
             
            ** attached WAL databases, the operation is still attempted on any remaining 
         | 
| 7247 | 
            -
            ** attached databases and SQLITE_BUSY is returned  | 
| 7499 | 
            +
            ** attached databases and SQLITE_BUSY is returned at the end. ^If any other 
         | 
| 7248 7500 | 
             
            ** error occurs while processing an attached database, processing is abandoned 
         | 
| 7249 | 
            -
            ** and the error code returned to the caller immediately. If no error 
         | 
| 7501 | 
            +
            ** and the error code is returned to the caller immediately. ^If no error 
         | 
| 7250 7502 | 
             
            ** (SQLITE_BUSY or otherwise) is encountered while processing the attached 
         | 
| 7251 7503 | 
             
            ** databases, SQLITE_OK is returned.
         | 
| 7252 7504 | 
             
            **
         | 
| 7253 | 
            -
            ** If database zDb is the name of an attached database that is not in WAL
         | 
| 7254 | 
            -
            ** mode, SQLITE_OK is returned and both *pnLog and *pnCkpt set to -1. If
         | 
| 7505 | 
            +
            ** ^If database zDb is the name of an attached database that is not in WAL
         | 
| 7506 | 
            +
            ** mode, SQLITE_OK is returned and both *pnLog and *pnCkpt set to -1. ^If
         | 
| 7255 7507 | 
             
            ** zDb is not NULL (or a zero length string) and is not the name of any
         | 
| 7256 7508 | 
             
            ** attached database, SQLITE_ERROR is returned to the caller.
         | 
| 7509 | 
            +
            **
         | 
| 7510 | 
            +
            ** ^Unless it returns SQLITE_MISUSE,
         | 
| 7511 | 
            +
            ** the sqlite3_wal_checkpoint_v2() interface
         | 
| 7512 | 
            +
            ** sets the error information that is queried by
         | 
| 7513 | 
            +
            ** [sqlite3_errcode()] and [sqlite3_errmsg()].
         | 
| 7514 | 
            +
            **
         | 
| 7515 | 
            +
            ** ^The [PRAGMA wal_checkpoint] command can be used to invoke this interface
         | 
| 7516 | 
            +
            ** from SQL.
         | 
| 7257 7517 | 
             
            */
         | 
| 7258 | 
            -
            SQLITE_API int sqlite3_wal_checkpoint_v2(
         | 
| 7518 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_wal_checkpoint_v2(
         | 
| 7259 7519 | 
             
              sqlite3 *db,                    /* Database handle */
         | 
| 7260 7520 | 
             
              const char *zDb,                /* Name of attached database (or NULL) */
         | 
| 7261 7521 | 
             
              int eMode,                      /* SQLITE_CHECKPOINT_* value */
         | 
| @@ -7264,16 +7524,18 @@ SQLITE_API int sqlite3_wal_checkpoint_v2( | |
| 7264 7524 | 
             
            );
         | 
| 7265 7525 |  | 
| 7266 7526 | 
             
            /*
         | 
| 7267 | 
            -
            ** CAPI3REF: Checkpoint  | 
| 7527 | 
            +
            ** CAPI3REF: Checkpoint Mode Values
         | 
| 7528 | 
            +
            ** KEYWORDS: {checkpoint mode}
         | 
| 7268 7529 | 
             
            **
         | 
| 7269 | 
            -
            ** These constants  | 
| 7270 | 
            -
            **  | 
| 7271 | 
            -
            ** documentation for  | 
| 7272 | 
            -
            ** each of these  | 
| 7530 | 
            +
            ** These constants define all valid values for the "checkpoint mode" passed
         | 
| 7531 | 
            +
            ** as the third parameter to the [sqlite3_wal_checkpoint_v2()] interface.
         | 
| 7532 | 
            +
            ** See the [sqlite3_wal_checkpoint_v2()] documentation for details on the
         | 
| 7533 | 
            +
            ** meaning of each of these checkpoint modes.
         | 
| 7273 7534 | 
             
            */
         | 
| 7274 | 
            -
            #define SQLITE_CHECKPOINT_PASSIVE  | 
| 7275 | 
            -
            #define SQLITE_CHECKPOINT_FULL | 
| 7276 | 
            -
            #define SQLITE_CHECKPOINT_RESTART  | 
| 7535 | 
            +
            #define SQLITE_CHECKPOINT_PASSIVE  0  /* Do as much as possible w/o blocking */
         | 
| 7536 | 
            +
            #define SQLITE_CHECKPOINT_FULL     1  /* Wait for writers, then checkpoint */
         | 
| 7537 | 
            +
            #define SQLITE_CHECKPOINT_RESTART  2  /* Like FULL but wait for for readers */
         | 
| 7538 | 
            +
            #define SQLITE_CHECKPOINT_TRUNCATE 3  /* Like RESTART but also truncate WAL */
         | 
| 7277 7539 |  | 
| 7278 7540 | 
             
            /*
         | 
| 7279 7541 | 
             
            ** CAPI3REF: Virtual Table Interface Configuration
         | 
| @@ -7289,7 +7551,7 @@ SQLITE_API int sqlite3_wal_checkpoint_v2( | |
| 7289 7551 | 
             
            ** this function. (See [SQLITE_VTAB_CONSTRAINT_SUPPORT].)  Further options
         | 
| 7290 7552 | 
             
            ** may be added in the future.
         | 
| 7291 7553 | 
             
            */
         | 
| 7292 | 
            -
            SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...);
         | 
| 7554 | 
            +
            SQLITE_API int SQLITE_CDECL sqlite3_vtab_config(sqlite3*, int op, ...);
         | 
| 7293 7555 |  | 
| 7294 7556 | 
             
            /*
         | 
| 7295 7557 | 
             
            ** CAPI3REF: Virtual Table Configuration Options
         | 
| @@ -7342,7 +7604,7 @@ SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...); | |
| 7342 7604 | 
             
            ** of the SQL statement that triggered the call to the [xUpdate] method of the
         | 
| 7343 7605 | 
             
            ** [virtual table].
         | 
| 7344 7606 | 
             
            */
         | 
| 7345 | 
            -
            SQLITE_API int sqlite3_vtab_on_conflict(sqlite3 *);
         | 
| 7607 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_vtab_on_conflict(sqlite3 *);
         | 
| 7346 7608 |  | 
| 7347 7609 | 
             
            /*
         | 
| 7348 7610 | 
             
            ** CAPI3REF: Conflict resolution modes
         | 
| @@ -7362,6 +7624,108 @@ SQLITE_API int sqlite3_vtab_on_conflict(sqlite3 *); | |
| 7362 7624 | 
             
            /* #define SQLITE_ABORT 4  // Also an error code */
         | 
| 7363 7625 | 
             
            #define SQLITE_REPLACE  5
         | 
| 7364 7626 |  | 
| 7627 | 
            +
            /*
         | 
| 7628 | 
            +
            ** CAPI3REF: Prepared Statement Scan Status Opcodes
         | 
| 7629 | 
            +
            ** KEYWORDS: {scanstatus options}
         | 
| 7630 | 
            +
            **
         | 
| 7631 | 
            +
            ** The following constants can be used for the T parameter to the
         | 
| 7632 | 
            +
            ** [sqlite3_stmt_scanstatus(S,X,T,V)] interface.  Each constant designates a
         | 
| 7633 | 
            +
            ** different metric for sqlite3_stmt_scanstatus() to return.
         | 
| 7634 | 
            +
            **
         | 
| 7635 | 
            +
            ** When the value returned to V is a string, space to hold that string is
         | 
| 7636 | 
            +
            ** managed by the prepared statement S and will be automatically freed when
         | 
| 7637 | 
            +
            ** S is finalized.
         | 
| 7638 | 
            +
            **
         | 
| 7639 | 
            +
            ** <dl>
         | 
| 7640 | 
            +
            ** [[SQLITE_SCANSTAT_NLOOP]] <dt>SQLITE_SCANSTAT_NLOOP</dt>
         | 
| 7641 | 
            +
            ** <dd>^The [sqlite3_int64] variable pointed to by the T parameter will be
         | 
| 7642 | 
            +
            ** set to the total number of times that the X-th loop has run.</dd>
         | 
| 7643 | 
            +
            **
         | 
| 7644 | 
            +
            ** [[SQLITE_SCANSTAT_NVISIT]] <dt>SQLITE_SCANSTAT_NVISIT</dt>
         | 
| 7645 | 
            +
            ** <dd>^The [sqlite3_int64] variable pointed to by the T parameter will be set
         | 
| 7646 | 
            +
            ** to the total number of rows examined by all iterations of the X-th loop.</dd>
         | 
| 7647 | 
            +
            **
         | 
| 7648 | 
            +
            ** [[SQLITE_SCANSTAT_EST]] <dt>SQLITE_SCANSTAT_EST</dt>
         | 
| 7649 | 
            +
            ** <dd>^The "double" variable pointed to by the T parameter will be set to the
         | 
| 7650 | 
            +
            ** query planner's estimate for the average number of rows output from each
         | 
| 7651 | 
            +
            ** iteration of the X-th loop.  If the query planner's estimates was accurate,
         | 
| 7652 | 
            +
            ** then this value will approximate the quotient NVISIT/NLOOP and the
         | 
| 7653 | 
            +
            ** product of this value for all prior loops with the same SELECTID will
         | 
| 7654 | 
            +
            ** be the NLOOP value for the current loop.
         | 
| 7655 | 
            +
            **
         | 
| 7656 | 
            +
            ** [[SQLITE_SCANSTAT_NAME]] <dt>SQLITE_SCANSTAT_NAME</dt>
         | 
| 7657 | 
            +
            ** <dd>^The "const char *" variable pointed to by the T parameter will be set
         | 
| 7658 | 
            +
            ** to a zero-terminated UTF-8 string containing the name of the index or table
         | 
| 7659 | 
            +
            ** used for the X-th loop.
         | 
| 7660 | 
            +
            **
         | 
| 7661 | 
            +
            ** [[SQLITE_SCANSTAT_EXPLAIN]] <dt>SQLITE_SCANSTAT_EXPLAIN</dt>
         | 
| 7662 | 
            +
            ** <dd>^The "const char *" variable pointed to by the T parameter will be set
         | 
| 7663 | 
            +
            ** to a zero-terminated UTF-8 string containing the [EXPLAIN QUERY PLAN]
         | 
| 7664 | 
            +
            ** description for the X-th loop.
         | 
| 7665 | 
            +
            **
         | 
| 7666 | 
            +
            ** [[SQLITE_SCANSTAT_SELECTID]] <dt>SQLITE_SCANSTAT_SELECT</dt>
         | 
| 7667 | 
            +
            ** <dd>^The "int" variable pointed to by the T parameter will be set to the
         | 
| 7668 | 
            +
            ** "select-id" for the X-th loop.  The select-id identifies which query or
         | 
| 7669 | 
            +
            ** subquery the loop is part of.  The main query has a select-id of zero.
         | 
| 7670 | 
            +
            ** The select-id is the same value as is output in the first column
         | 
| 7671 | 
            +
            ** of an [EXPLAIN QUERY PLAN] query.
         | 
| 7672 | 
            +
            ** </dl>
         | 
| 7673 | 
            +
            */
         | 
| 7674 | 
            +
            #define SQLITE_SCANSTAT_NLOOP    0
         | 
| 7675 | 
            +
            #define SQLITE_SCANSTAT_NVISIT   1
         | 
| 7676 | 
            +
            #define SQLITE_SCANSTAT_EST      2
         | 
| 7677 | 
            +
            #define SQLITE_SCANSTAT_NAME     3
         | 
| 7678 | 
            +
            #define SQLITE_SCANSTAT_EXPLAIN  4
         | 
| 7679 | 
            +
            #define SQLITE_SCANSTAT_SELECTID 5
         | 
| 7680 | 
            +
             | 
| 7681 | 
            +
            /*
         | 
| 7682 | 
            +
            ** CAPI3REF: Prepared Statement Scan Status
         | 
| 7683 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 7684 | 
            +
            **
         | 
| 7685 | 
            +
            ** This interface returns information about the predicted and measured
         | 
| 7686 | 
            +
            ** performance for pStmt.  Advanced applications can use this
         | 
| 7687 | 
            +
            ** interface to compare the predicted and the measured performance and
         | 
| 7688 | 
            +
            ** issue warnings and/or rerun [ANALYZE] if discrepancies are found.
         | 
| 7689 | 
            +
            **
         | 
| 7690 | 
            +
            ** Since this interface is expected to be rarely used, it is only
         | 
| 7691 | 
            +
            ** available if SQLite is compiled using the [SQLITE_ENABLE_STMT_SCANSTATUS]
         | 
| 7692 | 
            +
            ** compile-time option.
         | 
| 7693 | 
            +
            **
         | 
| 7694 | 
            +
            ** The "iScanStatusOp" parameter determines which status information to return.
         | 
| 7695 | 
            +
            ** The "iScanStatusOp" must be one of the [scanstatus options] or the behavior
         | 
| 7696 | 
            +
            ** of this interface is undefined.
         | 
| 7697 | 
            +
            ** ^The requested measurement is written into a variable pointed to by
         | 
| 7698 | 
            +
            ** the "pOut" parameter.
         | 
| 7699 | 
            +
            ** Parameter "idx" identifies the specific loop to retrieve statistics for.
         | 
| 7700 | 
            +
            ** Loops are numbered starting from zero. ^If idx is out of range - less than
         | 
| 7701 | 
            +
            ** zero or greater than or equal to the total number of loops used to implement
         | 
| 7702 | 
            +
            ** the statement - a non-zero value is returned and the variable that pOut
         | 
| 7703 | 
            +
            ** points to is unchanged.
         | 
| 7704 | 
            +
            **
         | 
| 7705 | 
            +
            ** ^Statistics might not be available for all loops in all statements. ^In cases
         | 
| 7706 | 
            +
            ** where there exist loops with no available statistics, this function behaves
         | 
| 7707 | 
            +
            ** as if the loop did not exist - it returns non-zero and leave the variable
         | 
| 7708 | 
            +
            ** that pOut points to unchanged.
         | 
| 7709 | 
            +
            **
         | 
| 7710 | 
            +
            ** See also: [sqlite3_stmt_scanstatus_reset()]
         | 
| 7711 | 
            +
            */
         | 
| 7712 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_stmt_scanstatus(
         | 
| 7713 | 
            +
              sqlite3_stmt *pStmt,      /* Prepared statement for which info desired */
         | 
| 7714 | 
            +
              int idx,                  /* Index of loop to report on */
         | 
| 7715 | 
            +
              int iScanStatusOp,        /* Information desired.  SQLITE_SCANSTAT_* */
         | 
| 7716 | 
            +
              void *pOut                /* Result written here */
         | 
| 7717 | 
            +
            );     
         | 
| 7718 | 
            +
             | 
| 7719 | 
            +
            /*
         | 
| 7720 | 
            +
            ** CAPI3REF: Zero Scan-Status Counters
         | 
| 7721 | 
            +
            ** METHOD: sqlite3_stmt
         | 
| 7722 | 
            +
            **
         | 
| 7723 | 
            +
            ** ^Zero all [sqlite3_stmt_scanstatus()] related event counters.
         | 
| 7724 | 
            +
            **
         | 
| 7725 | 
            +
            ** This API is only available if the library is built with pre-processor
         | 
| 7726 | 
            +
            ** symbol [SQLITE_ENABLE_STMT_SCANSTATUS] defined.
         | 
| 7727 | 
            +
            */
         | 
| 7728 | 
            +
            SQLITE_API void SQLITE_STDCALL sqlite3_stmt_scanstatus_reset(sqlite3_stmt*);
         | 
| 7365 7729 |  | 
| 7366 7730 |  | 
| 7367 7731 | 
             
            /*
         | 
| @@ -7416,7 +7780,7 @@ typedef struct sqlite3_rtree_query_info sqlite3_rtree_query_info; | |
| 7416 7780 | 
             
            **
         | 
| 7417 7781 | 
             
            **   SELECT ... FROM <rtree> WHERE <rtree col> MATCH $zGeom(... params ...)
         | 
| 7418 7782 | 
             
            */
         | 
| 7419 | 
            -
            SQLITE_API int sqlite3_rtree_geometry_callback(
         | 
| 7783 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_rtree_geometry_callback(
         | 
| 7420 7784 | 
             
              sqlite3 *db,
         | 
| 7421 7785 | 
             
              const char *zGeom,
         | 
| 7422 7786 | 
             
              int (*xGeom)(sqlite3_rtree_geometry*, int, sqlite3_rtree_dbl*,int*),
         | 
| @@ -7442,7 +7806,7 @@ struct sqlite3_rtree_geometry { | |
| 7442 7806 | 
             
            **
         | 
| 7443 7807 | 
             
            **   SELECT ... FROM <rtree> WHERE <rtree col> MATCH $zQueryFunc(... params ...)
         | 
| 7444 7808 | 
             
            */
         | 
| 7445 | 
            -
            SQLITE_API int sqlite3_rtree_query_callback(
         | 
| 7809 | 
            +
            SQLITE_API int SQLITE_STDCALL sqlite3_rtree_query_callback(
         | 
| 7446 7810 | 
             
              sqlite3 *db,
         | 
| 7447 7811 | 
             
              const char *zQueryFunc,
         | 
| 7448 7812 | 
             
              int (*xQueryFunc)(sqlite3_rtree_query_info*),
         | 
| @@ -7476,6 +7840,8 @@ struct sqlite3_rtree_query_info { | |
| 7476 7840 | 
             
              int eParentWithin;                /* Visibility of parent node */
         | 
| 7477 7841 | 
             
              int eWithin;                      /* OUT: Visiblity */
         | 
| 7478 7842 | 
             
              sqlite3_rtree_dbl rScore;         /* OUT: Write the score here */
         | 
| 7843 | 
            +
              /* The following fields are only available in 3.8.11 and later */
         | 
| 7844 | 
            +
              sqlite3_value **apSqlParam;       /* Original SQL values of parameters */
         | 
| 7479 7845 | 
             
            };
         | 
| 7480 7846 |  | 
| 7481 7847 | 
             
            /*
         |