mirror of
https://github.com/sqlite/sqlite.git
synced 2025-10-24 09:53:10 +03:00
wasm dist: add --snapshot flag, add -64 flag to include 64-bit builds, and add module-symbols.html to the dist.
FossilOrigin-Name: e9a6391b377b6964620285192262a4dc9fe1712799f7aa8a8b37c5f718544ed2
This commit is contained in:
@@ -1420,7 +1420,7 @@ dist-name-prefix = sqlite-wasm$(dist-name-extra)
|
||||
dist:
|
||||
./mkdist.sh $(dist-name-prefix)
|
||||
snapshot:
|
||||
./mkdist.sh $(dist-name-prefix)-snapshot-$(shell /usr/bin/date +%Y%m%d)
|
||||
./mkdist.sh $(dist-name-prefix) --snapshot
|
||||
endif
|
||||
# ^^^ making dist/snapshot
|
||||
CLEAN_FILES += $(wildcard sqlite-wasm-*.zip)
|
||||
|
@@ -97,8 +97,9 @@
|
||||
wrapper is significantly easier to use, however.</li>
|
||||
<li><a href='demo-worker1-promiser.html'>demo-worker1-promiser</a>:
|
||||
a demo of the Promise-based wrapper of the Worker1 API.</li>
|
||||
<!--li><a href='demo-worker1-promiser-esm.html'>demo-worker1-promiser-esm</a>:
|
||||
same as the previous demo except loads the promiser from an ESM module.</li-->
|
||||
<li><a href='module-symbols.html'>module-symbols</a> gives
|
||||
a high-level overview of the symbols exposed by the JS
|
||||
module.</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
|
@@ -1,7 +1,26 @@
|
||||
#!/usr/bin/env bash
|
||||
###
|
||||
#
|
||||
# Creates the zip bundle for the sqlite3 wasm builds.
|
||||
# $1 is a build name, defaulting to sqlite-wasm.
|
||||
# Builds the SQLite JS/WASM distribution zip file.
|
||||
#
|
||||
# Usage: $0 build-name ?flags?
|
||||
#
|
||||
# build-name is the dir/archive name prefix for the
|
||||
# build and defaults to sqlite-wasm.
|
||||
#
|
||||
# -?|--help = Show this text
|
||||
#
|
||||
# -0 = Use -O0 instead of ${optFlag}
|
||||
#
|
||||
# -1 = Use make -j1 instead of ${makeFlag}
|
||||
#
|
||||
# -64 = Include 64-bit builds
|
||||
#
|
||||
# --noclean = do not run 'make clean' first
|
||||
#
|
||||
# --snapshot = gives the archive name a distinctive suffix
|
||||
#
|
||||
###
|
||||
|
||||
function die(){
|
||||
local rc=$1
|
||||
@@ -10,16 +29,56 @@ function die(){
|
||||
exit $rc
|
||||
}
|
||||
|
||||
buildName=${1-sqlite-wasm}
|
||||
dirTop=../..
|
||||
buildName=
|
||||
b64=0
|
||||
optFlag=-Oz
|
||||
clean=1
|
||||
makeFlag=-j4
|
||||
snapshotSuffix=
|
||||
for arg in $@; do
|
||||
case $arg in
|
||||
|
||||
-64) b64=1
|
||||
;;
|
||||
|
||||
-0) optFlag=-O0
|
||||
;;
|
||||
|
||||
-1) makeFlag=
|
||||
;;
|
||||
|
||||
--noclean) clean=0
|
||||
;;
|
||||
|
||||
--snapshot)
|
||||
snapshotSuffix=$(date +%Y%m%d)
|
||||
;;
|
||||
|
||||
-?|--help)
|
||||
sed -n -e '2,/^###/p' $0
|
||||
exit
|
||||
;;
|
||||
|
||||
*) if [[ x != x${buildName} ]]; then
|
||||
die 1 "Unhandled argument: $arg"
|
||||
fi
|
||||
buildName=$arg
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
make=
|
||||
for i in gmake make; do
|
||||
make=$(which $i 2>/dev/null)
|
||||
[[ x != x$make ]] && break
|
||||
[[ x != x${make} ]] && break
|
||||
done
|
||||
[[ x = x$make ]] && die 127 "Cannot find make"
|
||||
|
||||
dirTop=../..
|
||||
|
||||
[[ x = x${buildName} ]] && buildName=sqlite-wasm
|
||||
|
||||
buildName=${buildName}${snapshotSuffix}
|
||||
|
||||
echo "Creating the SQLite wasm dist bundle..."
|
||||
|
||||
@@ -28,23 +87,30 @@ echo "Creating the SQLite wasm dist bundle..."
|
||||
# neaded for the dist bundle.
|
||||
#
|
||||
tgtFiles=(
|
||||
tester1.html
|
||||
tester1-worker.html
|
||||
tester1-esm.html
|
||||
tester1.js tester1.mjs
|
||||
demo-worker1-promiser.html
|
||||
demo-worker1-promiser.js
|
||||
demo-worker1-promiser-esm.html
|
||||
demo-worker1-promiser.mjs
|
||||
|
||||
tester1.html
|
||||
tester1-esm.html
|
||||
tester1-worker.html
|
||||
tester1.js
|
||||
tester1.mjs
|
||||
)
|
||||
|
||||
if false; then
|
||||
optFlag=-O0
|
||||
else
|
||||
optFlag=-Oz
|
||||
$make clean
|
||||
if [[ 1 = $b64 ]]; then
|
||||
tgtFiles+=(
|
||||
tester1-64bit.html
|
||||
tester1-esm-64bit.html
|
||||
tester1-worker-64bit.html
|
||||
tester1-64bit.js
|
||||
tester1-64bit.mjs
|
||||
)
|
||||
fi
|
||||
$make -j4 \
|
||||
|
||||
[[ 1 = $clean ]] && $make clean
|
||||
$make $makeFlag \
|
||||
t-version-info t-stripccomments \
|
||||
${tgtFiles[@]} \
|
||||
"emcc_opt=${optFlag}" || die $?
|
||||
@@ -54,14 +120,19 @@ rm -fr $dirTmp
|
||||
mkdir -p $dirTmp/jswasm || die $?
|
||||
mkdir -p $dirTmp/common || die $?
|
||||
|
||||
# Files for the top-most dir:
|
||||
# Static files for the top-most dir:
|
||||
fTop=(
|
||||
demo-123.html
|
||||
demo-123-worker.html
|
||||
demo-123.js
|
||||
|
||||
demo-worker1.html
|
||||
demo-worker1.js
|
||||
|
||||
demo-jsstorage.html
|
||||
demo-jsstorage.js
|
||||
demo-123.html
|
||||
demo-123-worker.html demo-123.js
|
||||
|
||||
module-symbols.html
|
||||
)
|
||||
|
||||
# Files for the jswasm subdir sans jswasm prefix:
|
||||
@@ -82,8 +153,15 @@ fJ2=(
|
||||
sqlite3.mjs
|
||||
)
|
||||
|
||||
# fW = list of wasm files to copy from jswasm/.
|
||||
fW=(sqlite3.wasm)
|
||||
if [[ 1 = $b64 ]]; then
|
||||
fW+=(sqlite3-64bit.wasm)
|
||||
fi
|
||||
|
||||
function fcp() {
|
||||
cp -p $@ || die $?
|
||||
chmod +w ${@: -1}
|
||||
}
|
||||
|
||||
function scc(){
|
||||
@@ -95,12 +173,15 @@ fcp ${tgtFiles[@]} $dirTmp/.
|
||||
fcp README-dist.txt $dirTmp/README.txt
|
||||
fcp index-dist.html $dirTmp/index.html
|
||||
fcp common/*.css common/SqliteTestUtil.js $dirTmp/common/.
|
||||
fcp $jw/sqlite3.wasm $dirTmp/$jw/.
|
||||
|
||||
for i in ${fTop[@]}; do
|
||||
fcp $i $dirTmp/.
|
||||
done
|
||||
|
||||
for i in ${fW[@]}; do
|
||||
fcp $jw/$i $dirTmp/$jw/.
|
||||
done
|
||||
|
||||
for i in ${fJ1[@]}; do
|
||||
scc -k < $jw/$i > $dirTmp/$jw/$i || die $?
|
||||
done
|
||||
@@ -112,13 +193,17 @@ done
|
||||
#
|
||||
# Done copying files. Now zip it up...
|
||||
#
|
||||
|
||||
svi=${dirTop}/version-info
|
||||
vnum=$($svi --download-version)
|
||||
vdir=${buildName}-${vnum}
|
||||
fzip=${vdir}.zip
|
||||
rm -fr ${vdir} ${fzip}
|
||||
mv $dirTmp $vdir || die $?
|
||||
zip -rq $fzip $(find $vdir -type f | sort) || die $?
|
||||
zip -rq9 $fzip $(find $vdir -type f | sort) || die $?
|
||||
ls -la $fzip
|
||||
unzip -lv $fzip || die $?
|
||||
cat <<EOF
|
||||
**
|
||||
** Unzipped files are in $vdir
|
||||
**
|
||||
EOF
|
||||
|
16
manifest
16
manifest
@@ -1,5 +1,5 @@
|
||||
C Replace\sext/wasm/dist.make\swith\smkdist.sh\sand\sget\sdist\sworking\swith\sthe\snew\sbuild.\sFix\sthe\spreprocessing\sflags\sfor\stester1-esm.html.
|
||||
D 2025-09-25T17:29:12.649
|
||||
C wasm\sdist:\sadd\s--snapshot\sflag,\sadd\s-64\sflag\sto\sinclude\s64-bit\sbuilds,\sand\sadd\smodule-symbols.html\sto\sthe\sdist.
|
||||
D 2025-09-25T18:53:28.163
|
||||
F .fossil-settings/binary-glob 61195414528fb3ea9693577e1980230d78a1f8b0a54c78cf1b9b24d0a409ed6a x
|
||||
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
||||
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
||||
@@ -578,7 +578,7 @@ F ext/session/sqlite3session.c b3de195ce668cace9b324599bf6255a70290cbfb5451e826e
|
||||
F ext/session/sqlite3session.h 7404723606074fcb2afdc6b72c206072cdb2b7d8ba097ca1559174a80bc26f7a
|
||||
F ext/session/test_session.c 8766b5973a6323934cb51248f621c3dc87ad2a98f023c3cc280d79e7d78d36fb
|
||||
F ext/wasm/EXPORTED_FUNCTIONS.fiddle.in 27450c8b8c70875a260aca55435ec927068b34cef801a96205adb81bdcefc65c
|
||||
F ext/wasm/GNUmakefile e478287749fcd55285072c4161cc6b9d6f448f14f9d84501de1a093734c9fd97
|
||||
F ext/wasm/GNUmakefile f5c8895122666957bcf2b83a7bcef3e06e16d60b710282397f29bfa013e9c4bc
|
||||
F ext/wasm/README-dist.txt f01081a850ce38a56706af6b481e3a7878e24e42b314cfcd4b129f0f8427066a
|
||||
F ext/wasm/README.md 66ace67ae98a45e4116f2ca5425b716887bcee4d64febee804ff6398e1ae9ec7
|
||||
F ext/wasm/SQLTester/GNUmakefile e0794f676d55819951bbfae45cc5e8d7818dc460492dc317ce7f0d2eca15caff
|
||||
@@ -629,11 +629,11 @@ F ext/wasm/example_extra_init.c 2347cd69d19d839ef4e5e77b7855103a7fe3ef2af86f2e8c
|
||||
F ext/wasm/fiddle/fiddle-worker.js 7798af02e672e088ff192716f80626c8895e19301a65b8af6d5d12b2d13d2451
|
||||
F ext/wasm/fiddle/fiddle.js 84fd75967e0af8b69d3dd849818342227d0f81d13db92e0dcbc63649b31a4893
|
||||
F ext/wasm/fiddle/index.html a27b8127ef9ecf19612da93b2a6a73bdb3777b5c56b5450bb7200a94bc108ff9
|
||||
F ext/wasm/index-dist.html 56132399702b15d70c474c3f1952541e25cb0922942868f70daf188f024b3730
|
||||
F ext/wasm/index-dist.html db23748044e286773f2768eec287669501703b5d5f72755e8db73607dc54d290
|
||||
F ext/wasm/index.html 1b329fb63e057c02a17ce178308d6b06aac62d92af7dd6d821fb0e183e0f1557
|
||||
F ext/wasm/jaccwabyt/jaccwabyt.js bbac67bc7a79dca34afe6215fd16b27768d84e22273507206f888c117e2ede7d
|
||||
F ext/wasm/jaccwabyt/jaccwabyt.md 167fc0b624c9bc2c477846e336de9403842d81b1a24fc4d3b24317cb9eba734f
|
||||
F ext/wasm/mkdist.sh 94e12f6cfb6131b90a994e7eab5a4b734e8f277fe38cffc3b37e775eb8fe8611 x
|
||||
F ext/wasm/mkdist.sh 29f8a37a7aba41fa5df8e89b1fab02b83b35c43473c5cf808584872e022514b8 x
|
||||
F ext/wasm/mkwasmbuilds.c 3f27681fd3b32a78560feb3bb54f0f46a68f75024f65d9c5d4247f6bd08a04ad
|
||||
F ext/wasm/module-symbols.html dc476b403369b26a1a23773e13b80f41b9a49f0825e81435fe3600a7cfbbe337
|
||||
F ext/wasm/scratchpad-wasmfs.html a3d7388f3c4b263676b58b526846e9d02dfcb4014ff29d3a5040935286af5b96
|
||||
@@ -2170,8 +2170,8 @@ F tool/version-info.c 3b36468a90faf1bbd59c65fd0eb66522d9f941eedd364fabccd7227350
|
||||
F tool/warnings-clang.sh bbf6a1e685e534c92ec2bfba5b1745f34fb6f0bc2a362850723a9ee87c1b31a7
|
||||
F tool/warnings.sh 1ad0169b022b280bcaaf94a7fa231591be96b514230ab5c98fbf15cd7df842dd
|
||||
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
|
||||
P 2f4be98614b49def2c2951887796c736269ef3bb7ba5b045cae5f748ae165a83
|
||||
R 2f32df5d7d259ad6860333afe5e70fec
|
||||
P ab6eb4d3b723107da488770b1849b9f1d1c491348f1eaa544e0e07356b8fac7d
|
||||
R 5604f99b6885eee7b3387abf567432cd
|
||||
U stephan
|
||||
Z 6108442ce190e421e8fe73707ba2c0fe
|
||||
Z 54eb9cf8d86f8180d0b259e57237e3ca
|
||||
# Remove this line to create a well-formed Fossil manifest.
|
||||
|
@@ -1 +1 @@
|
||||
ab6eb4d3b723107da488770b1849b9f1d1c491348f1eaa544e0e07356b8fac7d
|
||||
e9a6391b377b6964620285192262a4dc9fe1712799f7aa8a8b37c5f718544ed2
|
||||
|
Reference in New Issue
Block a user