improve performance of 'make install'

We now only build workspace dependencies of taler-wallet-cli instead of
the whole workspace.
This commit is contained in:
Florian Dold 2022-03-08 12:56:30 +01:00
parent 3e6f6eb3d7
commit 9c758d1fe9
No known key found for this signature in database
GPG Key ID: D2E4F00F29D02A4B

View File

@ -1,8 +1,10 @@
# This Makefile has been placed in the public domain.
src = src
poname = taler-wallet-webex
tsc = node_modules/typescript/bin/tsc
pogen = node_modules/@gnu-taler/pogen/bin/pogen.js
typedoc = node_modules/typedoc/bin/typedoc
ava = node_modules/.bin/ava
nyc = node_modules/nyc/bin/nyc.js
@ -10,11 +12,6 @@ git-archive-all = ./build-system/taler-build-scripts/archive-with-submodules/git
include ./build-system/config.mk
.PHONY: compile
compile:
pnpm i -r --frozen-lockfile
pnpm run compile
.PHONY: dist
dist:
$(git-archive-all) --include ./configure taler-wallet-$(shell git describe --tags --abbrev=0).tar.gz
@ -25,7 +22,9 @@ dist-git:
$(git-archive-all) --include ./configure taler-wallet-$(shell git describe --tags).tar.gz
.PHONY: publish
publish: compile
publish:
pnpm i -r --frozen-lockfile
pnpm run compile
pnpm publish -r --no-git-checks
# make documentation from docstrings
@ -42,24 +41,49 @@ submodules-update:
git submodule update --recursive --remote
.PHONY: check
check: compile
check:
pnpm i -r --frozen-lockfile
pnpm run compile
pnpm run check
.PHONY: webextensions
webextension: compile
webextension:
pnpm i -r --frozen-lockfile
pnpm run compile
cd ./packages/taler-wallet-webextension/ && ./pack.sh
.PHONY: webextension-dev-view
webextension-dev-view: compile
webextension-dev-view:
pnpm i -r --frozen-lockfile
pnpm run compile
pnpm run --filter @gnu-taler/taler-wallet-webextension storybook
.PHONY: integrationtests
integrationtests: compile
pnpm i -r --frozen-lockfile
pnpm run compile
./packages/taler-integrationtests/testrunner '*'
.PHONY: i18n
i18n: compile
pnpm run --filter @gnu-taler/taler-wallet-webextension i18n
i18n: compile
# extract translatable strings
find $(src) \( -name '*.ts' -or -name '*.tsx' \) ! -name '*.d.ts' \
| xargs node $(pogen) \
| msguniq \
| msgmerge src/i18n/poheader - \
> src/i18n/$(poname).pot
# merge existing translations
@for pofile in src/i18n/*.po; do \
echo merging $$pofile; \
msgmerge -o $$pofile $$pofile src/i18n/$(poname).pot; \
done;
# generate .ts file containing all translations
cat src/i18n/strings-prelude > src/i18n/strings.ts
@for pofile in src/i18n/*.po; do \
echo appending $$pofile; \
./contrib/po2ts $$pofile >> src/i18n/strings.ts; \
done;
./node_modules/.bin/prettier --config .prettierrc --write src/i18n/strings.ts
# Some commands are only available when ./configure has been run
@ -71,7 +95,8 @@ install: warn-noprefix
else
install_target = $(prefix)/lib/taler-wallet-cli
.PHONY: install
install: compile
install:
pnpm install --frozen-lockfile --filter @gnu-taler/taler-wallet-cli...
install -d $(prefix)/bin
install -d $(install_target)/bin
install -d $(install_target)/node_modules/taler-wallet-cli