- C For\sCLI\s.sha3sum,\semit\swarning\sto\sstderr\sfor\sany\sinvalidly\sencoded\stext\sfields.
- D 2022-12-06T18:48:37.123
- C Have\ssqlite3_stmt_scanstatus_v2()\sreturn\san\sNCYCLE\svalue\sfor\sall\sloops,\snot\sjust\svirtual\stables\sones.\sThe\svalue\sreturned\sis\sthe\ssum\sof\sthe\sNCYCLE\scounts\sfor\sthe\svarious\sopcodes\sthat\smove\sor\sread\sdata\sfrom\sthe\stable\sor\sindex\scursor\sassociated\swith\sthe\sloop.
- D 2022-12-06T18:48:06.154
-C Avoid\sseveral\s-Wall\swarnings\sin\stextfixture\sbuild.
-D 2022-12-06T19:20:49.029
+++C Merge\sfrom\strunk\sprepratory\sto\sbranch\send.
+++D 2022-12-06T19:25:07.478
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
F src/random.c 606b00941a1d7dd09c381d3279a058d771f406c5213c9932bbd93d5587be4b9c
F src/resolve.c efea4e5fbecfd6d0a9071b0be0d952620991673391b6ffaaf4c277b0bb674633
F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
- F src/select.c 6983de0e6b8b68c97f82f9fca27ffb8f17161cff4d0d48fdf9eb40b213da0cc6
- F src/shell.c.in cf32c16e1b4ff8e434b51fe38753bfddccd75d4a3ecb1fb838a6f96a70e2ff3a
- F src/sqlite.h.in 3439711b72cf1a541716da3671ac40f8d5957cdecfc192d47d32f7aed94207c2
+ F src/select.c 56162cde2f71314826f831618eae853205628080afa25cd90faef7a9b761dee4
--F src/shell.c.in 991eff7f819f96ae76671e7aa44597ac702274fd441d3b0d9297cbd3b9ce1284
+++F src/shell.c.in b5bc6e14605b8d1e8de729454d98d3353ad7e529a8d2b6e34080d068e99bff99
+ F src/sqlite.h.in 1fe1836879ecbb2e28f00f44eb6092db09a2a06bf072af351c6c2466bd515496
F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
F src/sqlite3ext.h c4b9fa7a7e2bcdf850cfeb4b8a91d5ec47b7a00033bc996fd2ee96cbf2741f5f
- F src/sqliteInt.h 4ddd98e423276714479f9f22dbbda050e8ef99aa97e7e26bf0bdf58acef0ca42
+ F src/sqliteInt.h 0c9934acd88e0fa14f0d4743233b4cd7bd7bbc84099ba3cad50d8e69676ce2b9
F src/sqliteLimit.h d7323ffea5208c6af2734574bae933ca8ed2ab728083caa117c9738581a31657
F src/status.c 160c445d7d28c984a0eae38c144f6419311ed3eace59b44ac6dafc20db4af749
F src/table.c 0f141b58a16de7e2fbe81c308379e7279f4c6b50eb08efeec5892794a0ba30d1
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
- P 123f2a0785790addf9c60a0fd09077dda9cb84d33a2594901a2b22bb555be491
- R 1a108a993a6e5c4e1463804542f95600
- P 540e895d877fab1ea138786e56923a202018f68c78199a89adfc296c75735b30
- R e347a9226ee206cfe1e680e2e5e722d0
- U dan
- Z eaf9f5c14b0f034256d24205aa5d85c9
-P 9499b2f51e8174c6b8a67840c92ba23b7dd1dc8dc2b91fca0c5dc07b71662149
-R 6d3961aec4c1529b866a56388835711c
+++P 8e833ecc81367658e81acd1d3a0242ab954a62d6f719af56f1d185656d0b73e6 9499b2f51e8174c6b8a67840c92ba23b7dd1dc8dc2b91fca0c5dc07b71662149 03ae8680e430c6d2c39ca26fa2cb6eed46e3c3e52b53f7a8bf548560446c6d3d
+++R 2aee8123cf630f6dc747669c6dfb6cfe
+ U larrybr
- Z 23502144cb7b8e35b977c4658f2c6efa
-Z 815c066cfe76a0b0ad34b27b7be96db7
+++Z 454f785f671f223a15f2524ef9698b47
# Remove this line to create a well-formed Fossil manifest.
- 8e833ecc81367658e81acd1d3a0242ab954a62d6f719af56f1d185656d0b73e6
- 9499b2f51e8174c6b8a67840c92ba23b7dd1dc8dc2b91fca0c5dc07b71662149
-03ae8680e430c6d2c39ca26fa2cb6eed46e3c3e52b53f7a8bf548560446c6d3d
+++1d01f8483af7b6a4e93a49fd8bbb6a2b9300e969b574efeb96d56081a33055c4
}else{
shell_exec(p, zSql, 0);
}
- const char *zGenQuery = sqlite3_column_text(pStmt,0);
++ {
++ int lrc;
++ char *zRevText = /* Query for reversible to-blob-to-text check */
++ "SELECT lower(name) as tname FROM sqlite_schema\n"
++ "WHERE type='table' AND coalesce(rootpage,0)>1\n"
++ "AND name NOT LIKE 'sqlite_%%'%s\n"
++ "ORDER BY 1 collate nocase";
++ zRevText = sqlite3_mprintf(zRevText, zLike? " AND name LIKE $tspec" : "");
++ zRevText = sqlite3_mprintf(
++ /* lower-case query is first run, producing upper-case query. */
++ "with tabcols as materialized(\n"
++ "select tname, cname\n"
++ "from ("
++ " select ss.tname as tname, ti.name as cname\n"
++ " from (%z) ss\n inner join pragma_table_info(tname) ti))\n"
++ "select 'SELECT total(bad_text_count) AS bad_text_count\n"
++ "FROM ('||group_concat(query, ' UNION ALL ')||')' as btc_query\n"
++ " from (select 'SELECT COUNT(*) AS bad_text_count\n"
++ "FROM '||tname||' WHERE '\n"
++ "||group_concat('CAST(CAST('||cname||' AS BLOB) AS TEXT)<>'||cname\n"
++ "|| ' AND typeof('||cname||')=''text'' ',\n"
++ "' OR ') as query, tname from tabcols group by tname)"
++ , zRevText);
++ shell_check_oom(zRevText);
++ if( bDebug ) utf8_printf(p->out, "%s\n", zRevText);
++ lrc = sqlite3_prepare_v2(p->db, zRevText, -1, &pStmt, 0);
++ assert(lrc==SQLITE_OK);
++ if( zLike ) sqlite3_bind_text(pStmt,1,zLike,-1,SQLITE_STATIC);
++ lrc = SQLITE_ROW==sqlite3_step(pStmt);
++ if( lrc ){
+++ const char *zGenQuery = (char*)sqlite3_column_text(pStmt,0);
++ sqlite3_stmt *pCheckStmt;
++ lrc = sqlite3_prepare_v2(p->db, zGenQuery, -1, &pCheckStmt, 0);
++ if( bDebug ) utf8_printf(p->out, "%s\n", zGenQuery);
++ if( SQLITE_OK==lrc ){
++ if( SQLITE_ROW==sqlite3_step(pCheckStmt) ){
++ double countIrreversible = sqlite3_column_double(pCheckStmt, 0);
++ if( countIrreversible>0 ){
++ int n = (int)(countIrreversible + 0.5);
++ utf8_printf(stderr,
++ "Digest includes %d invalidly encoded text field%s.\n",
++ n, (n>1)? "s": "");
++ }
++ }
++ sqlite3_finalize(pCheckStmt);
++ }
++ sqlite3_finalize(pStmt);
++ }
++ sqlite3_free(zRevText);
++ }
sqlite3_free(zSql);
}else