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 | |
parent | 39cbad89bbed61487a973e4df92084da1b0dc728 (diff) |
updated build fast for web
Diffstat (limited to 'contrib')
-rwxr-xr-x | contrib/build-fast-node.sh (renamed from contrib/build-fast.sh) | 35 | ||||
-rwxr-xr-x | contrib/build-fast-web.sh | 139 | ||||
-rw-r--r-- | contrib/build-fast-with-linaria.mjs | 42 |
3 files changed, 198 insertions, 18 deletions
diff --git a/contrib/build-fast.sh b/contrib/build-fast-node.sh index b73041e74..b514694fb 100755 --- a/contrib/build-fast.sh +++ b/contrib/build-fast-node.sh @@ -3,59 +3,56 @@ set -eu set -x -export NODE_PATH=vendor:build +export DIST=build/node +export NODE_PATH=$DIST:vendor function build_idb() { - rm -rf packages/idb-bridge/node_modules - idb_dir=build/@gnu-taler/idb-bridge + rm -rf packages/idb-bridge/{node_modules,lib,dist,tsconfig.tsbuildinfo} + idb_dir=$DIST/@gnu-taler/idb-bridge mkdir -p $idb_dir esbuild --platform=node --bundle packages/idb-bridge/src/index.ts > $idb_dir/index.js } function build_taler_util() { - taler_util_dir=build/@gnu-taler/taler-util + rm -rf packages/taler-util/{node_modules,lib,dist,tsconfig.tsbuildinfo} + taler_util_dir=$DIST/@gnu-taler/taler-util mkdir -p $taler_util_dir esbuild --platform=node --bundle packages/taler-util/src/index.ts > $taler_util_dir/index.js } function build_fflate() { - fflate_dir=build/fflate + fflate_dir=$DIST/fflate mkdir -p $fflate_dir esbuild --platform=node --bundle vendor/fflate/src/index.ts > $fflate_dir/index.js } function build_ct() { - ct_dir=build/cancellationtoken + ct_dir=$DIST/cancellationtoken mkdir -p $ct_dir esbuild --target=es6 --platform=node --bundle vendor/cancellationtoken/src/index.ts > $ct_dir/index.js } function build_wallet_core() { - taler_wallet_core_dir=build/@gnu-taler/taler-wallet-core - - rm -rf packages/taler-wallet-core/node_modules - rm -rf packages/taler-wallet-core/lib - rm -rf packages/taler-wallet-core/dist + rm -rf packages/taler-wallet-core/{node_modules,lib,dist,tsconfig.tsbuildinfo} + taler_wallet_core_dir=$DIST/@gnu-taler/taler-wallet-core mkdir -p $taler_wallet_core_dir - esbuild --platform=node --bundle packages/taler-wallet-core/src/index.node.ts > $taler_wallet_core_dir/index.js + esbuild --platform=node --bundle --external:@gnu-taler/taler-util packages/taler-wallet-core/src/index.node.ts > $taler_wallet_core_dir/index.js } function build_wallet_embedded() { - taler_wallet_embedded_dir=build/@gnu-taler/taler-wallet-embedded + rm -rf packages/taler-wallet-embedded/{node_modules,lib,dist,tsconfig.tsbuildinfo} + taler_wallet_embedded_dir=$DIST/@gnu-taler/taler-wallet-embedded mkdir -p $taler_wallet_embedded_dir esbuild --platform=node --bundle packages/taler-wallet-embedded/src/index.ts > $taler_wallet_embedded_dir/taler-wallet-embedded.js } function build_wallet_cli() { - taler_wallet_cli_dir=build/@gnu-taler/taler-wallet-cli + rm -rf packages/taler-wallet-cli/{node_modules,lib,dist,tsconfig.tsbuildinfo} + taler_wallet_cli_dir=$DIST/@gnu-taler/taler-wallet-cli mkdir -p $taler_wallet_cli_dir - rm -rf packages/taler-wallet-cli/node_modules - rm -rf packages/taler-wallet-cli/lib - rm -rf packages/taler-wallet-cli/dist - esbuild --platform=node --bundle packages/taler-wallet-cli/src/index.ts > $taler_wallet_cli_dir/index.js cp $taler_wallet_cli_dir/index.js $taler_wallet_cli_dir/taler-wallet-cli.js } @@ -67,4 +64,6 @@ build_fflate build_wallet_core build_wallet_embedded build_ct + build_wallet_cli + 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 diff --git a/contrib/build-fast-with-linaria.mjs b/contrib/build-fast-with-linaria.mjs new file mode 100644 index 000000000..88ce75f18 --- /dev/null +++ b/contrib/build-fast-with-linaria.mjs @@ -0,0 +1,42 @@ + +import linaria from '@linaria/esbuild' +import esbuild from 'esbuild' + +if (process.argv.length !== 4) { + console.log(` +Usage: + ${process.argv[1]} <entryPoint> <outDir> + +entryPoint: file to be converted +outputDir: destination directory +`) + process.exit(1) +} + +esbuild + .build({ + entryPoints: [process.argv[2]], + bundle: true, + outdir: process.argv[3], + minify: false, + nodePaths: ['build/web', 'vendor'], + loader: { + '.svg': 'dataurl', + '.png': 'dataurl', + }, + target: [ + 'esnext' + ], + format: 'esm', + jsxFactory: 'h', + jsxFragment: 'Fragment', + define: { + 'process.env.NODE_ENV' : '"development"', + }, + plugins: [ + linaria.default({ + sourceMap: true, + }), + ], + }) + .catch (() => process.exit(1)); |