diff options
author | Sebastian <sebasjm@gmail.com> | 2021-08-23 16:51:49 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2021-08-23 16:52:33 -0300 |
commit | 67e511d719cbc3e7f2b391a8d6914406caa2fb24 (patch) | |
tree | 0dc25e6c26ba0acc4c2aa217e1d30bfb1112268d /contrib/build-fast-web.sh | |
parent | 39cbad89bbed61487a973e4df92084da1b0dc728 (diff) | |
download | wallet-core-67e511d719cbc3e7f2b391a8d6914406caa2fb24.tar.xz |
updated build fast for web
Diffstat (limited to 'contrib/build-fast-web.sh')
-rwxr-xr-x | contrib/build-fast-web.sh | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/contrib/build-fast-web.sh b/contrib/build-fast-web.sh new file mode 100755 index 000000000..ddc9f10f3 --- /dev/null +++ b/contrib/build-fast-web.sh @@ -0,0 +1,139 @@ +#!/usr/bin/env bash + +set -eu +set -x + +export DIST=build/web +export NODE_PATH=$DIST:vendor + +export BUNDLE_OPTIONS='--bundle --format=esm --target=esnext' + +function build_idb() { + rm -rf packages/idb-bridge/{node_modules,lib,dist,tsconfig.tsbuildinfo} + idb_dir=$DIST/@gnu-taler/idb-bridge + mkdir -p $idb_dir + esbuild $BUNDLE_OPTIONS packages/idb-bridge/src/index.ts > $idb_dir/index.js +} + +function build_taler_util() { + taler_util_dir=$DIST/@gnu-taler/taler-util + mkdir -p $taler_util_dir + rm -rf packages/taler-util/{node_modules,lib,dist,tsconfig.tsbuildinfo} + + esbuild $BUNDLE_OPTIONS packages/taler-util/src/index.ts > $taler_util_dir/index.js +} + +function build_fflate() { + fflate_dir=$DIST/fflate + mkdir -p $fflate_dir + esbuild $BUNDLE_OPTIONS vendor/fflate/src/index.ts > $fflate_dir/index.js +} + +function build_ct() { + ct_dir=$DIST/cancellationtoken + mkdir -p $ct_dir + esbuild $BUNDLE_OPTIONS vendor/cancellationtoken/src/index.ts > $ct_dir/index.js +} + +function build_wallet_core() { + taler_wallet_core_dir=$DIST/@gnu-taler/taler-wallet-core + + rm -rf packages/taler-wallet-core/{node_modules,lib,dist,tsconfig.tsbuildinfo} + + mkdir -p $taler_wallet_core_dir + esbuild $BUNDLE_OPTIONS --external:@gnu-taler/taler-util packages/taler-wallet-core/src/index.browser.ts > $taler_wallet_core_dir/index.js +} + +function build_wallet_embedded() { + taler_wallet_embedded_dir=$DIST/@gnu-taler/taler-wallet-embedded + rm -rf packages/taler-wallet-embedded/{node_modules,lib,dist,tsconfig.tsbuildinfo} + + mkdir -p $taler_wallet_embedded_dir + esbuild $BUNDLE_OPTIONS packages/taler-wallet-embedded/src/index.ts > $taler_wallet_embedded_dir/taler-wallet-embedded.js +} + +function build_vendor() { + mkdir -p $DIST/$1 + + esbuild $BUNDLE_OPTIONS vendor/$1/src/index.js > $DIST/$1/index.js +} + +function build_preact() { + mkdir -p $DIST/preact/{debug,hooks} + + esbuild $BUNDLE_OPTIONS vendor/preact/src/index.js > $DIST/preact/index.js + esbuild $BUNDLE_OPTIONS --external:preact vendor/preact/hooks/src/index.js > $DIST/preact/hooks/index.js + esbuild $BUNDLE_OPTIONS --external:preact vendor/preact/debug/src/index.js > $DIST/preact/debug/index.js +} + +function build_preact-router() { + mkdir -p $DIST/preact-router/match + + esbuild $BUNDLE_OPTIONS --external:preact vendor/preact-router/src/index.js > $DIST/preact-router/index.js + esbuild $BUNDLE_OPTIONS --loader:.js=jsx --external:preact --external:preact-router vendor/preact-router/src/match.js > $DIST/preact-router/match/index.js +} + +function build_preact_compat() { + mkdir -p $DIST/{react/jsx-runtime,react-dom/test-utils} + + esbuild $BUNDLE_OPTIONS --loader:.js=jsx vendor/preact/compat/src/index.js > $DIST/react/index.js + + esbuild $BUNDLE_OPTIONS --loader:.js=jsx --external:preact vendor/preact/compat/src/index.js > $DIST/react/index.js + esbuild $BUNDLE_OPTIONS --loader:.js=jsx --external:preact vendor/preact/compat/src/index.js > $DIST/react-dom/index.js + esbuild $BUNDLE_OPTIONS --loader:.js=jsx vendor/preact/jsx-runtime/src/index.js > $DIST/react/jsx-runtime/index.js + esbuild $BUNDLE_OPTIONS --loader:.js=jsx vendor/preact/test-utils/src/index.js > $DIST/react-dom/test-utils/index.js +} + +function build_history() { + mkdir -p $DIST/{history,resolve-pathname,value-equal,tiny-warning,tiny-invariant} + + esbuild $BUNDLE_OPTIONS --loader:.js=ts vendor/tiny-warning/src/index.js > $DIST/tiny-warning/index.js + esbuild $BUNDLE_OPTIONS --loader:.js=ts vendor/tiny-invariant/src/index.js > $DIST/tiny-invariant/index.js + + esbuild $BUNDLE_OPTIONS vendor/resolve-pathname/modules/index.js > $DIST/resolve-pathname/index.js + esbuild $BUNDLE_OPTIONS vendor/value-equal/modules/index.js > $DIST/value-equal/index.js + + esbuild $BUNDLE_OPTIONS vendor/history/modules/index.js > $DIST/history/index.js +} + +function build_linaria() { + mkdir -p $DIST/@linaria/{react,core} + mkdir -p $DIST/@emotion/is-prop-valid + + esbuild $BUNDLE_OPTIONS vendor/@emotion/is-prop-valid/index.js > $DIST/@emotion/is-prop-valid/index.js + + esbuild $BUNDLE_OPTIONS vendor/@linaria/packages/core/src/index.ts > $DIST/@linaria/core/index.js + esbuild $BUNDLE_OPTIONS --external:preact vendor/@linaria/packages/react/src/index.ts > $DIST/@linaria/react/index.js +} + +function build_wallet_webextension() { + rm -rf packages/taler-wallet-webextension/{node_modules,lib,dist,tsconfig.tsbuildinfo,extension} + + taler_wallet_webextension_dir=packages/taler-wallet-webextension/dist + mkdir -p $taler_wallet_webextension_dir + + esbuild $BUNDLE_OPTIONS packages/taler-wallet-webextension/src/background.ts > $taler_wallet_webextension_dir/background.js + esbuild $BUNDLE_OPTIONS packages/taler-wallet-webextension/src/browserWorkerEntry.ts > $taler_wallet_webextension_dir/browserWorkerEntry.js + + # implemented as a script because right now esbuild binary does not support plugins + # FIXME: remove javascript when possible + node ./contrib/build-fast-with-linaria.mjs packages/taler-wallet-webextension/src/popupEntryPoint.tsx $taler_wallet_webextension_dir + node ./contrib/build-fast-with-linaria.mjs packages/taler-wallet-webextension/src/walletEntryPoint.tsx $taler_wallet_webextension_dir +} + + +build_idb +build_taler_util +build_fflate +build_wallet_core + +build_vendor date-fns + +build_preact +build_preact-router +build_preact_compat + +build_history +build_linaria + +build_wallet_webextension |