forked from cory/tildefriends
sqlite-amalgamation-3440000.zip
git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4592 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
parent
0da45b7b40
commit
4414676076
406
deps/sqlite/shell.c
vendored
406
deps/sqlite/shell.c
vendored
@ -467,18 +467,23 @@ static int bail_on_error = 0;
|
|||||||
*/
|
*/
|
||||||
static int stdin_is_interactive = 1;
|
static int stdin_is_interactive = 1;
|
||||||
|
|
||||||
#if (defined(_WIN32) || defined(WIN32)) && SHELL_USE_LOCAL_GETLINE \
|
|
||||||
&& !defined(SHELL_OMIT_WIN_UTF8)
|
|
||||||
# define SHELL_WIN_UTF8_OPT 1
|
|
||||||
#else
|
|
||||||
# define SHELL_WIN_UTF8_OPT 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if SHELL_WIN_UTF8_OPT
|
|
||||||
/*
|
/*
|
||||||
** Setup console for UTF-8 input/output when following variable true.
|
** If build is for non-RT Windows, without 3rd-party line editing,
|
||||||
|
** console input and output may be done in a UTF-8 compatible way,
|
||||||
|
** if the OS is capable of it and the --no-utf8 option is not seen.
|
||||||
*/
|
*/
|
||||||
static int console_utf8 = 0;
|
#if (defined(_WIN32) || defined(WIN32)) && SHELL_USE_LOCAL_GETLINE \
|
||||||
|
&& !defined(SHELL_OMIT_WIN_UTF8) && !SQLITE_OS_WINRT
|
||||||
|
# define SHELL_WIN_UTF8_OPT 1
|
||||||
|
/* Record whether to do UTF-8 console I/O translation per stream. */
|
||||||
|
static int console_utf8_in = 0;
|
||||||
|
static int console_utf8_out = 0;
|
||||||
|
/* Record whether can do UTF-8 or --no-utf8 seen in invocation. */
|
||||||
|
static int mbcs_opted = 1; /* Assume cannot do until shown otherwise. */
|
||||||
|
#else
|
||||||
|
# define console_utf8_in 0
|
||||||
|
# define console_utf8_out 0
|
||||||
|
# define SHELL_WIN_UTF8_OPT 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -614,13 +619,13 @@ static char *dynamicContinuePrompt(void){
|
|||||||
#endif /* !defined(SQLITE_OMIT_DYNAPROMPT) */
|
#endif /* !defined(SQLITE_OMIT_DYNAPROMPT) */
|
||||||
|
|
||||||
#if SHELL_WIN_UTF8_OPT
|
#if SHELL_WIN_UTF8_OPT
|
||||||
/* Following struct is used for -utf8 operation. */
|
/* Following struct is used for UTF-8 console I/O. */
|
||||||
static struct ConsoleState {
|
static struct ConsoleState {
|
||||||
int stdinEof; /* EOF has been seen on console input */
|
int stdinEof; /* EOF has been seen on console input */
|
||||||
int infsMode; /* Input file stream mode upon shell start */
|
int infsMode; /* Input file stream mode upon shell start */
|
||||||
UINT inCodePage; /* Input code page upon shell start */
|
UINT inCodePage; /* Input code page upon shell start */
|
||||||
UINT outCodePage; /* Output code page upon shell start */
|
UINT outCodePage; /* Output code page upon shell start */
|
||||||
HANDLE hConsoleIn; /* Console input handle */
|
HANDLE hConsole; /* Console input or output handle */
|
||||||
DWORD consoleMode; /* Console mode upon shell start */
|
DWORD consoleMode; /* Console mode upon shell start */
|
||||||
} conState = { 0, 0, 0, 0, INVALID_HANDLE_VALUE, 0 };
|
} conState = { 0, 0, 0, 0, INVALID_HANDLE_VALUE, 0 };
|
||||||
|
|
||||||
@ -629,50 +634,123 @@ static struct ConsoleState {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Prepare console, (if known to be a WIN32 console), for UTF-8
|
** If given stream number is a console, return 1 and get some attributes,
|
||||||
** input (from either typing or suitable paste operations) and for
|
** else return 0 and set the output attributes to invalid values.
|
||||||
** UTF-8 rendering. This may "fail" with a message to stderr, where
|
|
||||||
** the preparation is not done and common "code page" issues occur.
|
|
||||||
*/
|
*/
|
||||||
static void console_prepare(void){
|
static short console_attrs(unsigned stnum, HANDLE *pH, DWORD *pConsMode){
|
||||||
HANDLE hCI = GetStdHandle(STD_INPUT_HANDLE);
|
static int stid[3] = { STD_INPUT_HANDLE,STD_OUTPUT_HANDLE,STD_ERROR_HANDLE };
|
||||||
DWORD consoleMode = 0;
|
HANDLE h;
|
||||||
if( isatty(0) && GetFileType(hCI)==FILE_TYPE_CHAR
|
*pH = INVALID_HANDLE_VALUE;
|
||||||
&& GetConsoleMode( hCI, &consoleMode) ){
|
*pConsMode = 0;
|
||||||
if( !IsValidCodePage(CP_UTF8) ){
|
if( stnum > 2 ) return 0;
|
||||||
fprintf(stderr, "Cannot use UTF-8 code page.\n");
|
h = GetStdHandle(stid[stnum]);
|
||||||
console_utf8 = 0;
|
if( h!=*pH && GetFileType(h)==FILE_TYPE_CHAR && GetConsoleMode(h,pConsMode) ){
|
||||||
return;
|
*pH = h;
|
||||||
}
|
return 1;
|
||||||
conState.hConsoleIn = hCI;
|
}
|
||||||
conState.consoleMode = consoleMode;
|
return 0;
|
||||||
conState.inCodePage = GetConsoleCP();
|
}
|
||||||
conState.outCodePage = GetConsoleOutputCP();
|
|
||||||
SetConsoleCP(CP_UTF8);
|
/*
|
||||||
|
** Perform a runtime test of Windows console to determine if it can
|
||||||
|
** do char-stream I/O correctly when the code page is set to CP_UTF8.
|
||||||
|
** Returns are: 1 => yes it can, 0 => no it cannot
|
||||||
|
**
|
||||||
|
** The console's output code page is momentarily set, then restored.
|
||||||
|
** So this should only be run when the process is given use of the
|
||||||
|
** console for either input or output.
|
||||||
|
*/
|
||||||
|
static short ConsoleDoesUTF8(void){
|
||||||
|
UINT ocp = GetConsoleOutputCP();
|
||||||
|
const char TrialUtf8[] = { '\xC8', '\xAB' }; /* "ȫ" or 2 MBCS characters */
|
||||||
|
WCHAR aReadBack[1] = { 0 }; /* Read back as 0x022B when decoded as UTF-8. */
|
||||||
|
CONSOLE_SCREEN_BUFFER_INFO csbInfo = {0};
|
||||||
|
/* Create an inactive screen buffer with which to do the experiment. */
|
||||||
|
HANDLE hCSB = CreateConsoleScreenBuffer(GENERIC_READ|GENERIC_WRITE, 0, 0,
|
||||||
|
CONSOLE_TEXTMODE_BUFFER, NULL);
|
||||||
|
if( hCSB!=INVALID_HANDLE_VALUE ){
|
||||||
|
COORD cpos = {0,0};
|
||||||
|
DWORD rbc;
|
||||||
|
SetConsoleCursorPosition(hCSB, cpos);
|
||||||
SetConsoleOutputCP(CP_UTF8);
|
SetConsoleOutputCP(CP_UTF8);
|
||||||
consoleMode |= ENABLE_LINE_INPUT | ENABLE_PROCESSED_INPUT;
|
/* Write 2 chars which are a single character in UTF-8 but more in MBCS. */
|
||||||
SetConsoleMode(conState.hConsoleIn, consoleMode);
|
WriteConsoleA(hCSB, TrialUtf8, sizeof(TrialUtf8), NULL, NULL);
|
||||||
|
ReadConsoleOutputCharacterW(hCSB, &aReadBack[0], 1, cpos, &rbc);
|
||||||
|
GetConsoleScreenBufferInfo(hCSB, &csbInfo);
|
||||||
|
SetConsoleOutputCP(ocp);
|
||||||
|
CloseHandle(hCSB);
|
||||||
|
}
|
||||||
|
/* Return 1 if cursor advanced by 1 position, else 0. */
|
||||||
|
return (short)(csbInfo.dwCursorPosition.X == 1 && aReadBack[0] == 0x022B);
|
||||||
|
}
|
||||||
|
|
||||||
|
static short in_console = 0;
|
||||||
|
static short out_console = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Determine whether either normal I/O stream is the console,
|
||||||
|
** and whether it can do UTF-8 translation, setting globals
|
||||||
|
** in_console, out_console and mbcs_opted accordingly.
|
||||||
|
*/
|
||||||
|
static void probe_console(void){
|
||||||
|
HANDLE h;
|
||||||
|
DWORD cMode;
|
||||||
|
in_console = console_attrs(0, &h, &cMode);
|
||||||
|
out_console = console_attrs(1, &h, &cMode);
|
||||||
|
if( in_console || out_console ) mbcs_opted = !ConsoleDoesUTF8();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** If console is used for normal I/O, absent a --no-utf8 option,
|
||||||
|
** prepare console for UTF-8 input (from either typing or suitable
|
||||||
|
** paste operations) and/or for UTF-8 output rendering.
|
||||||
|
**
|
||||||
|
** The console state upon entry is preserved, in conState, so that
|
||||||
|
** console_restore() can later restore the same console state.
|
||||||
|
**
|
||||||
|
** The globals console_utf8_in and console_utf8_out are set, for
|
||||||
|
** later use in selecting UTF-8 or MBCS console I/O translations.
|
||||||
|
** This routine depends upon globals set by probe_console().
|
||||||
|
*/
|
||||||
|
static void console_prepare_utf8(void){
|
||||||
|
struct ConsoleState csWork = { 0, 0, 0, 0, INVALID_HANDLE_VALUE, 0 };
|
||||||
|
|
||||||
|
console_utf8_in = console_utf8_out = 0;
|
||||||
|
if( (!in_console && !out_console) || mbcs_opted ) return;
|
||||||
|
console_attrs((in_console)? 0 : 1, &conState.hConsole, &conState.consoleMode);
|
||||||
|
conState.inCodePage = GetConsoleCP();
|
||||||
|
conState.outCodePage = GetConsoleOutputCP();
|
||||||
|
if( in_console ){
|
||||||
|
SetConsoleCP(CP_UTF8);
|
||||||
|
DWORD newConsoleMode = conState.consoleMode
|
||||||
|
| ENABLE_LINE_INPUT | ENABLE_PROCESSED_INPUT;
|
||||||
|
SetConsoleMode(conState.hConsole, newConsoleMode);
|
||||||
conState.infsMode = _setmode(_fileno(stdin), _O_U16TEXT);
|
conState.infsMode = _setmode(_fileno(stdin), _O_U16TEXT);
|
||||||
console_utf8 = 1;
|
console_utf8_in = 1;
|
||||||
}else{
|
}
|
||||||
console_utf8 = 0;
|
if( out_console ){
|
||||||
|
SetConsoleOutputCP(CP_UTF8);
|
||||||
|
console_utf8_out = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Undo the effects of console_prepare(), if any.
|
** Undo the effects of console_prepare_utf8(), if any.
|
||||||
*/
|
*/
|
||||||
static void SQLITE_CDECL console_restore(void){
|
static void SQLITE_CDECL console_restore(void){
|
||||||
if( console_utf8 && conState.inCodePage!=0
|
if( (console_utf8_in||console_utf8_out)
|
||||||
&& conState.hConsoleIn!=INVALID_HANDLE_VALUE ){
|
&& conState.hConsole!=INVALID_HANDLE_VALUE ){
|
||||||
_setmode(_fileno(stdin), conState.infsMode);
|
if( console_utf8_in ){
|
||||||
SetConsoleCP(conState.inCodePage);
|
SetConsoleCP(conState.inCodePage);
|
||||||
SetConsoleOutputCP(conState.outCodePage);
|
_setmode(_fileno(stdin), conState.infsMode);
|
||||||
SetConsoleMode(conState.hConsoleIn, conState.consoleMode);
|
}
|
||||||
|
if( console_utf8_out ) SetConsoleOutputCP(conState.outCodePage);
|
||||||
|
SetConsoleMode(conState.hConsole, conState.consoleMode);
|
||||||
/* Avoid multiple calls. */
|
/* Avoid multiple calls. */
|
||||||
conState.hConsoleIn = INVALID_HANDLE_VALUE;
|
conState.hConsole = INVALID_HANDLE_VALUE;
|
||||||
conState.consoleMode = 0;
|
conState.consoleMode = 0;
|
||||||
console_utf8 = 0;
|
console_utf8_in = 0;
|
||||||
|
console_utf8_out = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -680,11 +758,11 @@ static void SQLITE_CDECL console_restore(void){
|
|||||||
** Collect input like fgets(...) with special provisions for input
|
** Collect input like fgets(...) with special provisions for input
|
||||||
** from the Windows console to get around its strange coding issues.
|
** from the Windows console to get around its strange coding issues.
|
||||||
** Defers to plain fgets() when input is not interactive or when the
|
** Defers to plain fgets() when input is not interactive or when the
|
||||||
** startup option, -utf8, has not been provided or taken effect.
|
** UTF-8 input is unavailable or opted out.
|
||||||
*/
|
*/
|
||||||
static char* utf8_fgets(char *buf, int ncmax, FILE *fin){
|
static char* utf8_fgets(char *buf, int ncmax, FILE *fin){
|
||||||
if( fin==0 ) fin = stdin;
|
if( fin==0 ) fin = stdin;
|
||||||
if( fin==stdin && stdin_is_interactive && console_utf8 ){
|
if( fin==stdin && stdin_is_interactive && console_utf8_in ){
|
||||||
# define SQLITE_IALIM 150
|
# define SQLITE_IALIM 150
|
||||||
wchar_t wbuf[SQLITE_IALIM];
|
wchar_t wbuf[SQLITE_IALIM];
|
||||||
int lend = 0;
|
int lend = 0;
|
||||||
@ -697,7 +775,7 @@ static char* utf8_fgets(char *buf, int ncmax, FILE *fin){
|
|||||||
? SQLITE_IALIM : (ncmax-1 - noc)/4;
|
? SQLITE_IALIM : (ncmax-1 - noc)/4;
|
||||||
# undef SQLITE_IALIM
|
# undef SQLITE_IALIM
|
||||||
DWORD nbr = 0;
|
DWORD nbr = 0;
|
||||||
BOOL bRC = ReadConsoleW(conState.hConsoleIn, wbuf, na, &nbr, 0);
|
BOOL bRC = ReadConsoleW(conState.hConsole, wbuf, na, &nbr, 0);
|
||||||
if( !bRC || (noc==0 && nbr==0) ) return 0;
|
if( !bRC || (noc==0 && nbr==0) ) return 0;
|
||||||
if( nbr > 0 ){
|
if( nbr > 0 ){
|
||||||
int nmb = WideCharToMultiByte(CP_UTF8,WC_COMPOSITECHECK|WC_DEFAULTCHAR,
|
int nmb = WideCharToMultiByte(CP_UTF8,WC_COMPOSITECHECK|WC_DEFAULTCHAR,
|
||||||
@ -743,20 +821,16 @@ static char* utf8_fgets(char *buf, int ncmax, FILE *fin){
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
** Render output like fprintf(). Except, if the output is going to the
|
** Render output like fprintf(). Except, if the output is going to the
|
||||||
** console and if this is running on a Windows machine, and if the -utf8
|
** console and if this is running on a Windows machine, and if UTF-8
|
||||||
** option is unavailable or (available and inactive), translate the
|
** output unavailable (or available but opted out), translate the
|
||||||
** output from UTF-8 into MBCS for output through 8-bit stdout stream.
|
** output from UTF-8 into MBCS for output through 8-bit stdout stream.
|
||||||
** (With -utf8 active, no translation is needed and must not be done.)
|
** (Without -no-utf8, no translation is needed and must not be done.)
|
||||||
*/
|
*/
|
||||||
#if defined(_WIN32) || defined(WIN32)
|
#if defined(_WIN32) || defined(WIN32)
|
||||||
void utf8_printf(FILE *out, const char *zFormat, ...){
|
void utf8_printf(FILE *out, const char *zFormat, ...){
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, zFormat);
|
va_start(ap, zFormat);
|
||||||
if( stdout_is_console && (out==stdout || out==stderr)
|
if( stdout_is_console && (out==stdout || out==stderr) && !console_utf8_out ){
|
||||||
# if SHELL_WIN_UTF8_OPT
|
|
||||||
&& !console_utf8
|
|
||||||
# endif
|
|
||||||
){
|
|
||||||
char *z1 = sqlite3_vmprintf(zFormat, ap);
|
char *z1 = sqlite3_vmprintf(zFormat, ap);
|
||||||
char *z2 = sqlite3_win32_utf8_to_mbcs_v2(z1, 0);
|
char *z2 = sqlite3_win32_utf8_to_mbcs_v2(z1, 0);
|
||||||
sqlite3_free(z1);
|
sqlite3_free(z1);
|
||||||
@ -967,14 +1041,10 @@ static char *local_getline(char *zLine, FILE *in){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if defined(_WIN32) || defined(WIN32)
|
#if defined(_WIN32) || defined(WIN32)
|
||||||
/* For interactive input on Windows systems, without -utf8,
|
/* For interactive input on Windows systems, with -no-utf8,
|
||||||
** translate the multi-byte characterset characters into UTF-8.
|
** translate the multi-byte characterset characters into UTF-8.
|
||||||
** This is the translation that predates the -utf8 option. */
|
** This is the translation that predates console UTF-8 input. */
|
||||||
if( stdin_is_interactive && in==stdin
|
if( stdin_is_interactive && in==stdin && !console_utf8_in ){
|
||||||
# if SHELL_WIN_UTF8_OPT
|
|
||||||
&& !console_utf8
|
|
||||||
# endif /* SHELL_WIN_UTF8_OPT */
|
|
||||||
){
|
|
||||||
char *zTrans = sqlite3_win32_mbcs_to_utf8_v2(zLine, 0);
|
char *zTrans = sqlite3_win32_mbcs_to_utf8_v2(zLine, 0);
|
||||||
if( zTrans ){
|
if( zTrans ){
|
||||||
i64 nTrans = strlen(zTrans)+1;
|
i64 nTrans = strlen(zTrans)+1;
|
||||||
@ -5372,7 +5442,8 @@ static sqlite3_module seriesModule = {
|
|||||||
0, /* xSavepoint */
|
0, /* xSavepoint */
|
||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollbackTo */
|
0, /* xRollbackTo */
|
||||||
0 /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0 /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* SQLITE_OMIT_VIRTUALTABLE */
|
#endif /* SQLITE_OMIT_VIRTUALTABLE */
|
||||||
@ -7270,6 +7341,7 @@ static int fsdirRegister(sqlite3 *db){
|
|||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollbackTo */
|
0, /* xRollbackTo */
|
||||||
0, /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0 /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
int rc = sqlite3_create_module(db, "fsdir", &fsdirModule, 0);
|
int rc = sqlite3_create_module(db, "fsdir", &fsdirModule, 0);
|
||||||
@ -7790,7 +7862,8 @@ static sqlite3_module completionModule = {
|
|||||||
0, /* xSavepoint */
|
0, /* xSavepoint */
|
||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollbackTo */
|
0, /* xRollbackTo */
|
||||||
0 /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0 /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* SQLITE_OMIT_VIRTUALTABLE */
|
#endif /* SQLITE_OMIT_VIRTUALTABLE */
|
||||||
@ -8530,6 +8603,7 @@ SQLITE_EXTENSION_INIT1
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
#include <zlib.h>
|
#include <zlib.h>
|
||||||
|
|
||||||
@ -10701,7 +10775,8 @@ static int zipfileRegister(sqlite3 *db){
|
|||||||
0, /* xSavepoint */
|
0, /* xSavepoint */
|
||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollback */
|
0, /* xRollback */
|
||||||
0 /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0 /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
int rc = sqlite3_create_module(db, "zipfile" , &zipfileModule, 0);
|
int rc = sqlite3_create_module(db, "zipfile" , &zipfileModule, 0);
|
||||||
@ -11070,7 +11145,7 @@ void sqlite3_expert_destroy(sqlite3expert*);
|
|||||||
#endif /* !defined(SQLITE_AMALGAMATION) */
|
#endif /* !defined(SQLITE_AMALGAMATION) */
|
||||||
|
|
||||||
|
|
||||||
#ifndef SQLITE_OMIT_VIRTUALTABLE
|
#ifndef SQLITE_OMIT_VIRTUALTABLE
|
||||||
|
|
||||||
/* typedef sqlite3_int64 i64; */
|
/* typedef sqlite3_int64 i64; */
|
||||||
/* typedef sqlite3_uint64 u64; */
|
/* typedef sqlite3_uint64 u64; */
|
||||||
@ -11700,6 +11775,7 @@ static int idxRegisterVtab(sqlite3expert *p){
|
|||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollbackTo */
|
0, /* xRollbackTo */
|
||||||
0, /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0, /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
return sqlite3_create_module(p->dbv, "expert", &expertModule, (void*)p);
|
return sqlite3_create_module(p->dbv, "expert", &expertModule, (void*)p);
|
||||||
@ -12856,6 +12932,88 @@ static int idxPopulateStat1(sqlite3expert *p, char **pzErr){
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Define and possibly pretend to use a useless collation sequence.
|
||||||
|
** This pretense allows expert to accept SQL using custom collations.
|
||||||
|
*/
|
||||||
|
int dummyCompare(void *up1, int up2, const void *up3, int up4, const void *up5){
|
||||||
|
(void)up1;
|
||||||
|
(void)up2;
|
||||||
|
(void)up3;
|
||||||
|
(void)up4;
|
||||||
|
(void)up5;
|
||||||
|
assert(0); /* VDBE should never be run. */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
/* And a callback to register above upon actual need */
|
||||||
|
void useDummyCS(void *up1, sqlite3 *db, int etr, const char *zName){
|
||||||
|
(void)up1;
|
||||||
|
sqlite3_create_collation_v2(db, zName, etr, 0, dummyCompare, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if !defined(SQLITE_OMIT_SCHEMA_PRAGMAS) \
|
||||||
|
&& !defined(SQLITE_OMIT_INTROSPECTION_PRAGMAS)
|
||||||
|
/*
|
||||||
|
** dummy functions for no-op implementation of UDFs during expert's work
|
||||||
|
*/
|
||||||
|
void dummyUDF(sqlite3_context *up1, int up2, sqlite3_value **up3){
|
||||||
|
(void)up1;
|
||||||
|
(void)up2;
|
||||||
|
(void)up3;
|
||||||
|
assert(0); /* VDBE should never be run. */
|
||||||
|
}
|
||||||
|
void dummyUDFvalue(sqlite3_context *up1){
|
||||||
|
(void)up1;
|
||||||
|
assert(0); /* VDBE should never be run. */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Register UDFs from user database with another.
|
||||||
|
*/
|
||||||
|
int registerUDFs(sqlite3 *dbSrc, sqlite3 *dbDst){
|
||||||
|
sqlite3_stmt *pStmt;
|
||||||
|
int rc = sqlite3_prepare_v2(dbSrc,
|
||||||
|
"SELECT name,type,enc,narg,flags "
|
||||||
|
"FROM pragma_function_list() "
|
||||||
|
"WHERE builtin==0", -1, &pStmt, 0);
|
||||||
|
if( rc==SQLITE_OK ){
|
||||||
|
while( SQLITE_ROW==(rc = sqlite3_step(pStmt)) ){
|
||||||
|
int nargs = sqlite3_column_int(pStmt,3);
|
||||||
|
int flags = sqlite3_column_int(pStmt,4);
|
||||||
|
const char *name = (char*)sqlite3_column_text(pStmt,0);
|
||||||
|
const char *type = (char*)sqlite3_column_text(pStmt,1);
|
||||||
|
const char *enc = (char*)sqlite3_column_text(pStmt,2);
|
||||||
|
if( name==0 || type==0 || enc==0 ){
|
||||||
|
/* no-op. Only happens on OOM */
|
||||||
|
}else{
|
||||||
|
int ienc = SQLITE_UTF8;
|
||||||
|
int rcf = SQLITE_ERROR;
|
||||||
|
if( strcmp(enc,"utf16le")==0 ) ienc = SQLITE_UTF16LE;
|
||||||
|
else if( strcmp(enc,"utf16be")==0 ) ienc = SQLITE_UTF16BE;
|
||||||
|
ienc |= (flags & (SQLITE_DETERMINISTIC|SQLITE_DIRECTONLY));
|
||||||
|
if( strcmp(type,"w")==0 ){
|
||||||
|
rcf = sqlite3_create_window_function(dbDst,name,nargs,ienc,0,
|
||||||
|
dummyUDF,dummyUDFvalue,0,0,0);
|
||||||
|
}else if( strcmp(type,"a")==0 ){
|
||||||
|
rcf = sqlite3_create_function(dbDst,name,nargs,ienc,0,
|
||||||
|
0,dummyUDF,dummyUDFvalue);
|
||||||
|
}else if( strcmp(type,"s")==0 ){
|
||||||
|
rcf = sqlite3_create_function(dbDst,name,nargs,ienc,0,
|
||||||
|
dummyUDF,0,0);
|
||||||
|
}
|
||||||
|
if( rcf!=SQLITE_OK ){
|
||||||
|
rc = rcf;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sqlite3_finalize(pStmt);
|
||||||
|
if( rc==SQLITE_DONE ) rc = SQLITE_OK;
|
||||||
|
}
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Allocate a new sqlite3expert object.
|
** Allocate a new sqlite3expert object.
|
||||||
*/
|
*/
|
||||||
@ -12882,7 +13040,21 @@ sqlite3expert *sqlite3_expert_new(sqlite3 *db, char **pzErrmsg){
|
|||||||
sqlite3_db_config(pNew->dbm, SQLITE_DBCONFIG_TRIGGER_EQP, 1, (int*)0);
|
sqlite3_db_config(pNew->dbm, SQLITE_DBCONFIG_TRIGGER_EQP, 1, (int*)0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Allow custom collations to be dealt with through prepare. */
|
||||||
|
if( rc==SQLITE_OK ) rc = sqlite3_collation_needed(pNew->dbm,0,useDummyCS);
|
||||||
|
if( rc==SQLITE_OK ) rc = sqlite3_collation_needed(pNew->dbv,0,useDummyCS);
|
||||||
|
|
||||||
|
#if !defined(SQLITE_OMIT_SCHEMA_PRAGMAS) \
|
||||||
|
&& !defined(SQLITE_OMIT_INTROSPECTION_PRAGMAS)
|
||||||
|
/* Register UDFs from database [db] with [dbm] and [dbv]. */
|
||||||
|
if( rc==SQLITE_OK ){
|
||||||
|
rc = registerUDFs(pNew->db, pNew->dbm);
|
||||||
|
}
|
||||||
|
if( rc==SQLITE_OK ){
|
||||||
|
rc = registerUDFs(pNew->db, pNew->dbv);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Copy the entire schema of database [db] into [dbm]. */
|
/* Copy the entire schema of database [db] into [dbm]. */
|
||||||
if( rc==SQLITE_OK ){
|
if( rc==SQLITE_OK ){
|
||||||
@ -12958,6 +13130,10 @@ int sqlite3_expert_sql(
|
|||||||
|
|
||||||
while( rc==SQLITE_OK && zStmt && zStmt[0] ){
|
while( rc==SQLITE_OK && zStmt && zStmt[0] ){
|
||||||
sqlite3_stmt *pStmt = 0;
|
sqlite3_stmt *pStmt = 0;
|
||||||
|
/* Ensure that the provided statement compiles against user's DB. */
|
||||||
|
rc = idxPrepareStmt(p->db, &pStmt, pzErr, zStmt);
|
||||||
|
if( rc!=SQLITE_OK ) break;
|
||||||
|
sqlite3_finalize(pStmt);
|
||||||
rc = sqlite3_prepare_v2(p->dbv, zStmt, -1, &pStmt, &zStmt);
|
rc = sqlite3_prepare_v2(p->dbv, zStmt, -1, &pStmt, &zStmt);
|
||||||
if( rc==SQLITE_OK ){
|
if( rc==SQLITE_OK ){
|
||||||
if( pStmt ){
|
if( pStmt ){
|
||||||
@ -14282,7 +14458,8 @@ static int sqlite3DbdataRegister(sqlite3 *db){
|
|||||||
0, /* xSavepoint */
|
0, /* xSavepoint */
|
||||||
0, /* xRelease */
|
0, /* xRelease */
|
||||||
0, /* xRollbackTo */
|
0, /* xRollbackTo */
|
||||||
0 /* xShadowName */
|
0, /* xShadowName */
|
||||||
|
0 /* xIntegrity */
|
||||||
};
|
};
|
||||||
|
|
||||||
int rc = sqlite3_create_module(db, "sqlite_dbdata", &dbdata_module, 0);
|
int rc = sqlite3_create_module(db, "sqlite_dbdata", &dbdata_module, 0);
|
||||||
@ -19154,7 +19331,7 @@ static void display_explain_scanstats(
|
|||||||
if( sqlite3_stmt_scanstatus_v2(p,ii,SQLITE_SCANSTAT_EXPLAIN,f,(void*)&z) ){
|
if( sqlite3_stmt_scanstatus_v2(p,ii,SQLITE_SCANSTAT_EXPLAIN,f,(void*)&z) ){
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
n = strlen(z) + scanStatsHeight(p, ii)*3;
|
n = (int)strlen(z) + scanStatsHeight(p, ii)*3;
|
||||||
if( n>nWidth ) nWidth = n;
|
if( n>nWidth ) nWidth = n;
|
||||||
}
|
}
|
||||||
nWidth += 4;
|
nWidth += 4;
|
||||||
@ -19166,12 +19343,12 @@ static void display_explain_scanstats(
|
|||||||
i64 nCycle = 0;
|
i64 nCycle = 0;
|
||||||
int iId = 0;
|
int iId = 0;
|
||||||
int iPid = 0;
|
int iPid = 0;
|
||||||
const char *z = 0;
|
const char *zo = 0;
|
||||||
const char *zName = 0;
|
const char *zName = 0;
|
||||||
char *zText = 0;
|
char *zText = 0;
|
||||||
double rEst = 0.0;
|
double rEst = 0.0;
|
||||||
|
|
||||||
if( sqlite3_stmt_scanstatus_v2(p,ii,SQLITE_SCANSTAT_EXPLAIN,f,(void*)&z) ){
|
if( sqlite3_stmt_scanstatus_v2(p,ii,SQLITE_SCANSTAT_EXPLAIN,f,(void*)&zo) ){
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_EST,f,(void*)&rEst);
|
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_EST,f,(void*)&rEst);
|
||||||
@ -19182,7 +19359,7 @@ static void display_explain_scanstats(
|
|||||||
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_PARENTID,f,(void*)&iPid);
|
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_PARENTID,f,(void*)&iPid);
|
||||||
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_NAME,f,(void*)&zName);
|
sqlite3_stmt_scanstatus_v2(p, ii, SQLITE_SCANSTAT_NAME,f,(void*)&zName);
|
||||||
|
|
||||||
zText = sqlite3_mprintf("%s", z);
|
zText = sqlite3_mprintf("%s", zo);
|
||||||
if( nCycle>=0 || nLoop>=0 || nRow>=0 ){
|
if( nCycle>=0 || nLoop>=0 || nRow>=0 ){
|
||||||
char *z = 0;
|
char *z = 0;
|
||||||
if( nCycle>=0 && nTotal>0 ){
|
if( nCycle>=0 && nTotal>0 ){
|
||||||
@ -23830,7 +24007,6 @@ static int do_meta_command(char *zLine, ShellState *p){
|
|||||||
azArg[nArg++] = &zLine[h];
|
azArg[nArg++] = &zLine[h];
|
||||||
while( zLine[h] && !IsSpace(zLine[h]) ){ h++; }
|
while( zLine[h] && !IsSpace(zLine[h]) ){ h++; }
|
||||||
if( zLine[h] ) zLine[h++] = 0;
|
if( zLine[h] ) zLine[h++] = 0;
|
||||||
resolve_backslashes(azArg[nArg-1]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
azArg[nArg] = 0;
|
azArg[nArg] = 0;
|
||||||
@ -24569,8 +24745,10 @@ static int do_meta_command(char *zLine, ShellState *p){
|
|||||||
"SELECT rowid FROM sqlite_schema"
|
"SELECT rowid FROM sqlite_schema"
|
||||||
" WHERE name GLOB 'sqlite_stat[134]'",
|
" WHERE name GLOB 'sqlite_stat[134]'",
|
||||||
-1, &pStmt, 0);
|
-1, &pStmt, 0);
|
||||||
doStats = sqlite3_step(pStmt)==SQLITE_ROW;
|
if( rc==SQLITE_OK ){
|
||||||
sqlite3_finalize(pStmt);
|
doStats = sqlite3_step(pStmt)==SQLITE_ROW;
|
||||||
|
sqlite3_finalize(pStmt);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if( doStats==0 ){
|
if( doStats==0 ){
|
||||||
raw_printf(p->out, "/* No STAT tables available */\n");
|
raw_printf(p->out, "/* No STAT tables available */\n");
|
||||||
@ -24859,6 +25037,14 @@ static int do_meta_command(char *zLine, ShellState *p){
|
|||||||
** the remaining columns.
|
** the remaining columns.
|
||||||
*/
|
*/
|
||||||
if( p->mode==MODE_Ascii && (z==0 || z[0]==0) && i==0 ) break;
|
if( p->mode==MODE_Ascii && (z==0 || z[0]==0) && i==0 ) break;
|
||||||
|
/*
|
||||||
|
** For CSV mode, per RFC 4180, accept EOF in lieu of final
|
||||||
|
** record terminator but only for last field of multi-field row.
|
||||||
|
** (If there are too few fields, it's not valid CSV anyway.)
|
||||||
|
*/
|
||||||
|
if( z==0 && (xRead==csv_read_one_field) && i==nCol-1 && i>0 ){
|
||||||
|
z = "";
|
||||||
|
}
|
||||||
sqlite3_bind_text(pStmt, i+1, z, -1, SQLITE_TRANSIENT);
|
sqlite3_bind_text(pStmt, i+1, z, -1, SQLITE_TRANSIENT);
|
||||||
if( i<nCol-1 && sCtx.cTerm!=sCtx.cColSep ){
|
if( i<nCol-1 && sCtx.cTerm!=sCtx.cColSep ){
|
||||||
utf8_printf(stderr, "%s:%d: expected %d columns but found %d - "
|
utf8_printf(stderr, "%s:%d: expected %d columns but found %d - "
|
||||||
@ -26698,6 +26884,7 @@ static int do_meta_command(char *zLine, ShellState *p){
|
|||||||
{"byteorder", SQLITE_TESTCTRL_BYTEORDER, 0, "" },
|
{"byteorder", SQLITE_TESTCTRL_BYTEORDER, 0, "" },
|
||||||
{"extra_schema_checks",SQLITE_TESTCTRL_EXTRA_SCHEMA_CHECKS,0,"BOOLEAN" },
|
{"extra_schema_checks",SQLITE_TESTCTRL_EXTRA_SCHEMA_CHECKS,0,"BOOLEAN" },
|
||||||
/*{"fault_install", SQLITE_TESTCTRL_FAULT_INSTALL, 1,"" },*/
|
/*{"fault_install", SQLITE_TESTCTRL_FAULT_INSTALL, 1,"" },*/
|
||||||
|
{"fk_no_action", SQLITE_TESTCTRL_FK_NO_ACTION, 0, "BOOLEAN" },
|
||||||
{"imposter", SQLITE_TESTCTRL_IMPOSTER,1,"SCHEMA ON/OFF ROOTPAGE"},
|
{"imposter", SQLITE_TESTCTRL_IMPOSTER,1,"SCHEMA ON/OFF ROOTPAGE"},
|
||||||
{"internal_functions", SQLITE_TESTCTRL_INTERNAL_FUNCTIONS,0,"" },
|
{"internal_functions", SQLITE_TESTCTRL_INTERNAL_FUNCTIONS,0,"" },
|
||||||
{"localtime_fault", SQLITE_TESTCTRL_LOCALTIME_FAULT,0,"BOOLEAN" },
|
{"localtime_fault", SQLITE_TESTCTRL_LOCALTIME_FAULT,0,"BOOLEAN" },
|
||||||
@ -26768,6 +26955,7 @@ static int do_meta_command(char *zLine, ShellState *p){
|
|||||||
|
|
||||||
/* sqlite3_test_control(int, db, int) */
|
/* sqlite3_test_control(int, db, int) */
|
||||||
case SQLITE_TESTCTRL_OPTIMIZATIONS:
|
case SQLITE_TESTCTRL_OPTIMIZATIONS:
|
||||||
|
case SQLITE_TESTCTRL_FK_NO_ACTION:
|
||||||
if( nArg==3 ){
|
if( nArg==3 ){
|
||||||
unsigned int opt = (unsigned int)strtol(azArg[2], 0, 0);
|
unsigned int opt = (unsigned int)strtol(azArg[2], 0, 0);
|
||||||
rc2 = sqlite3_test_control(testctrl, p->db, opt);
|
rc2 = sqlite3_test_control(testctrl, p->db, opt);
|
||||||
@ -27720,6 +27908,9 @@ static const char zOptions[] =
|
|||||||
" -multiplex enable the multiplexor VFS\n"
|
" -multiplex enable the multiplexor VFS\n"
|
||||||
#endif
|
#endif
|
||||||
" -newline SEP set output row separator. Default: '\\n'\n"
|
" -newline SEP set output row separator. Default: '\\n'\n"
|
||||||
|
#if SHELL_WIN_UTF8_OPT
|
||||||
|
" -no-utf8 do not try to set up UTF-8 output (for legacy)\n"
|
||||||
|
#endif
|
||||||
" -nofollow refuse to open symbolic links to database files\n"
|
" -nofollow refuse to open symbolic links to database files\n"
|
||||||
" -nonce STRING set the safe-mode escape nonce\n"
|
" -nonce STRING set the safe-mode escape nonce\n"
|
||||||
" -nullvalue TEXT set text string for NULL values. Default ''\n"
|
" -nullvalue TEXT set text string for NULL values. Default ''\n"
|
||||||
@ -27736,7 +27927,7 @@ static const char zOptions[] =
|
|||||||
" -table set output mode to 'table'\n"
|
" -table set output mode to 'table'\n"
|
||||||
" -tabs set output mode to 'tabs'\n"
|
" -tabs set output mode to 'tabs'\n"
|
||||||
" -unsafe-testing allow unsafe commands and modes for testing\n"
|
" -unsafe-testing allow unsafe commands and modes for testing\n"
|
||||||
#if SHELL_WIN_UTF8_OPT
|
#if SHELL_WIN_UTF8_OPT && 0 /* Option is accepted, but is now the default. */
|
||||||
" -utf8 setup interactive console code page for UTF-8\n"
|
" -utf8 setup interactive console code page for UTF-8\n"
|
||||||
#endif
|
#endif
|
||||||
" -version show SQLite version\n"
|
" -version show SQLite version\n"
|
||||||
@ -27887,7 +28078,8 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
stdout_is_console = isatty(1);
|
stdout_is_console = isatty(1);
|
||||||
#endif
|
#endif
|
||||||
#if SHELL_WIN_UTF8_OPT
|
#if SHELL_WIN_UTF8_OPT
|
||||||
atexit(console_restore); /* Needs revision for CLI as library call */
|
probe_console(); /* Check for console I/O and UTF-8 capability. */
|
||||||
|
if( !mbcs_opted ) atexit(console_restore);
|
||||||
#endif
|
#endif
|
||||||
atexit(sayAbnormalExit);
|
atexit(sayAbnormalExit);
|
||||||
#ifdef SQLITE_DEBUG
|
#ifdef SQLITE_DEBUG
|
||||||
@ -27974,8 +28166,8 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
|
|
||||||
/* Do an initial pass through the command-line argument to locate
|
/* Do an initial pass through the command-line argument to locate
|
||||||
** the name of the database file, the name of the initialization file,
|
** the name of the database file, the name of the initialization file,
|
||||||
** the size of the alternative malloc heap,
|
** the size of the alternative malloc heap, options affecting commands
|
||||||
** and the first command to execute.
|
** or SQL run from the command line, and the first command to execute.
|
||||||
*/
|
*/
|
||||||
#ifndef SQLITE_SHELL_FIDDLE
|
#ifndef SQLITE_SHELL_FIDDLE
|
||||||
verify_uninitialized();
|
verify_uninitialized();
|
||||||
@ -28009,12 +28201,26 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
(void)cmdline_option_value(argc, argv, ++i);
|
(void)cmdline_option_value(argc, argv, ++i);
|
||||||
}else if( cli_strcmp(z,"-init")==0 ){
|
}else if( cli_strcmp(z,"-init")==0 ){
|
||||||
zInitFile = cmdline_option_value(argc, argv, ++i);
|
zInitFile = cmdline_option_value(argc, argv, ++i);
|
||||||
|
}else if( cli_strcmp(z,"-interactive")==0 ){
|
||||||
|
/* Need to check for interactive override here to so that it can
|
||||||
|
** affect console setup (for Windows only) and testing thereof.
|
||||||
|
*/
|
||||||
|
stdin_is_interactive = 1;
|
||||||
}else if( cli_strcmp(z,"-batch")==0 ){
|
}else if( cli_strcmp(z,"-batch")==0 ){
|
||||||
/* Need to check for batch mode here to so we can avoid printing
|
/* Need to check for batch mode here to so we can avoid printing
|
||||||
** informational messages (like from process_sqliterc) before
|
** informational messages (like from process_sqliterc) before
|
||||||
** we do the actual processing of arguments later in a second pass.
|
** we do the actual processing of arguments later in a second pass.
|
||||||
*/
|
*/
|
||||||
stdin_is_interactive = 0;
|
stdin_is_interactive = 0;
|
||||||
|
}else if( cli_strcmp(z,"-utf8")==0 ){
|
||||||
|
#if SHELL_WIN_UTF8_OPT
|
||||||
|
/* Option accepted, but is ignored except for this diagnostic. */
|
||||||
|
if( mbcs_opted ) fprintf(stderr, "Cannot do UTF-8 at this console.\n");
|
||||||
|
#endif /* SHELL_WIN_UTF8_OPT */
|
||||||
|
}else if( cli_strcmp(z,"-no-utf8")==0 ){
|
||||||
|
#if SHELL_WIN_UTF8_OPT
|
||||||
|
mbcs_opted = 1;
|
||||||
|
#endif /* SHELL_WIN_UTF8_OPT */
|
||||||
}else if( cli_strcmp(z,"-heap")==0 ){
|
}else if( cli_strcmp(z,"-heap")==0 ){
|
||||||
#if defined(SQLITE_ENABLE_MEMSYS3) || defined(SQLITE_ENABLE_MEMSYS5)
|
#if defined(SQLITE_ENABLE_MEMSYS3) || defined(SQLITE_ENABLE_MEMSYS5)
|
||||||
const char *zSize;
|
const char *zSize;
|
||||||
@ -28153,6 +28359,15 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#if SHELL_WIN_UTF8_OPT
|
||||||
|
/* Get indicated Windows console setup done before running invocation commands. */
|
||||||
|
if( in_console || out_console ){
|
||||||
|
console_prepare_utf8();
|
||||||
|
}
|
||||||
|
if( !in_console ){
|
||||||
|
setBinaryMode(stdin, 0);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if( data.pAuxDb->zDbFilename==0 ){
|
if( data.pAuxDb->zDbFilename==0 ){
|
||||||
#ifndef SQLITE_OMIT_MEMORYDB
|
#ifndef SQLITE_OMIT_MEMORYDB
|
||||||
@ -28280,13 +28495,13 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
8*(int)sizeof(char*));
|
8*(int)sizeof(char*));
|
||||||
return 0;
|
return 0;
|
||||||
}else if( cli_strcmp(z,"-interactive")==0 ){
|
}else if( cli_strcmp(z,"-interactive")==0 ){
|
||||||
stdin_is_interactive = 1;
|
/* already handled */
|
||||||
}else if( cli_strcmp(z,"-batch")==0 ){
|
}else if( cli_strcmp(z,"-batch")==0 ){
|
||||||
stdin_is_interactive = 0;
|
/* already handled */
|
||||||
}else if( cli_strcmp(z,"-utf8")==0 ){
|
}else if( cli_strcmp(z,"-utf8")==0 ){
|
||||||
#if SHELL_WIN_UTF8_OPT
|
/* already handled */
|
||||||
console_utf8 = 1;
|
}else if( cli_strcmp(z,"-no-utf8")==0 ){
|
||||||
#endif /* SHELL_WIN_UTF8_OPT */
|
/* already handled */
|
||||||
}else if( cli_strcmp(z,"-heap")==0 ){
|
}else if( cli_strcmp(z,"-heap")==0 ){
|
||||||
i++;
|
i++;
|
||||||
}else if( cli_strcmp(z,"-pagecache")==0 ){
|
}else if( cli_strcmp(z,"-pagecache")==0 ){
|
||||||
@ -28368,14 +28583,6 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
}
|
}
|
||||||
data.cMode = data.mode;
|
data.cMode = data.mode;
|
||||||
}
|
}
|
||||||
#if SHELL_WIN_UTF8_OPT
|
|
||||||
if( console_utf8 && stdin_is_interactive ){
|
|
||||||
console_prepare();
|
|
||||||
}else{
|
|
||||||
setBinaryMode(stdin, 0);
|
|
||||||
console_utf8 = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if( !readStdin ){
|
if( !readStdin ){
|
||||||
/* Run all arguments that do not begin with '-' as if they were separate
|
/* Run all arguments that do not begin with '-' as if they were separate
|
||||||
@ -28411,11 +28618,20 @@ int SQLITE_CDECL wmain(int argc, wchar_t **wargv){
|
|||||||
if( stdin_is_interactive ){
|
if( stdin_is_interactive ){
|
||||||
char *zHome;
|
char *zHome;
|
||||||
char *zHistory;
|
char *zHistory;
|
||||||
|
const char *zCharset = "";
|
||||||
int nHistory;
|
int nHistory;
|
||||||
|
#if SHELL_WIN_UTF8_OPT
|
||||||
|
switch( console_utf8_in+2*console_utf8_out ){
|
||||||
|
default: case 0: break;
|
||||||
|
case 1: zCharset = " (utf8 in)"; break;
|
||||||
|
case 2: zCharset = " (utf8 out)"; break;
|
||||||
|
case 3: zCharset = " (utf8 I/O)"; break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
printf(
|
printf(
|
||||||
"SQLite version %s %.19s\n" /*extra-version-info*/
|
"SQLite version %s %.19s%s\n" /*extra-version-info*/
|
||||||
"Enter \".help\" for usage hints.\n",
|
"Enter \".help\" for usage hints.\n",
|
||||||
sqlite3_libversion(), sqlite3_sourceid()
|
sqlite3_libversion(), sqlite3_sourceid(), zCharset
|
||||||
);
|
);
|
||||||
if( warnInmemoryDb ){
|
if( warnInmemoryDb ){
|
||||||
printf("Connected to a ");
|
printf("Connected to a ");
|
||||||
|
6460
deps/sqlite/sqlite3.c
vendored
6460
deps/sqlite/sqlite3.c
vendored
File diff suppressed because it is too large
Load Diff
199
deps/sqlite/sqlite3.h
vendored
199
deps/sqlite/sqlite3.h
vendored
@ -146,9 +146,9 @@ extern "C" {
|
|||||||
** [sqlite3_libversion_number()], [sqlite3_sourceid()],
|
** [sqlite3_libversion_number()], [sqlite3_sourceid()],
|
||||||
** [sqlite_version()] and [sqlite_source_id()].
|
** [sqlite_version()] and [sqlite_source_id()].
|
||||||
*/
|
*/
|
||||||
#define SQLITE_VERSION "3.43.2"
|
#define SQLITE_VERSION "3.44.0"
|
||||||
#define SQLITE_VERSION_NUMBER 3043002
|
#define SQLITE_VERSION_NUMBER 3044000
|
||||||
#define SQLITE_SOURCE_ID "2023-10-10 12:14:04 4310099cce5a487035fa535dd3002c59ac7f1d1bec68d7cf317fd3e769484790"
|
#define SQLITE_SOURCE_ID "2023-11-01 11:23:50 17129ba1ff7f0daf37100ee82d507aef7827cf38de1866e2633096ae6ad81301"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Run-Time Library Version Numbers
|
** CAPI3REF: Run-Time Library Version Numbers
|
||||||
@ -2127,7 +2127,7 @@ struct sqlite3_mem_methods {
|
|||||||
** is stored in each sorted record and the required column values loaded
|
** is stored in each sorted record and the required column values loaded
|
||||||
** from the database as records are returned in sorted order. The default
|
** from the database as records are returned in sorted order. The default
|
||||||
** value for this option is to never use this optimization. Specifying a
|
** value for this option is to never use this optimization. Specifying a
|
||||||
** negative value for this option restores the default behaviour.
|
** negative value for this option restores the default behavior.
|
||||||
** This option is only available if SQLite is compiled with the
|
** This option is only available if SQLite is compiled with the
|
||||||
** [SQLITE_ENABLE_SORTER_REFERENCES] compile-time option.
|
** [SQLITE_ENABLE_SORTER_REFERENCES] compile-time option.
|
||||||
**
|
**
|
||||||
@ -2302,7 +2302,7 @@ struct sqlite3_mem_methods {
|
|||||||
** database handle, SQLite checks if this will mean that there are now no
|
** database handle, SQLite checks if this will mean that there are now no
|
||||||
** connections at all to the database. If so, it performs a checkpoint
|
** connections at all to the database. If so, it performs a checkpoint
|
||||||
** operation before closing the connection. This option may be used to
|
** operation before closing the connection. This option may be used to
|
||||||
** override this behaviour. The first parameter passed to this operation
|
** override this behavior. The first parameter passed to this operation
|
||||||
** is an integer - positive to disable checkpoints-on-close, or zero (the
|
** is an integer - positive to disable checkpoints-on-close, or zero (the
|
||||||
** default) to enable them, and negative to leave the setting unchanged.
|
** default) to enable them, and negative to leave the setting unchanged.
|
||||||
** The second parameter is a pointer to an integer
|
** The second parameter is a pointer to an integer
|
||||||
@ -3955,6 +3955,7 @@ SQLITE_API void sqlite3_free_filename(sqlite3_filename);
|
|||||||
**
|
**
|
||||||
** ^The sqlite3_errmsg() and sqlite3_errmsg16() return English-language
|
** ^The sqlite3_errmsg() and sqlite3_errmsg16() return English-language
|
||||||
** text that describes the error, as either UTF-8 or UTF-16 respectively.
|
** text that describes the error, as either UTF-8 or UTF-16 respectively.
|
||||||
|
** (See how SQLite handles [invalid UTF] for exceptions to this rule.)
|
||||||
** ^(Memory to hold the error message string is managed internally.
|
** ^(Memory to hold the error message string is managed internally.
|
||||||
** The application does not need to worry about freeing the result.
|
** The application does not need to worry about freeing the result.
|
||||||
** However, the error string might be overwritten or deallocated by
|
** However, the error string might be overwritten or deallocated by
|
||||||
@ -5325,6 +5326,7 @@ SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt);
|
|||||||
*/
|
*/
|
||||||
SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
|
SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Create Or Redefine SQL Functions
|
** CAPI3REF: Create Or Redefine SQL Functions
|
||||||
** KEYWORDS: {function creation routines}
|
** KEYWORDS: {function creation routines}
|
||||||
@ -5879,32 +5881,32 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
|
|||||||
** METHOD: sqlite3_context
|
** METHOD: sqlite3_context
|
||||||
**
|
**
|
||||||
** These functions may be used by (non-aggregate) SQL functions to
|
** These functions may be used by (non-aggregate) SQL functions to
|
||||||
** associate metadata with argument values. If the same value is passed to
|
** associate auxiliary data with argument values. If the same argument
|
||||||
** multiple invocations of the same SQL function during query execution, under
|
** value is passed to multiple invocations of the same SQL function during
|
||||||
** some circumstances the associated metadata may be preserved. An example
|
** query execution, under some circumstances the associated auxiliary data
|
||||||
** of where this might be useful is in a regular-expression matching
|
** might be preserved. An example of where this might be useful is in a
|
||||||
** function. The compiled version of the regular expression can be stored as
|
** regular-expression matching function. The compiled version of the regular
|
||||||
** metadata associated with the pattern string.
|
** expression can be stored as auxiliary data associated with the pattern string.
|
||||||
** Then as long as the pattern string remains the same,
|
** Then as long as the pattern string remains the same,
|
||||||
** the compiled regular expression can be reused on multiple
|
** the compiled regular expression can be reused on multiple
|
||||||
** invocations of the same function.
|
** invocations of the same function.
|
||||||
**
|
**
|
||||||
** ^The sqlite3_get_auxdata(C,N) interface returns a pointer to the metadata
|
** ^The sqlite3_get_auxdata(C,N) interface returns a pointer to the auxiliary data
|
||||||
** associated by the sqlite3_set_auxdata(C,N,P,X) function with the Nth argument
|
** associated by the sqlite3_set_auxdata(C,N,P,X) function with the Nth argument
|
||||||
** value to the application-defined function. ^N is zero for the left-most
|
** value to the application-defined function. ^N is zero for the left-most
|
||||||
** function argument. ^If there is no metadata
|
** function argument. ^If there is no auxiliary data
|
||||||
** associated with the function argument, the sqlite3_get_auxdata(C,N) interface
|
** associated with the function argument, the sqlite3_get_auxdata(C,N) interface
|
||||||
** returns a NULL pointer.
|
** returns a NULL pointer.
|
||||||
**
|
**
|
||||||
** ^The sqlite3_set_auxdata(C,N,P,X) interface saves P as metadata for the N-th
|
** ^The sqlite3_set_auxdata(C,N,P,X) interface saves P as auxiliary data for the
|
||||||
** argument of the application-defined function. ^Subsequent
|
** N-th argument of the application-defined function. ^Subsequent
|
||||||
** calls to sqlite3_get_auxdata(C,N) return P from the most recent
|
** calls to sqlite3_get_auxdata(C,N) return P from the most recent
|
||||||
** sqlite3_set_auxdata(C,N,P,X) call if the metadata is still valid or
|
** sqlite3_set_auxdata(C,N,P,X) call if the auxiliary data is still valid or
|
||||||
** NULL if the metadata has been discarded.
|
** NULL if the auxiliary data has been discarded.
|
||||||
** ^After each call to sqlite3_set_auxdata(C,N,P,X) where X is not NULL,
|
** ^After each call to sqlite3_set_auxdata(C,N,P,X) where X is not NULL,
|
||||||
** SQLite will invoke the destructor function X with parameter P exactly
|
** SQLite will invoke the destructor function X with parameter P exactly
|
||||||
** once, when the metadata is discarded.
|
** once, when the auxiliary data is discarded.
|
||||||
** SQLite is free to discard the metadata at any time, including: <ul>
|
** SQLite is free to discard the auxiliary data at any time, including: <ul>
|
||||||
** <li> ^(when the corresponding function parameter changes)^, or
|
** <li> ^(when the corresponding function parameter changes)^, or
|
||||||
** <li> ^(when [sqlite3_reset()] or [sqlite3_finalize()] is called for the
|
** <li> ^(when [sqlite3_reset()] or [sqlite3_finalize()] is called for the
|
||||||
** SQL statement)^, or
|
** SQL statement)^, or
|
||||||
@ -5920,7 +5922,7 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
|
|||||||
** function implementation should not make any use of P after
|
** function implementation should not make any use of P after
|
||||||
** sqlite3_set_auxdata() has been called.
|
** sqlite3_set_auxdata() has been called.
|
||||||
**
|
**
|
||||||
** ^(In practice, metadata is preserved between function calls for
|
** ^(In practice, auxiliary data is preserved between function calls for
|
||||||
** function parameters that are compile-time constants, including literal
|
** function parameters that are compile-time constants, including literal
|
||||||
** values and [parameters] and expressions composed from the same.)^
|
** values and [parameters] and expressions composed from the same.)^
|
||||||
**
|
**
|
||||||
@ -5930,10 +5932,67 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
|
|||||||
**
|
**
|
||||||
** These routines must be called from the same thread in which
|
** These routines must be called from the same thread in which
|
||||||
** the SQL function is running.
|
** the SQL function is running.
|
||||||
|
**
|
||||||
|
** See also: [sqlite3_get_clientdata()] and [sqlite3_set_clientdata()].
|
||||||
*/
|
*/
|
||||||
SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
|
SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
|
||||||
SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
|
SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
|
||||||
|
|
||||||
|
/*
|
||||||
|
** CAPI3REF: Database Connection Client Data
|
||||||
|
** METHOD: sqlite3
|
||||||
|
**
|
||||||
|
** These functions are used to associate one or more named pointers
|
||||||
|
** with a [database connection].
|
||||||
|
** A call to sqlite3_set_clientdata(D,N,P,X) causes the pointer P
|
||||||
|
** to be attached to [database connection] D using name N. Subsequent
|
||||||
|
** calls to sqlite3_get_clientdata(D,N) will return a copy of pointer P
|
||||||
|
** or a NULL pointer if there were no prior calls to
|
||||||
|
** sqlite3_set_clientdata() with the same values of D and N.
|
||||||
|
** Names are compared using strcmp() and are thus case sensitive.
|
||||||
|
**
|
||||||
|
** If P and X are both non-NULL, then the destructor X is invoked with
|
||||||
|
** argument P on the first of the following occurrences:
|
||||||
|
** <ul>
|
||||||
|
** <li> An out-of-memory error occurs during the call to
|
||||||
|
** sqlite3_set_clientdata() which attempts to register pointer P.
|
||||||
|
** <li> A subsequent call to sqlite3_set_clientdata(D,N,P,X) is made
|
||||||
|
** with the same D and N parameters.
|
||||||
|
** <li> The database connection closes. SQLite does not make any guarantees
|
||||||
|
** about the order in which destructors are called, only that all
|
||||||
|
** destructors will be called exactly once at some point during the
|
||||||
|
** database connection closing process.
|
||||||
|
** </ul>
|
||||||
|
**
|
||||||
|
** SQLite does not do anything with client data other than invoke
|
||||||
|
** destructors on the client data at the appropriate time. The intended
|
||||||
|
** use for client data is to provide a mechanism for wrapper libraries
|
||||||
|
** to store additional information about an SQLite database connection.
|
||||||
|
**
|
||||||
|
** There is no limit (other than available memory) on the number of different
|
||||||
|
** client data pointers (with different names) that can be attached to a
|
||||||
|
** single database connection. However, the implementation is optimized
|
||||||
|
** for the case of having only one or two different client data names.
|
||||||
|
** Applications and wrapper libraries are discouraged from using more than
|
||||||
|
** one client data name each.
|
||||||
|
**
|
||||||
|
** There is no way to enumerate the client data pointers
|
||||||
|
** associated with a database connection. The N parameter can be thought
|
||||||
|
** of as a secret key such that only code that knows the secret key is able
|
||||||
|
** to access the associated data.
|
||||||
|
**
|
||||||
|
** Security Warning: These interfaces should not be exposed in scripting
|
||||||
|
** languages or in other circumstances where it might be possible for an
|
||||||
|
** an attacker to invoke them. Any agent that can invoke these interfaces
|
||||||
|
** can probably also take control of the process.
|
||||||
|
**
|
||||||
|
** Database connection client data is only available for SQLite
|
||||||
|
** version 3.44.0 ([dateof:3.44.0]) and later.
|
||||||
|
**
|
||||||
|
** See also: [sqlite3_set_auxdata()] and [sqlite3_get_auxdata()].
|
||||||
|
*/
|
||||||
|
SQLITE_API void *sqlite3_get_clientdata(sqlite3*,const char*);
|
||||||
|
SQLITE_API int sqlite3_set_clientdata(sqlite3*, const char*, void*, void(*)(void*));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Constants Defining Special Destructor Behavior
|
** CAPI3REF: Constants Defining Special Destructor Behavior
|
||||||
@ -6566,7 +6625,7 @@ SQLITE_API int sqlite3_db_readonly(sqlite3 *db, const char *zDbName);
|
|||||||
SQLITE_API int sqlite3_txn_state(sqlite3*,const char *zSchema);
|
SQLITE_API int sqlite3_txn_state(sqlite3*,const char *zSchema);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Allowed return values from [sqlite3_txn_state()]
|
** CAPI3REF: Allowed return values from sqlite3_txn_state()
|
||||||
** KEYWORDS: {transaction state}
|
** KEYWORDS: {transaction state}
|
||||||
**
|
**
|
||||||
** These constants define the current transaction state of a database file.
|
** These constants define the current transaction state of a database file.
|
||||||
@ -6698,7 +6757,7 @@ SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
|
|||||||
** ^Each call to the sqlite3_autovacuum_pages() interface overrides all
|
** ^Each call to the sqlite3_autovacuum_pages() interface overrides all
|
||||||
** previous invocations for that database connection. ^If the callback
|
** previous invocations for that database connection. ^If the callback
|
||||||
** argument (C) to sqlite3_autovacuum_pages(D,C,P,X) is a NULL pointer,
|
** argument (C) to sqlite3_autovacuum_pages(D,C,P,X) is a NULL pointer,
|
||||||
** then the autovacuum steps callback is cancelled. The return value
|
** then the autovacuum steps callback is canceled. The return value
|
||||||
** from sqlite3_autovacuum_pages() is normally SQLITE_OK, but might
|
** from sqlite3_autovacuum_pages() is normally SQLITE_OK, but might
|
||||||
** be some other error code if something goes wrong. The current
|
** be some other error code if something goes wrong. The current
|
||||||
** implementation will only return SQLITE_OK or SQLITE_MISUSE, but other
|
** implementation will only return SQLITE_OK or SQLITE_MISUSE, but other
|
||||||
@ -7217,6 +7276,10 @@ struct sqlite3_module {
|
|||||||
/* The methods above are in versions 1 and 2 of the sqlite_module object.
|
/* The methods above are in versions 1 and 2 of the sqlite_module object.
|
||||||
** Those below are for version 3 and greater. */
|
** Those below are for version 3 and greater. */
|
||||||
int (*xShadowName)(const char*);
|
int (*xShadowName)(const char*);
|
||||||
|
/* The methods above are in versions 1 through 3 of the sqlite_module object.
|
||||||
|
** Those below are for version 4 and greater. */
|
||||||
|
int (*xIntegrity)(sqlite3_vtab *pVTab, const char *zSchema,
|
||||||
|
const char *zTabName, int mFlags, char **pzErr);
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -7704,7 +7767,7 @@ SQLITE_API int sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64);
|
|||||||
** code is returned and the transaction rolled back.
|
** code is returned and the transaction rolled back.
|
||||||
**
|
**
|
||||||
** Calling this function with an argument that is not a NULL pointer or an
|
** Calling this function with an argument that is not a NULL pointer or an
|
||||||
** open blob handle results in undefined behaviour. ^Calling this routine
|
** open blob handle results in undefined behavior. ^Calling this routine
|
||||||
** with a null pointer (such as would be returned by a failed call to
|
** with a null pointer (such as would be returned by a failed call to
|
||||||
** [sqlite3_blob_open()]) is a harmless no-op. ^Otherwise, if this function
|
** [sqlite3_blob_open()]) is a harmless no-op. ^Otherwise, if this function
|
||||||
** is passed a valid open blob handle, the values returned by the
|
** is passed a valid open blob handle, the values returned by the
|
||||||
@ -8184,6 +8247,7 @@ SQLITE_API int sqlite3_test_control(int op, ...);
|
|||||||
#define SQLITE_TESTCTRL_PRNG_SAVE 5
|
#define SQLITE_TESTCTRL_PRNG_SAVE 5
|
||||||
#define SQLITE_TESTCTRL_PRNG_RESTORE 6
|
#define SQLITE_TESTCTRL_PRNG_RESTORE 6
|
||||||
#define SQLITE_TESTCTRL_PRNG_RESET 7 /* NOT USED */
|
#define SQLITE_TESTCTRL_PRNG_RESET 7 /* NOT USED */
|
||||||
|
#define SQLITE_TESTCTRL_FK_NO_ACTION 7
|
||||||
#define SQLITE_TESTCTRL_BITVEC_TEST 8
|
#define SQLITE_TESTCTRL_BITVEC_TEST 8
|
||||||
#define SQLITE_TESTCTRL_FAULT_INSTALL 9
|
#define SQLITE_TESTCTRL_FAULT_INSTALL 9
|
||||||
#define SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS 10
|
#define SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS 10
|
||||||
@ -9245,8 +9309,8 @@ SQLITE_API int sqlite3_backup_pagecount(sqlite3_backup *p);
|
|||||||
** blocked connection already has a registered unlock-notify callback,
|
** blocked connection already has a registered unlock-notify callback,
|
||||||
** then the new callback replaces the old.)^ ^If sqlite3_unlock_notify() is
|
** then the new callback replaces the old.)^ ^If sqlite3_unlock_notify() is
|
||||||
** called with a NULL pointer as its second argument, then any existing
|
** called with a NULL pointer as its second argument, then any existing
|
||||||
** unlock-notify callback is cancelled. ^The blocked connections
|
** unlock-notify callback is canceled. ^The blocked connections
|
||||||
** unlock-notify callback may also be cancelled by closing the blocked
|
** unlock-notify callback may also be canceled by closing the blocked
|
||||||
** connection using [sqlite3_close()].
|
** connection using [sqlite3_close()].
|
||||||
**
|
**
|
||||||
** The unlock-notify callback is not reentrant. If an application invokes
|
** The unlock-notify callback is not reentrant. If an application invokes
|
||||||
@ -10549,6 +10613,13 @@ SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_recover(sqlite3 *db, const c
|
|||||||
** SQLITE_SERIALIZE_NOCOPY bit is set but no contiguous copy
|
** SQLITE_SERIALIZE_NOCOPY bit is set but no contiguous copy
|
||||||
** of the database exists.
|
** of the database exists.
|
||||||
**
|
**
|
||||||
|
** After the call, if the SQLITE_SERIALIZE_NOCOPY bit had been set,
|
||||||
|
** the returned buffer content will remain accessible and unchanged
|
||||||
|
** until either the next write operation on the connection or when
|
||||||
|
** the connection is closed, and applications must not modify the
|
||||||
|
** buffer. If the bit had been clear, the returned buffer will not
|
||||||
|
** be accessed by SQLite after the call.
|
||||||
|
**
|
||||||
** A call to sqlite3_serialize(D,S,P,F) might return NULL even if the
|
** A call to sqlite3_serialize(D,S,P,F) might return NULL even if the
|
||||||
** SQLITE_SERIALIZE_NOCOPY bit is omitted from argument F if a memory
|
** SQLITE_SERIALIZE_NOCOPY bit is omitted from argument F if a memory
|
||||||
** allocation error occurs.
|
** allocation error occurs.
|
||||||
@ -10597,6 +10668,9 @@ SQLITE_API unsigned char *sqlite3_serialize(
|
|||||||
** SQLite will try to increase the buffer size using sqlite3_realloc64()
|
** SQLite will try to increase the buffer size using sqlite3_realloc64()
|
||||||
** if writes on the database cause it to grow larger than M bytes.
|
** if writes on the database cause it to grow larger than M bytes.
|
||||||
**
|
**
|
||||||
|
** Applications must not modify the buffer P or invalidate it before
|
||||||
|
** the database connection D is closed.
|
||||||
|
**
|
||||||
** The sqlite3_deserialize() interface will fail with SQLITE_BUSY if the
|
** The sqlite3_deserialize() interface will fail with SQLITE_BUSY if the
|
||||||
** database is currently in a read transaction or is involved in a backup
|
** database is currently in a read transaction or is involved in a backup
|
||||||
** operation.
|
** operation.
|
||||||
@ -10605,6 +10679,13 @@ SQLITE_API unsigned char *sqlite3_serialize(
|
|||||||
** S argument to sqlite3_deserialize(D,S,P,N,M,F) is "temp" then the
|
** S argument to sqlite3_deserialize(D,S,P,N,M,F) is "temp" then the
|
||||||
** function returns SQLITE_ERROR.
|
** function returns SQLITE_ERROR.
|
||||||
**
|
**
|
||||||
|
** The deserialized database should not be in [WAL mode]. If the database
|
||||||
|
** is in WAL mode, then any attempt to use the database file will result
|
||||||
|
** in an [SQLITE_CANTOPEN] error. The application can set the
|
||||||
|
** [file format version numbers] (bytes 18 and 19) of the input database P
|
||||||
|
** to 0x01 prior to invoking sqlite3_deserialize(D,S,P,N,M,F) to force the
|
||||||
|
** database file into rollback mode and work around this limitation.
|
||||||
|
**
|
||||||
** If sqlite3_deserialize(D,S,P,N,M,F) fails for any reason and if the
|
** If sqlite3_deserialize(D,S,P,N,M,F) fails for any reason and if the
|
||||||
** SQLITE_DESERIALIZE_FREEONCLOSE bit is set in argument F, then
|
** SQLITE_DESERIALIZE_FREEONCLOSE bit is set in argument F, then
|
||||||
** [sqlite3_free()] is invoked on argument P prior to returning.
|
** [sqlite3_free()] is invoked on argument P prior to returning.
|
||||||
@ -11677,6 +11758,18 @@ SQLITE_API int sqlite3changeset_concat(
|
|||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
** CAPI3REF: Upgrade the Schema of a Changeset/Patchset
|
||||||
|
*/
|
||||||
|
SQLITE_API int sqlite3changeset_upgrade(
|
||||||
|
sqlite3 *db,
|
||||||
|
const char *zDb,
|
||||||
|
int nIn, const void *pIn, /* Input changeset */
|
||||||
|
int *pnOut, void **ppOut /* OUT: Inverse of input */
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Changegroup Handle
|
** CAPI3REF: Changegroup Handle
|
||||||
**
|
**
|
||||||
@ -11723,6 +11816,38 @@ typedef struct sqlite3_changegroup sqlite3_changegroup;
|
|||||||
*/
|
*/
|
||||||
SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
|
SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
|
||||||
|
|
||||||
|
/*
|
||||||
|
** CAPI3REF: Add a Schema to a Changegroup
|
||||||
|
** METHOD: sqlite3_changegroup_schema
|
||||||
|
**
|
||||||
|
** This method may be used to optionally enforce the rule that the changesets
|
||||||
|
** added to the changegroup handle must match the schema of database zDb
|
||||||
|
** ("main", "temp", or the name of an attached database). If
|
||||||
|
** sqlite3changegroup_add() is called to add a changeset that is not compatible
|
||||||
|
** with the configured schema, SQLITE_SCHEMA is returned and the changegroup
|
||||||
|
** object is left in an undefined state.
|
||||||
|
**
|
||||||
|
** A changeset schema is considered compatible with the database schema in
|
||||||
|
** the same way as for sqlite3changeset_apply(). Specifically, for each
|
||||||
|
** table in the changeset, there exists a database table with:
|
||||||
|
**
|
||||||
|
** <ul>
|
||||||
|
** <li> The name identified by the changeset, and
|
||||||
|
** <li> at least as many columns as recorded in the changeset, and
|
||||||
|
** <li> the primary key columns in the same position as recorded in
|
||||||
|
** the changeset.
|
||||||
|
** </ul>
|
||||||
|
**
|
||||||
|
** The output of the changegroup object always has the same schema as the
|
||||||
|
** database nominated using this function. In cases where changesets passed
|
||||||
|
** to sqlite3changegroup_add() have fewer columns than the corresponding table
|
||||||
|
** in the database schema, these are filled in using the default column
|
||||||
|
** values from the database schema. This makes it possible to combined
|
||||||
|
** changesets that have different numbers of columns for a single table
|
||||||
|
** within a changegroup, provided that they are otherwise compatible.
|
||||||
|
*/
|
||||||
|
SQLITE_API int sqlite3changegroup_schema(sqlite3_changegroup*, sqlite3*, const char *zDb);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Add A Changeset To A Changegroup
|
** CAPI3REF: Add A Changeset To A Changegroup
|
||||||
** METHOD: sqlite3_changegroup
|
** METHOD: sqlite3_changegroup
|
||||||
@ -11791,13 +11916,18 @@ SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
|
|||||||
** If the new changeset contains changes to a table that is already present
|
** If the new changeset contains changes to a table that is already present
|
||||||
** in the changegroup, then the number of columns and the position of the
|
** in the changegroup, then the number of columns and the position of the
|
||||||
** primary key columns for the table must be consistent. If this is not the
|
** primary key columns for the table must be consistent. If this is not the
|
||||||
** case, this function fails with SQLITE_SCHEMA. If the input changeset
|
** case, this function fails with SQLITE_SCHEMA. Except, if the changegroup
|
||||||
** appears to be corrupt and the corruption is detected, SQLITE_CORRUPT is
|
** object has been configured with a database schema using the
|
||||||
** returned. Or, if an out-of-memory condition occurs during processing, this
|
** sqlite3changegroup_schema() API, then it is possible to combine changesets
|
||||||
** function returns SQLITE_NOMEM. In all cases, if an error occurs the state
|
** with different numbers of columns for a single table, provided that
|
||||||
** of the final contents of the changegroup is undefined.
|
** they are otherwise compatible.
|
||||||
**
|
**
|
||||||
** If no error occurs, SQLITE_OK is returned.
|
** If the input changeset appears to be corrupt and the corruption is
|
||||||
|
** detected, SQLITE_CORRUPT is returned. Or, if an out-of-memory condition
|
||||||
|
** occurs during processing, this function returns SQLITE_NOMEM.
|
||||||
|
**
|
||||||
|
** In all cases, if an error occurs the state of the final contents of the
|
||||||
|
** changegroup is undefined. If no error occurs, SQLITE_OK is returned.
|
||||||
*/
|
*/
|
||||||
SQLITE_API int sqlite3changegroup_add(sqlite3_changegroup*, int nData, void *pData);
|
SQLITE_API int sqlite3changegroup_add(sqlite3_changegroup*, int nData, void *pData);
|
||||||
|
|
||||||
@ -12062,10 +12192,17 @@ SQLITE_API int sqlite3changeset_apply_v2(
|
|||||||
** <li>an insert change if all fields of the conflicting row match
|
** <li>an insert change if all fields of the conflicting row match
|
||||||
** the row being inserted.
|
** the row being inserted.
|
||||||
** </ul>
|
** </ul>
|
||||||
|
**
|
||||||
|
** <dt>SQLITE_CHANGESETAPPLY_FKNOACTION <dd>
|
||||||
|
** If this flag it set, then all foreign key constraints in the target
|
||||||
|
** database behave as if they were declared with "ON UPDATE NO ACTION ON
|
||||||
|
** DELETE NO ACTION", even if they are actually CASCADE, RESTRICT, SET NULL
|
||||||
|
** or SET DEFAULT.
|
||||||
*/
|
*/
|
||||||
#define SQLITE_CHANGESETAPPLY_NOSAVEPOINT 0x0001
|
#define SQLITE_CHANGESETAPPLY_NOSAVEPOINT 0x0001
|
||||||
#define SQLITE_CHANGESETAPPLY_INVERT 0x0002
|
#define SQLITE_CHANGESETAPPLY_INVERT 0x0002
|
||||||
#define SQLITE_CHANGESETAPPLY_IGNORENOOP 0x0004
|
#define SQLITE_CHANGESETAPPLY_IGNORENOOP 0x0004
|
||||||
|
#define SQLITE_CHANGESETAPPLY_FKNOACTION 0x0008
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Constants Passed To The Conflict Handler
|
** CAPI3REF: Constants Passed To The Conflict Handler
|
||||||
|
6
deps/sqlite/sqlite3ext.h
vendored
6
deps/sqlite/sqlite3ext.h
vendored
@ -363,6 +363,9 @@ struct sqlite3_api_routines {
|
|||||||
int (*is_interrupted)(sqlite3*);
|
int (*is_interrupted)(sqlite3*);
|
||||||
/* Version 3.43.0 and later */
|
/* Version 3.43.0 and later */
|
||||||
int (*stmt_explain)(sqlite3_stmt*,int);
|
int (*stmt_explain)(sqlite3_stmt*,int);
|
||||||
|
/* Version 3.44.0 and later */
|
||||||
|
void *(*get_clientdata)(sqlite3*,const char*);
|
||||||
|
int (*set_clientdata)(sqlite3*, const char*, void*, void(*)(void*));
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -693,6 +696,9 @@ typedef int (*sqlite3_loadext_entry)(
|
|||||||
#define sqlite3_is_interrupted sqlite3_api->is_interrupted
|
#define sqlite3_is_interrupted sqlite3_api->is_interrupted
|
||||||
/* Version 3.43.0 and later */
|
/* Version 3.43.0 and later */
|
||||||
#define sqlite3_stmt_explain sqlite3_api->stmt_explain
|
#define sqlite3_stmt_explain sqlite3_api->stmt_explain
|
||||||
|
/* Version 3.44.0 and later */
|
||||||
|
#define sqlite3_get_clientdata sqlite3_api->get_clientdata
|
||||||
|
#define sqlite3_set_clientdata sqlite3_api->set_clientdata
|
||||||
#endif /* !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION) */
|
#endif /* !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION) */
|
||||||
|
|
||||||
#if !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION)
|
#if !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user