summaryrefslogtreecommitdiff
path: root/Makefile
blob: e2cd5e16912eba7a0299c4be8e5f11b213297862 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
src = src
ts = $(shell git ls-files $(src) | grep '\.tsx\?$$')
poname = taler-wallet-webex

gulp = node_modules/gulp/bin/gulp.js
tsc = node_modules/typescript/bin/tsc
po2json = node_modules/po2json/bin/po2json

.PHONY: pogen src/i18n/strings.js yarn-install

package-stable: tsc i18n yarn-install
	$(gulp) package-stable

package-unstable: tsc i18n yarn-install
	$(gulp) package-unstable

tsc: tsconfig.json yarn-install
	$(tsc)

yarn-install:
	yarn install

tsconfig.json: gulpfile.js yarn-install
	$(gulp) tsconfig

i18n: pogen msgmerge src/i18n/strings.js

pogen/pogen.js: pogen/pogen.ts pogen/tsconfig.json
	cd pogen; ../$(tsc)

pogen: $(ts) pogen/pogen.js yarn-install
	find $(src) \( -name '*.ts' -or -name '*.tsx' \) ! -name '*.d.ts' \
	  | xargs node pogen/pogen.js \
	  | msguniq \
	  | msgmerge src/i18n/poheader - \
	  > src/i18n/$(poname).pot

msgmerge:
	@for pofile in src/i18n/*.po; do \
	  echo merging $$pofile; \
	  msgmerge -o $$pofile $$pofile src/i18n/$(poname).pot; \
	done; \

dist:
	$(gulp) srcdist

src/i18n/strings.js: # $(ts)
	cp src/i18n/strings-prelude.js src/i18n/strings.js
	for pofile in src/i18n/*.po; do \
	  b=`basename $$pofile`; \
	  lang=$${b%%.po}; \
	  $(po2json) -F -f jed1.x -d $$lang $$pofile $$pofile.json; \
	  (echo -n "i18n.strings['$$lang'] = "; cat $$pofile.json; echo ';') >> $@; \
	done