Makefile - Fix mtest target (and clean up utest targets)
[tpg/acess2.git] / Usermode / Libraries / Makefile.tpl
1 # Acess2
2 # - Library Common Makefile
3 #
4
5 comma=,
6
7 LDFLAGS += -soname $(BIN)
8
9 ifeq ($(ARCH),native)
10  LDFLAGS := $(LDFLAGS:-lc=-lc_acess)
11 endif
12
13 _LD_CMD := $(lastword $(subst -, ,$(firstword $(LD))))
14 ifneq ($(_LD_CMD),ld)
15   LDFLAGS := $(subst -soname ,-Wl$(comma)-soname$(comma),$(LDFLAGS))
16   LDFLAGS := $(subst -Map ,-Wl$(comma)-Map$(comma),$(LDFLAGS))
17   LDFLAGS := $(LDFLAGS:-x=-Wl,-x)
18   LDFLAGS := $(LDFLAGS:--%=-Wl,--%)
19 endif
20
21 _BIN := $(addprefix $(OUTPUTDIR)Libs/,$(BIN))
22 _XBIN := $(addprefix $(OUTPUTDIR)Libs/,$(EXTRABIN))
23 _OBJPREFIX := obj-$(ARCH)/
24
25 _LIBS := $(filter -l%,$(LDFLAGS))
26 _LIBS := $(patsubst -l%,$(OUTPUTDIR)Libs/lib%.so,$(_LIBS))
27
28 OBJ := $(addprefix $(_OBJPREFIX),$(OBJ))
29
30 UTESTS := $(patsubst TEST_%.c,%,$(wildcard TEST_*.c))
31 DEPFILES := $(addsuffix .dep,$(OBJ))
32
33 ifeq ($(VERBOSE),1)
34 V :=
35 else
36 V := @
37 endif
38
39 .PHONY: all clean install postbuild
40
41 all: _libs $(_BIN) $(_XBIN)
42
43 .PHONY: _libs
44
45 .PRECIOUS: .no
46
47 HEADERS := $(patsubst include_exp/%,../../include/%,$(shell find include_exp/ -name \*.h 2>/dev/null))
48 _libs: $(HEADERS)
49
50 ../../include/%: include_exp/%
51         @mkdir -p $(dir $@)
52         @ln -s $(shell pwd)/$< $@
53
54 .PHONY: utest utest-build utest-run $(UTESTS:%=runtest-%)
55
56 utest: utest-build utest-run
57
58 generate_exp: $(UTESTS:%=EXP_%.txt)
59         @echo > /dev/null
60
61 utest-build: $(UTESTS:%=TEST_%)
62         @echo > /dev/null
63
64 utest-run: $(UTESTS:%=runtest-%)
65         @echo > /dev/null
66
67 $(UTESTS:%=runtest-%): runtest-%: TEST_% EXP_%.txt
68         ./TEST_$* | diff EXP_$*.txt -
69
70 clean:
71         $(RM) $(_BIN) $(_XBIN) $(OBJ) $(_BIN).dsm $(DEPFILES) $(EXTRACLEAN)
72
73 install: all
74         @echo [xCP] $(DISTROOT)/Libs/$(BIN)
75         $V$(xMKDIR) $(DISTROOT)/Libs; true
76         $V$(STRIP) $(_BIN) -o $(_BIN)_
77         $V$(xCP) $(_BIN)_ $(DISTROOT)/Libs/$(BIN)
78         $V$(RM) $(_BIN)_
79 ifneq ($(_XBIN),)
80         $(xCP) $(_XBIN) $(DISTROOT)/Libs/
81 endif
82 #ifneq ($(INCFILES),)
83 #       for f in $(INCFILES); do ln -s $f $(ACESSDIR)/include/$f; done
84 #endif
85
86 $(_BIN): $(OBJ)
87         @mkdir -p $(dir $(_BIN))
88         @echo [LD] -o $(BIN) $(OBJ)
89         $V$(LD) $(LDFLAGS) -o $(_BIN) $(OBJ) $(shell $(CC) -print-libgcc-file-name)
90         $V$(DISASM) -D -S $(_BIN) > $(_OBJPREFIX)$(BIN).dsm
91
92 $(_OBJPREFIX)%.o: %.c
93         @echo [CC] -o $@
94         @mkdir -p $(dir $@)
95         $V$(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -c $< -MMD -MP -MT $@ -MF [email protected]
96
97 $(_OBJPREFIX)%.o: %.cc
98         @echo [CXX] -o $@
99         @mkdir -p $(dir $@)
100         $V$(CXX) $(CXXFLAGS) $(CPPFLAGS) -o $@ -c $< -MMD -MP -MT $@ -MF [email protected]
101
102 $(_OBJPREFIX)%.ao: %.$(ASSUFFIX)
103         @echo [AS] -o $@
104         @mkdir -p $(dir $@)
105         $V$(AS) $(ASFLAGS) -o $@ $<
106 ifeq ($(ASSUFFIX),S)
107         $V$(AS) $(ASFLAGS) -o [email protected] $< -M
108 else
109         $V$(AS) $(ASFLAGS) -o $@ $< -M > [email protected]
110 endif
111
112 #$(OUTPUTDIR)Libs/libld-acess.so:
113 #       @make -C $(ACESSDIR)/Usermode/Libraries/ld-acess.so_src/
114 $(OUTPUTDIR)Libs/%:
115         @make -C $(ACESSDIR)/Usermode/Libraries/$*_src/
116
117
118 obj-native/%.no: %.c
119         @mkdir -p $(dir $@)
120         $(NCC) -g -c $< -o $@ -Wall -std=gnu99 -MD -MP -MF [email protected] '-D_SysDebug(f,v...)=fprintf(stderr,"DEBUG "f"\n",##v)' -include stdio.h
121
122 TEST_%: obj-native/TEST_%.no obj-native/%.no
123         $(NCC) -g -o $@ $^
124
125 -include $(UTESTS:%=obj-native/TEST_%.no.dep)
126 -include $(UTESTS:%=obj-native/%.no.dep)
127
128 -include $(DEPFILES)
129
130 # vim: ft=make

UCC git Repository :: git.ucc.asn.au