#
# The rules for building a program.
-base_prog = $(shell basename $(PROGRAM))
+base_prog = $(notdir $(PROGRAM))
+prog_dir := $(filter-out . ./, $(dir $(PROGRAM)))
sourcefile = $(base_prog).sources
+base_prog_config := $(wildcard $(base_prog).config.$(PROFILE))
+ifndef base_prog_config
base_prog_config := $(wildcard $(base_prog).config)
+endif
ifdef base_prog_config
PROGRAM_config := $(PROGRAM).config
endif
executable_CLEAN_FILES += $(response)
endif
+ifdef KEEP_OUTPUT_FILE_COPY
+ COPY_CMD = cp
+else
+ COPY_CMD = mv
+endif
+
makefrag = $(depsdir)/$(PROFILE)_$(base_prog).makefrag
pdb = $(patsubst %.exe,%.pdb,$(PROGRAM))
mdb = $(patsubst %.exe,%.mdb,$(PROGRAM))
dist-local: dist-default
for f in `cat $(sourcefile)` ; do \
- dest=`dirname $(distdir)/$$f` ; \
- $(MKINSTALLDIRS) $$dest && cp -p $$f $$dest || exit 1 ; \
- done
+ case $$f in \
+ ../*) : ;; \
+ *) dest=`dirname $$f` ; \
+ case $$subs in *" $$dest "*) : ;; *) subs=" $$dest$$subs" ; $(MKINSTALLDIRS) $(distdir)/$$dest ;; esac ; \
+ cp -p $$f $(distdir)/$$dest || exit 1 ;; \
+ esac ; done ; \
+ for d in . $$subs ; do \
+ case $$d in .) : ;; *) test ! -f $$d/ChangeLog || cp -p $$d/ChangeLog $(distdir)/$$d ;; esac ; done
ifndef PROGRAM_COMPILE
PROGRAM_COMPILE = $(CSCOMPILE)
endif
-$(PROGRAM): $(BUILT_SOURCES) $(EXTRA_SOURCES) $(response)
- $(PROGRAM_COMPILE) /target:exe /out:$(base_prog) $(BUILT_SOURCES) $(EXTRA_SOURCES) @$(response)
+$(PROGRAM): $(BUILT_SOURCES) $(EXTRA_SOURCES) $(response) $(prog_dir:=/.stamp)
+ $(PROGRAM_COMPILE) -target:exe -out:$(base_prog) $(BUILT_SOURCES) $(EXTRA_SOURCES) @$(response)
ifneq ($(base_prog),$(PROGRAM))
- mv $(base_prog) $(PROGRAM)
- test ! -f $(base_prog).mdb || mv $(base_prog).mdb $(PROGRAM).mdb
+ $(COPY_CMD) $(base_prog) $(PROGRAM)
+ test ! -f $(base_prog).mdb || $(COPY_CMD) $(base_prog).mdb $(PROGRAM).mdb
endif
ifdef PROGRAM_config
ifneq ($(base_prog_config),$(PROGRAM_config))
executable_CLEAN_FILES += $(PROGRAM_config)
-$(PROGRAM_config): $(base_prog_config)
+$(PROGRAM_config): $(base_prog_config) $(dir $(PROGRAM_config))/.stamp
cp $(base_prog_config) $(PROGRAM_config)
endif
endif
-include $(makefrag)
all-local: $(makefrag)
-$(makefrag): $(topdir)/build/executable.make
+
+ifneq ($(response),$(sourcefile))
+$(response): $(topdir)/build/executable.make $(depsdir)/.stamp
+endif
+$(makefrag): $(topdir)/build/executable.make $(depsdir)/.stamp