forked from usetania/tania-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
119 lines (90 loc) · 3.44 KB
/
Makefile
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
SHELL = /bin/bash
NODE_BINDIR = ./node_modules/.bin
export PATH := $(NODE_BINDIR):$(PATH)
LOGNAME ?= $(shell logname)
# adding the name of the user's login name to the template file, so that
# on a multi-user system several users can run this without interference
TEMPLATE_POT = ./languages/template.pot
# Where to find input files (it can be multiple paths).
INPUT_FILES = ./resources/js
# Where to write the files generated by this makefile.
OUTPUT_DIR = ./languages
# Available locales for the app.
LOCALES = en_GB id_ID hu_HU
# Name of the generated .po files for each available locale.
LOCALE_FILES ?= $(patsubst %,$(OUTPUT_DIR)/locale/app.po, $(LOCALES))
GETTEXT_SOURCES ?= $($(INPUT_FILES) 2> /dev/null)
.PHONY: all cover clean clean-osx clean-linux-arm clean-linux-amd64 clean-win64 \
osx linux-amd64 linux-arm windows fetch-dep run osxcross.bin \
cleantranslations makemessages translations
all: osx linux-amd64 linux-arm windows
clean:
@[ -f tania.osx.amd64 ] && rm -f tania.osx.amd64 || true
@[ -f tania.linux.arm ] && rm -f tania.linux.arm || true
@[ -f tania.linux.amd64 ] && rm -f tania.linux.amd64 || true
@[ -f tania.win.amd64.exe ] && rm -f tania.win.amd64.exe || true
clean-osx: tania.osx.amd64
rm -rf $^
clean-linux-arm: tania.linux.arm
rm -rf $^
clean-linux-amd64: tania.linux.amd64
rm -rf $^
clean-win64: tania.win.amd64.exe
rm -rf $^
tania.osx.amd64: main.go
CGO_ENABLED=1 GOOS=darwin GOARCH=amd64 go build -ldflags '-s -w' -o $@
file $@
osx: tania.osx.amd64
osxcross: main.go
CGO_ENABLED=1 GOOS=darwin GOARCH=amd64 \
CC=o64-clang \
CXX=o64-clang++ \
go build -ldflags '-s -w' -o tania.osx.amd64
file tania.osx.amd64
tania.linux.arm: main.go
CGO_ENABLED=1 GOOS=linux GOARCH=arm GOARM=7 \
CC=arm-linux-gnueabihf-gcc \
CXX=arm-linux-gnueabihf-g++ \
go build -ldflags '-s -w' -o $@
file $@
linux-arm: tania.linux.arm
tania.linux.amd64: main.go
CGO_ENABLED=1 GOOS=linux GOARCH=amd64 go build -ldflags '-s -w' -o $@
file $@
linux-amd64: tania.linux.amd64
tania.windows.amd64.exe: main.go
CGO_ENABLED=1 GOOS=windows GOARCH=amd64 \
CC=x86_64-w64-mingw32-gcc \
CXX=x86_64-w64-mingw32-g++ \
go build -ldflags '-s -w' -o $@
file $@
windows: tania.windows.amd64.exe
fetch-dep: Gopkg.toml Gopke.lock
dep ensure
run: main.go
go run $^
# Translation makefile
cleantranslations:
rm -f $(TEMPLATE_POT) $(OUTPUT_DIR)/translations.json
makemessages: $(TEMPLATE_POT)
translations: ./$(OUTPUT_DIR)/translations.json
# Create a main .pot template, then generate .po files for each available language.
# Thanx to Systematic: https://github.com/Polyconseil/systematic/blob/866d5a/mk/main.mk#L167-L183
$(TEMPLATE_POT): $(GETTEXT_SOURCES)
# Extract gettext strings from templates files and create a POT dictionary template.
node node_modules/vue-webpack-gettext/extract --output ./$(OUTPUT_DIR)/template.pot --src ./resources/js/
# Generate .po files for each available language.
@for lang in $(LOCALES); do \
export PO_FILE=$(OUTPUT_DIR)/locale/$$lang/LC_MESSAGES/app.po; \
mkdir -p $$(dirname $$PO_FILE); \
if [ -f $$PO_FILE ]; then \
echo "msgmerge --update $$PO_FILE $@"; \
msgmerge --lang=$$lang --update $$PO_FILE $@ || break ;\
else \
msginit --no-translator --locale=$$lang --input=$@ --output-file=$$PO_FILE || break ; \
msgattrib --no-wrap --no-obsolete -o $$PO_FILE $$PO_FILE || break; \
fi; \
done;
$(OUTPUT_DIR)/translations.json: $(LOCALE_FILES)
mkdir -p $(OUTPUT_DIR)
gettext-compile --output $@ $(LOCALE_FILES)