src/Makefileで、.dファイルをインクルードする書き方を修正
[YACASL2.git] / src / Makefile
1 # ソースファイル。グループに分類
2 CMDOBJ := casl2 comet2 dumpword
3 COMMONOBJ := word cmem cerr
4 CASL2OBJ := struct hash
5 ASOBJ := assemble token label
6 EXECOBJ := exec dump
7
8 # ヘッダファイル
9 INCLUDEDIR := ../include
10 INCLUDE = -I $(INCLUDEDIR)
11
12 # コマンド
13 CC := gcc
14 CFLAGS := -g -Wall -Wextra $(INCLUDE)
15 CTAGS := ctags
16 ETAGS := etags
17 ECHO := echo
18 SED := sed
19 WHICH := which
20
21 .PHONY: all build tag clean
22
23 all: build tag
24
25 # casl2、comet2、dumpwordのビルド
26 build: $(CMDOBJ)
27
28 casl2: $(addsuffix .o,casl2 $(COMMONOBJ) $(CASL2OBJ) $(ASOBJ) $(EXECOBJ))
29
30 comet2: $(addsuffix .o,comet2 $(COMMONOBJ) $(CASL2OBJ) $(EXECOBJ))
31
32 dumpword: $(addsuffix .o,dumpword $(COMMONOBJ))
33
34 # .dファイルからヘッダファイルの依存関係を取得する
35 # tags、check、clean、.d で終わるターゲットの場合は除く
36 NODEP := %tags %check %clean %.d
37 ifeq ($(filter $(NODEP),$(MAKECMDGOALS)),)
38   -include $(addsuffix .d,$(CMDOBJ) $(COMMONOBJ) $(CASL2OBJ) $(ASOBJ) $(EXECOBJ))
39 endif
40
41 # tagファイル作成 - ctags & etags
42 # コマンドがない場合はなにもしない
43 tag: tags TAGS
44
45 tags: $(INCLUDEDIR)/*.h *.c
46         $(if $(strip $(shell $(WHICH) $(CTAGS))),$(CTAGS) $^,@$(ECHO) '$(CTAGS): not found')
47
48 TAGS: $(INCLUDEDIR)/*.h *.c
49         $(if $(strip $(shell $(WHICH) $(ETAGS))),$(ETAGS) $^,@$(ECHO) '$(ETAGS): not found')
50
51 # makeで生成したファイルの削除
52 distclean: clean
53         $(RM) casl2 comet2 dumpword
54
55 clean:
56         $(RM) *.o *.d
57
58 tag-clean:
59         $(RM) TAGS tags
60
61 # ヘッダファイルの依存関係を.dファイルに出力する
62 %.d: %.c $(INCLUDEDIR)/package.h
63         $(CC) -MM -I $(INCLUDEDIR) $< | $(SED) 's,$*\.o *:,$*.o $*.d:,g' >$@
64
65 $(INCLUDEDIR)/package.h: ../VERSION
66         $(MAKE) -C .. version