Makefileの推敲
[YACASL2.git] / src / Makefile
index 7b7f1f5..59e1189 100644 (file)
@@ -1,3 +1,4 @@
+# ヘッダファイルの場所
 INCLUDEDIR := ../include
 INCLUDE = -I $(INCLUDEDIR)
 
@@ -6,6 +7,7 @@ CC := gcc
 CFLAGS := -g -Wall -Wextra $(INCLUDE)
 CTAGS := ctags
 ETAGS := etags
+ECHO := echo
 SED := sed
 WHICH := which
 
@@ -20,16 +22,6 @@ EXECOBJ := exec dump
 
 all: build tag
 
-# ヘッダファイルの依存関係を.dファイルに出力する
-%.d: %.c
-       @($(CC) -MM -I $(INCLUDEDIR) $< | $(SED) 's/\($*\.o\):/\1 $@:/g' >$@ && echo '$@ is created from $<')
-
-# .dファイルからヘッダファイルの依存関係を取得する
-# ターゲットに clean が含まれている場合は除く
-ifneq ($(findstring $(MAKECMDGOALS),clean),clean)
-  -include $(addsuffix .d,$(CMDOBJ) $(COMMONOBJ) $(CASL2OBJ) $(ASOBJ) $(EXECOBJ))
-endif
-
 # casl2、comet2、dumpwordのビルド
 build: $(CMDOBJ)
 
@@ -39,6 +31,17 @@ comet2: comet2.o $(addsuffix .o,$(COMMONOBJ) $(CASL2OBJ) $(EXECOBJ))
 
 dumpword: dumpword.o $(addsuffix .o,$(COMMONOBJ))
 
+# .dファイルからヘッダファイルの依存関係を取得する
+# tags、check、clean、.d で終わるターゲットの場合は除く
+ifeq (,$(strip \
+    $(filter %tags,$(MAKECMDGOALS)) \
+    $(filter %check,$(MAKECMDGOALS)) \
+    $(filter %clean,$(MAKECMDGOALS)) \
+    $(filter %.d,$(MAKECMDGOALS))\
+))
+  -include $(addsuffix .d,$(CMDOBJ) $(COMMONOBJ) $(CASL2OBJ) $(ASOBJ) $(EXECOBJ))
+endif
+
 # tagファイル作成 - ctags & etags
 # コマンドがない場合はなにもしない
 tag: tags TAGS
@@ -50,13 +53,18 @@ TAGS: $(INCLUDEDIR)/*.h *.c
        $(if $(strip $(shell $(WHICH) $(ETAGS))),$(ETAGS) $^,@$(ECHO) '$(ETAGS): not found')
 
 # makeで生成したファイルの削除
-clean: clean-cmd clean-work clean-tag
+distclean: clean
+       $(RM) casl2 comet2 dumpword
+
+clean: tag-clean
+       $(RM) *.o *.d
 
-clean-cmd:
-       @$(RM) casl2 comet2 dumpword
+tag-clean:
+       $(RM) TAGS tags
 
-clean-work:
-       @$(RM) *.o *.d
+# ヘッダファイルの依存関係を.dファイルに出力する
+%.d: %.c $(INCLUDEDIR)/package.h
+       $(CC) -MM -I $(INCLUDEDIR) $< | $(SED) 's,$*\.o *:,$*.o $*.d:,g' >$@
 
-clean-tag:
-       @$(RM) TAGS tags
+$(INCLUDEDIR)/package.h: ../VERSION
+       $(MAKE) -C .. version