X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=Makefile;h=d27eb2d292f5526f20be17c86ab36f907531422c;hb=87b251552f58323aa76828de607e8e335f3c8467;hp=be3d181bde5a8178d7fcc6fe6cad2c5d86dc948c;hpb=6c699be2856c963bcc0e197845a199193f66d19a;p=libc-test diff --git a/Makefile b/Makefile index be3d181..d27eb2d 100644 --- a/Makefile +++ b/Makefile @@ -1,14 +1,36 @@ B:=src SRCS:=$(sort $(wildcard src/*/*.c)) OBJS:=$(SRCS:src/%.c=$(B)/%.o) -DIRS:=$(patsubst src/%,%,$(filter-out src/REPORT,$(sort $(wildcard src/*)))) +DIRS:=$(patsubst src/%/,%,$(sort $(dir $(SRCS)))) BDIRS:=$(DIRS:%=$(B)/%) NAMES:=$(SRCS:src/%.c=%) -CFLAGS:=-Isrc/common +CFLAGS:=-Isrc/common -I$(B)/common LDLIBS:=$(B)/common/libtest.a +AR = $(CROSS_COMPILE)ar +RANLIB = $(CROSS_COMPILE)ranlib all: %.mk: +# turn off evil implicit rules +.SUFFIXES: +%: %.o +%: %.c +%: %.cc +%: %.C +%: %.cpp +%: %.p +%: %.f +%: %.F +%: %.r +%: %.s +%: %.S +%: %.mod +%: %.sh +%: %,v +%: RCS/%,v +%: RCS/% +%: s.% +%: SCCS/s.% config.mak: cp config.mak.def $@ @@ -38,7 +60,7 @@ endef $(foreach n,$(NAMES),$(eval $(call template,$(n)))) BINS:=$(foreach n,$(NAMES),$($(n).BINS)) $(B)/api/main -LIBS:=$(foreach n,$(NAMES),$($(n).LIBS)) $(B)/common/run +LIBS:=$(foreach n,$(NAMES),$($(n).LIBS)) $(B)/common/runtest ERRS:=$(BINS:%=%.err) debug: @@ -51,7 +73,6 @@ debug: define target_template $(1).ERRS:=$$(filter $(B)/$(1)/%,$$(ERRS)) $(B)/$(1)/all: $(B)/$(1)/REPORT -# TODO: $(B)/common/run collides with the run binary target $(B)/$(1)/run: $(B)/$(1)/cleanerr $(B)/$(1)/REPORT $(B)/$(1)/cleanerr: rm -f $$(filter-out $(B)/$(1)/%-static.err,$$($(1).ERRS)) @@ -70,34 +91,37 @@ $(B)/common/libtest.a: $(common.OBJS) $(AR) rc $@ $^ $(RANLIB) $@ -$(ERRS): $(B)/common/run | $(BDIRS) +$(ERRS): $(B)/common/runtest | $(BDIRS) $(BINS) $(LIBS): $(B)/common/libtest.a $(OBJS): src/common/test.h | $(BDIRS) $(BDIRS): mkdir -p $@ +$(B)/common/options.h: src/common/options.h.in + $(CC) -E - <$< | sed -e '1,/optiongroups_unistd_end/d' -e '/^#/d' -e '/^[[:space:]]*$$/d' -e 's/^/#define /' >$@ + $(B)/common/mtest.o: src/common/mtest.h $(math.OBJS): src/common/mtest.h $(B)/api/main: $(api.OBJS) api/main.OBJS:=$(api.OBJS) +$(api.OBJS):$(B)/common/options.h $(api.OBJS):CFLAGS+=-pedantic-errors -Werror -Wno-unused -D_XOPEN_SOURCE=700 -$(api.OBJS):CFLAGS+=-DX_PS -DX_TPS -DX_SS all:$(B)/REPORT run:$(B)/REPORT clean: - rm -f $(OBJS) $(BINS) $(LIBS) $(B)/common/libtest.a $(B)/common/run $(B)/*/*.err + rm -f $(OBJS) $(BINS) $(LIBS) $(B)/common/libtest.a $(B)/common/runtest $(B)/common/options.h $(B)/*/*.err cleanall: clean rm -f $(B)/REPORT $(B)/*/REPORT $(B)/REPORT: cat $^ |tee $@ -$(B)/%.o: src/%.c +$(B)/%.o:: src/%.c $(CC) $(CFLAGS) $($*.CFLAGS) -c -o $@ $< 2>$@.err || echo BUILDERROR $@ -$(B)/%.s: src/%.c +$(B)/%.s:: src/%.c $(CC) $(CFLAGS) $($*.CFLAGS) -S -o $@ $< || echo BUILDERROR $@ -$(B)/%.lo: src/%.c +$(B)/%.lo:: src/%.c $(CC) $(CFLAGS) $($*.CFLAGS) -fPIC -DSHARED -c -o $@ $< 2>$@.err || echo BUILDERROR $@ $(B)/%.so: $(B)/%.lo $(CC) -shared $(LDFLAGS) $($*.so.LDFLAGS) -o $@ $< $($*.so.LOBJS) $(LDLIBS) $($*.so.LDLIBS) 2>$@.err || echo BUILDERROR $@ @@ -115,7 +139,7 @@ $(B)/%: $(B)/%.o %.ld.err: % touch $@ %.err: % - $(B)/common/run ./$< 2>/dev/null >$@ || true + $(B)/common/runtest ./$< >$@ || true .PHONY: all run clean cleanall