]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - Makefile
build revision watermark
[xonotic/xonotic-data.pk3dir.git] / Makefile
1 SCM := $(shell if [ -d .svn ]; then echo svn; elif [ -d ../.git ]; then echo git; fi)
2 FTEQCC ?= fteqcc
3 PERL ?= perl
4 PK3NAME ?= `date +../data%Y%m%d.pk3`
5 ZIP ?= 7za a -tzip -mx=9
6 ZIPEXCLUDE ?= -x\!*.pk3 -xr\!\.svn -x\!qcsrc
7 DIFF ?= diff
8
9 FTEQCCFLAGS_WATERMARK ?= -DWATERMARK='"^1$(shell git describe) TEST BUILD"'
10 FTEQCCFLAGS ?= -Werror -Wall -Wno-mundane -O3 -Ono-c -Ono-cs -flo $(FTEQCCFLAGS_EXTRA) $(FTEQCCFLAGS_WATERMARK)
11 FTEQCCFLAGS_PROGS ?= 
12 FTEQCCFLAGS_MENU ?= 
13
14 # NOTE: use -DUSE_FTE instead of -TFTE here!
15 # It will automagically add an engine check with -TID and then change back to -TFTE
16 FTEQCCFLAGS_CSPROGS ?= 
17
18 # xonotic svn build system overrides this by command line argument
19 NEX_BUILDSYSTEM =
20
21 all: qc
22
23 .PHONY: update-cvarcount
24 update-cvarcount:
25         [ "$(NEX_BUILDSYSTEM)" = "" ] || [ "$(NEX_BUILDSYSTEM)" = "1" ]
26         [ "$(NEX_BUILDSYSTEM)" != "" ] || { ! [ -f ../misc/netradiant-XonoticPack/xonotic.game/data/entities.def ] || $(DIFF) scripts/entities.def ../misc/netradiant-XonoticPack/xonotic.game/data/entities.def || { echo entities.def mismatch, please merge ../misc/netradiant-XonoticPack/xonotic.game/data/entities.def and scripts/entities.def; exit 1; }; }
27         [ "$(NEX_BUILDSYSTEM)" != "" ] || { DO_NOT_RUN_MAKE=1 sh update-cvarcount.sh; }
28
29 .PHONY: qc
30 qc: update-cvarcount
31         $(MAKE) qc-recursive
32
33 .PHONY: qc-recursive
34 qc-recursive: menu.dat progs.dat csprogs.dat
35
36 .PHONY: skin
37 skin: gfx/menu/default/skinvalues.txt
38
39 .PHONY: pk3
40 pk3: $(PK3NAME)
41
42 .PHONY: pk3here
43 pk3here: qc
44         $(RM) $(PK3NAME); \
45         set -ex; \
46                 ABSPK3NAME=$(PK3NAME); \
47                 case $$ABSPK3NAME in \
48                         /*) \
49                                 ;; \
50                         *) \
51                                 ABSPK3NAME=$$PWD/$$ABSPK3NAME; \
52                                 ;; \
53                 esac; \
54                 $(ZIP) $(ZIPEXCLUDE) $$ABSPK3NAME .
55
56 .PHONY: clean
57 clean:
58         rm -f progs.dat menu.dat csprogs.dat
59
60 csprogs.dat: qcsrc/client/*.* qcsrc/common/*.* qcsrc/warpzonelib/*.*
61         cd qcsrc/client && $(FTEQCC) $(FTEQCCFLAGS) $(FTEQCCFLAGS_CSPROGS)
62
63 progs.dat: qcsrc/server/*.* qcsrc/common/*.* qcsrc/server/*/*.* qcsrc/server/*/*/*.* qcsrc/warpzonelib/*.*
64         cd qcsrc/server && $(FTEQCC) $(FTEQCCFLAGS) $(FTEQCCFLAGS_PROGS)
65
66 menu.dat: qcsrc/menu/*.* qcsrc/menu/*/*.* qcsrc/common/*.*
67         cd qcsrc/menu && $(FTEQCC) $(FTEQCCFLAGS) $(FTEQCCFLAGS_MENU)
68
69 gfx/menu/default/skinvalues.txt: qcsrc/menu/skin-customizables.inc
70         $(PERL) qcsrc/menu/skin-customizables.inc > gfx/menu/default/skinvalues.txt
71
72 $(PK3NAME): qc
73         $(RM) $(PK3NAME)
74         set -ex; \
75                 ABSPK3NAME=$(PK3NAME); \
76                 case $$ABSPK3NAME in \
77                         /*) \
78                                 ;; \
79                         *) \
80                                 ABSPK3NAME=$$PWD/$$ABSPK3NAME; \
81                                 ;; \
82                 esac; \
83                 TDIR=`mktemp -d -t xonoticpk3.XXXXXX`; \
84                 cp -v progs.dat csprogs.dat menu.dat $$TDIR/; \
85                 svn export --force . $$TDIR; \
86                 cd $$TDIR; \
87                 $(ZIP) $$ABSPK3NAME .
88
89 .PHONY: testcase
90 testcase:
91         cd qcsrc/testcase && $(FTEQCC) $(FTEQCCFLAGS) $(FTEQCCFLAGS_CSPROGS) -DTESTCASE="$$TESTCASE"
92
93 .PHONY: update commit diff log logv logupdate logvupdate revert
94 update: $(SCM)-update
95 commit: $(SCM)-commit
96 diff: $(SCM)-diff
97 log: $(SCM)-log
98 logv: $(SCM)-logv
99 revert: $(SCM)-revert
100 logupdate: log update
101 logvupdate: logv update
102
103 .PHONY: svn-update
104 svn-update:
105         cd .. && svn update
106
107 .PHONY: svn-commit
108 svn-commit:
109         cd .. && svn commit
110
111 .PHONY: svn-diff
112 svn-diff:
113         cd .. && svn diff
114
115 .PHONY: svn-log
116 svn-log:
117         cd .. && svn log -r HEAD:BASE
118
119 .PHONY: svn-logv
120 svn-logv:
121         cd .. && svn log -r HEAD:BASE -v
122
123 .PHONY: svn-revert
124 svn-revert:
125         svn revert -- $(FILE)
126
127 .PHONY: git-update
128 git-update:
129         git pull origin
130
131 .PHONY: git-commit
132 git-commit:
133         git commit -a || true
134         if echo -n 'Also send to server? Hit Enter for yes, ^C for no. '; read -r L; then \
135                 git config svn-remote.svn.url svn://svn.icculus.org/xonotic; \
136                 git config svn-remote.svn.fetch trunk:refs/remotes/origin/master; \
137                 git svn dcommit; \
138         fi
139
140 .PHONY: git-diff
141 git-diff:
142         git diff; git diff origin/master..HEAD; true
143
144 .PHONY: git-log
145 git-log:
146         git fetch && git log HEAD..origin/master
147
148 .PHONY: git-logv
149 git-logv:
150         git fetch && git log -v HEAD..origin/master
151
152 .PHONY: git-revert
153 git-revert:
154         git checkout -- $(FILE)