update: sqlite 3.50.4.
This commit is contained in:
		| @@ -23,7 +23,7 @@ VERSION_NAME := This program kills fascists. | ||||
|  | ||||
| IPHONEOS_VERSION_MIN=14.0 | ||||
|  | ||||
| SQLITE_URL := https://www.sqlite.org/2025/sqlite-amalgamation-3500300.zip | ||||
| SQLITE_URL := https://www.sqlite.org/2025/sqlite-amalgamation-3500400.zip | ||||
| BUNDLETOOL_URL := https://github.com/google/bundletool/releases/download/1.17.0/bundletool-all-1.17.0.jar | ||||
| APPIMAGETOOL_URL := https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage | ||||
| APPIMAGETOOL_MD5 := e989fadfc4d685fd3d6aeeb9b525d74d  out/appimagetool | ||||
|   | ||||
							
								
								
									
										43
									
								
								deps/sqlite/sqlite3.c
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										43
									
								
								deps/sqlite/sqlite3.c
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| /******************************************************************************
 | ||||
| ** This file is an amalgamation of many separate C source files from SQLite | ||||
| ** version 3.50.3.  By combining all the individual C code files into this | ||||
| ** version 3.50.4.  By combining all the individual C code files into this | ||||
| ** single large file, the entire code can be compiled as a single translation | ||||
| ** unit.  This allows many compilers to do optimizations that would not be | ||||
| ** possible if the files were compiled separately.  Performance improvements | ||||
| @@ -18,7 +18,7 @@ | ||||
| ** separate file. This file contains only code for the core SQLite library. | ||||
| ** | ||||
| ** The content in this amalgamation comes from Fossil check-in | ||||
| ** 3ce993b8657d6d9deda380a93cdd6404a8c8 with changes in files: | ||||
| ** 4d8adfb30e03f9cf27f800a2c1ba3c48fb4c with changes in files: | ||||
| ** | ||||
| **     | ||||
| */ | ||||
| @@ -465,9 +465,9 @@ extern "C" { | ||||
| ** [sqlite3_libversion_number()], [sqlite3_sourceid()], | ||||
| ** [sqlite_version()] and [sqlite_source_id()]. | ||||
| */ | ||||
| #define SQLITE_VERSION        "3.50.3" | ||||
| #define SQLITE_VERSION_NUMBER 3050003 | ||||
| #define SQLITE_SOURCE_ID      "2025-07-17 13:25:10 3ce993b8657d6d9deda380a93cdd6404a8c8ba1b185b2bc423703e41ae5f2543" | ||||
| #define SQLITE_VERSION        "3.50.4" | ||||
| #define SQLITE_VERSION_NUMBER 3050004 | ||||
| #define SQLITE_SOURCE_ID      "2025-07-30 19:33:53 4d8adfb30e03f9cf27f800a2c1ba3c48fb4ca1b08b0f5ed59a4d5ecbf45e20a3" | ||||
| 
 | ||||
| /*
 | ||||
| ** CAPI3REF: Run-Time Library Version Numbers | ||||
| @@ -19440,6 +19440,7 @@ struct Expr { | ||||
|     Table *pTab;           /* TK_COLUMN: Table containing column. Can be NULL
 | ||||
|                            ** for a column of an index on an expression */ | ||||
|     Window *pWin;          /* EP_WinFunc: Window/Filter defn for a function */ | ||||
|     int nReg;              /* TK_NULLS: Number of registers to NULL out */ | ||||
|     struct {               /* TK_IN, TK_SELECT, and TK_EXISTS */ | ||||
|       int iAddr;             /* Subroutine entry address */ | ||||
|       int regReturn;         /* Register used to hold return address */ | ||||
| @@ -21474,6 +21475,7 @@ SQLITE_PRIVATE void sqlite3ExprCodeGeneratedColumn(Parse*, Table*, Column*, int) | ||||
| SQLITE_PRIVATE void sqlite3ExprCodeCopy(Parse*, Expr*, int); | ||||
| SQLITE_PRIVATE void sqlite3ExprCodeFactorable(Parse*, Expr*, int); | ||||
| SQLITE_PRIVATE int sqlite3ExprCodeRunJustOnce(Parse*, Expr*, int); | ||||
| SQLITE_PRIVATE void sqlite3ExprNullRegisterRange(Parse*, int, int); | ||||
| SQLITE_PRIVATE int sqlite3ExprCodeTemp(Parse*, Expr*, int*); | ||||
| SQLITE_PRIVATE int sqlite3ExprCodeTarget(Parse*, Expr*, int); | ||||
| SQLITE_PRIVATE int sqlite3ExprCodeExprList(Parse*, ExprList*, int, int, u8); | ||||
| @@ -115241,6 +115243,12 @@ expr_code_doover: | ||||
|       sqlite3VdbeLoadString(v, target, pExpr->u.zToken); | ||||
|       return target; | ||||
|     } | ||||
|     case TK_NULLS: { | ||||
|       /* Set a range of registers to NULL.  pExpr->y.nReg registers starting
 | ||||
|       ** with target */ | ||||
|       sqlite3VdbeAddOp3(v, OP_Null, 0, target, target + pExpr->y.nReg - 1); | ||||
|       return target; | ||||
|     } | ||||
|     default: { | ||||
|       /* Make NULL the default case so that if a bug causes an illegal
 | ||||
|       ** Expr node to be passed into this function, it will be handled | ||||
| @@ -115925,6 +115933,25 @@ SQLITE_PRIVATE int sqlite3ExprCodeRunJustOnce( | ||||
|   return regDest; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
| ** Make arrangements to invoke OP_Null on a range of registers | ||||
| ** during initialization. | ||||
| */ | ||||
| SQLITE_PRIVATE SQLITE_NOINLINE void sqlite3ExprNullRegisterRange( | ||||
|   Parse *pParse,   /* Parsing context */ | ||||
|   int iReg,        /* First register to set to NULL */ | ||||
|   int nReg         /* Number of sequential registers to NULL out */ | ||||
| ){ | ||||
|   u8 okConstFactor = pParse->okConstFactor; | ||||
|   Expr t; | ||||
|   memset(&t, 0, sizeof(t)); | ||||
|   t.op = TK_NULLS; | ||||
|   t.y.nReg = nReg; | ||||
|   pParse->okConstFactor = 1; | ||||
|   sqlite3ExprCodeRunJustOnce(pParse, &t, iReg); | ||||
|   pParse->okConstFactor = okConstFactor; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
| ** Generate code to evaluate an expression and store the results | ||||
| ** into a register.  Return the register number where the results | ||||
| @@ -153175,6 +153202,7 @@ SQLITE_PRIVATE int sqlite3Select( | ||||
|       sqlite3VdbeAddOp2(v, OP_Integer, 0, iAbortFlag); | ||||
|       VdbeComment((v, "clear abort flag")); | ||||
|       sqlite3VdbeAddOp3(v, OP_Null, 0, iAMem, iAMem+pGroupBy->nExpr-1); | ||||
|       sqlite3ExprNullRegisterRange(pParse, iAMem, pGroupBy->nExpr); | ||||
| 
 | ||||
|       /* Begin a loop that will extract all source rows in GROUP BY order.
 | ||||
|       ** This might involve two separate loops with an OP_Sort in between, or | ||||
| @@ -168470,6 +168498,7 @@ static int whereLoopAddBtree( | ||||
|     pNew->u.btree.nEq = 0; | ||||
|     pNew->u.btree.nBtm = 0; | ||||
|     pNew->u.btree.nTop = 0; | ||||
|     pNew->u.btree.nDistinctCol = 0; | ||||
|     pNew->nSkip = 0; | ||||
|     pNew->nLTerm = 0; | ||||
|     pNew->iSortIdx = 0; | ||||
| @@ -169538,8 +169567,6 @@ static i8 wherePathSatisfiesOrderBy( | ||||
|         obSat = obDone; | ||||
|       } | ||||
|       break; | ||||
|     }else if( wctrlFlags & WHERE_DISTINCTBY ){ | ||||
|       pLoop->u.btree.nDistinctCol = 0; | ||||
|     } | ||||
|     iCur = pWInfo->pTabList->a[pLoop->iTab].iCursor; | ||||
| 
 | ||||
| @@ -257280,7 +257307,7 @@ static void fts5SourceIdFunc( | ||||
| ){ | ||||
|   assert( nArg==0 ); | ||||
|   UNUSED_PARAM2(nArg, apUnused); | ||||
|   sqlite3_result_text(pCtx, "fts5: 2025-07-17 13:25:10 3ce993b8657d6d9deda380a93cdd6404a8c8ba1b185b2bc423703e41ae5f2543", -1, SQLITE_TRANSIENT); | ||||
|   sqlite3_result_text(pCtx, "fts5: 2025-07-30 19:33:53 4d8adfb30e03f9cf27f800a2c1ba3c48fb4ca1b08b0f5ed59a4d5ecbf45e20a3", -1, SQLITE_TRANSIENT); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|   | ||||
							
								
								
									
										6
									
								
								deps/sqlite/sqlite3.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								deps/sqlite/sqlite3.h
									
									
									
									
										vendored
									
									
								
							| @@ -146,9 +146,9 @@ extern "C" { | ||||
| ** [sqlite3_libversion_number()], [sqlite3_sourceid()], | ||||
| ** [sqlite_version()] and [sqlite_source_id()]. | ||||
| */ | ||||
| #define SQLITE_VERSION        "3.50.3" | ||||
| #define SQLITE_VERSION_NUMBER 3050003 | ||||
| #define SQLITE_SOURCE_ID      "2025-07-17 13:25:10 3ce993b8657d6d9deda380a93cdd6404a8c8ba1b185b2bc423703e41ae5f2543" | ||||
| #define SQLITE_VERSION        "3.50.4" | ||||
| #define SQLITE_VERSION_NUMBER 3050004 | ||||
| #define SQLITE_SOURCE_ID      "2025-07-30 19:33:53 4d8adfb30e03f9cf27f800a2c1ba3c48fb4ca1b08b0f5ed59a4d5ecbf45e20a3" | ||||
|  | ||||
| /* | ||||
| ** CAPI3REF: Run-Time Library Version Numbers | ||||
|   | ||||
		Reference in New Issue
	
	Block a user