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