]> rtime.felk.cvut.cz Git - omk.git/commitdiff
Fixed build in subdirectories
authorMichal Sojka <sojkam1@fel.cvut.cz>
Tue, 30 Dec 2008 20:55:01 +0000 (21:55 +0100)
committerMichal Sojka <sojkam1@fel.cvut.cz>
Tue, 30 Dec 2008 20:55:01 +0000 (21:55 +0100)
devel-test/Makefile.omk
devel-test/dir/Makefile [new file with mode: 0644]
devel-test/dir/Makefile.omk [new file with mode: 0644]
devel-test/dir/test.c [new file with mode: 0644]
devel-test/test.c [deleted file]
snippets/Makefile.rules.test
snippets/base
snippets/build

index dd0139e00a7778017e976707cf74002859ee2f67..87e884847779e0fdfabef4440b570a7a0320d990 100644 (file)
@@ -1,3 +1 @@
-bin_PROGRAMS = test
-
-test_SOURCES = test.c
\ No newline at end of file
+SUBDIRS=dir
diff --git a/devel-test/dir/Makefile b/devel-test/dir/Makefile
new file mode 100644 (file)
index 0000000..b22a357
--- /dev/null
@@ -0,0 +1,14 @@
+# Generic directory or leaf node makefile for OCERA make framework
+
+ifndef MAKERULES_DIR
+MAKERULES_DIR := $(shell ( old_pwd="" ;  while [ ! -e Makefile.rules ] ; do if [ "$$old_pwd" = `pwd`  ] ; then exit 1 ; else old_pwd=`pwd` ; cd -L .. 2>/dev/null ; fi ; done ; pwd ) )
+endif
+
+ifeq ($(MAKERULES_DIR),)
+all : default
+.DEFAULT::
+       @echo -e "\nThe Makefile.rules has not been found in this or partent directory\n"
+else
+include $(MAKERULES_DIR)/Makefile.rules
+endif
+
diff --git a/devel-test/dir/Makefile.omk b/devel-test/dir/Makefile.omk
new file mode 100644 (file)
index 0000000..13d3ec5
--- /dev/null
@@ -0,0 +1,4 @@
+bin_PROGRAMS = test
+
+test_SOURCES = test.c
+test_LIBS = m
diff --git a/devel-test/dir/test.c b/devel-test/dir/test.c
new file mode 100644 (file)
index 0000000..822e084
--- /dev/null
@@ -0,0 +1,7 @@
+#include <stdio.h>
+
+int main()
+{
+        printf("Hello world\n");
+        return 0;
+}
diff --git a/devel-test/test.c b/devel-test/test.c
deleted file mode 100644 (file)
index f24b7bd..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-#include <stdio.h>
-
-int main()
-{
-#ifdef NUMBER
-        printf("NUMBER is %d\n", NUMBER);
-#endif
-        return 0;
-}
index c6a17e7364f9acf885dd51a1ef8b9faa1b76789b..d16e073a20df1315c97099ff60d07b06cdd62b8e 100644 (file)
@@ -60,7 +60,12 @@ program_cmd = set -e; $(if $(filter %.cc,$($(1)_SOURCES)),$(CXX),$(CC)) \
        sed -n -e 's|^LOAD \(.*\)$$$$|  \1  \&|p' $(USER_OBJS_DIR)/$(1).exe.map|tr '&' '\134'  >>$(USER_OBJS_DIR)/$(1).exe.d; \
        echo >>$(USER_OBJS_DIR)/$(1).exe.d
 
-
+prepare-pass: create-build-dirs
+create-build-dirs::
+ifneq ($(bin_PROGRAMS),)
+create-build-dirs::
+       @$(call mkdir_def,$(USER_OBJS_DIR))
+endif
 $(foreach prog,$(bin_PROGRAMS),$(eval $(call program_template,$(prog),bin)))
 #$(foreach prog,$(bin_PROGRAMS),$(info >>>$(call program_template,$(prog),bin)<<<))
 $(foreach src,$(filter %.c,$(USER_SOURCES)),\
@@ -70,11 +75,11 @@ $(foreach src,$(filter %.c,$(USER_SOURCES)),\
                "CC      ",\
                $(c_o_cmd))))
 
-$(eval $(call prepare_rule_goal,\
-               $(USER_OBJS_DIR)/test.X.o,\
-               $(SOURCES_DIR)/test.c,\
-               "CC      ",\
-               $(c_o_cmd)))
+$(eval $(call prepare_rule_goal,\
+#              $(USER_OBJS_DIR)/test.X.o,\
+#              $(SOURCES_DIR)/test.c,\
+#              "CC      ",\
+#              $(c_o_cmd)))
 
 check-dir::
        @$(call mkdir_def,$(USER_BUILD_DIR))
index 08c441092521905f84a702fc6482aa706211c108..37f6d8a0a7af07ea970946e5693b4ad3e8eff856 100644 (file)
@@ -33,7 +33,7 @@ ifndef OUTPUT_DIR
 OUTPUT_DIR := $(MAKERULES_DIR)
 endif
 
-.PHONY: all default check-make-ver omkize prepare build
+.PHONY: all default check-make-ver omkize prepare build-pseudo-pass
 
 ifdef W
   ifeq ("$(origin W)", "command line")
@@ -49,12 +49,12 @@ ifneq ($(OMK_WHOLE_TREE),1)
   omk_checks=check-make-ver check-dir
   export omk_prereq_checked=1
   endif
-all: build
+all: build-pseudo-pass
 
 prepare: $(omk_checks) prepare-pass
-build: prepare
+build-pseudo-pass: prepare
        +@echo "make[omk]: build"
-       @$(MAKE) -C $(MAKERULES_DIR) -f Makefile.rules build-pseudo-pass
+       @$(MAKE) -C $(MAKERULES_DIR) -f Makefile.rules build
        @echo "Compilation finished"
 
 prepare-pass: $(omk_checks)
@@ -206,7 +206,7 @@ distclean dist-clean:
 # Common OMK templates
 # ====================
 
-# Syntax: $(call mkdir,<dir name>)
+# Syntax: $(call mkdir_def,<dir name>)
 define mkdir_def
        [ -d $(1) ] || mkdir -p $(1) || exit 1
 endef
@@ -241,7 +241,6 @@ define omk_pass_subdir_template
 .PHONY: $(pass)-$(2)-subdir
 $(pass)-subdirs: $(pass)-$(2)-subdir
 $(pass)-$(2)-subdir:
-       @$(call mkdir_def,$(OMK_WORK_DIR)/$(2))
        +@$(MAKE) SOURCES_DIR=$(SOURCES_DIR)/$(2) $(NO_PRINT_DIRECTORY) \
                RELATIVE_DIR=$(RELATIVE_PREFIX)$(2) -C $(2) \
                -f $(SUBDIR_MAKEFILE) $(pass)
@@ -260,7 +259,7 @@ extra-rules-$(1):
                SOURCES_DIR=$(SOURCES_DIR)/$(1) RELATIVE_DIR=$(RELATIVE_PREFIX)$(1) -C $(SOURCES_DIR)/$(1)
 endef
 
-.PHONY: extra-rules-subdirs
+.PHONY: extra-rules-subdirs mkdir-omk-work
 extra-rules-subdirs:
 
 $(foreach subdir,$(EXTRA_RULES_SUBDIRS),$(eval $(call extra_rules_subdir_template,$(subdir))))
@@ -269,13 +268,17 @@ $(foreach subdir,$(EXTRA_RULES_SUBDIRS),$(eval $(call extra_rules_subdir_templat
 define omk_pass_template
 .PHONY: $(pass) $(pass)-local $(pass)-msg $(pass)-subdirs
 $(pass): $(pass)-local
-$(pass)-local: $(pass)-subdirs $(pass)-msg
+$(pass)-local: $(pass)-subdirs $(pass)-msg mkdir-omk-work
 $(foreach subdir,$(SUBDIRS),$(call omk_pass_subdir_template,$(pass),$(subdir)))
 
 $(pass)-msg: $(pass)-subdirs
        +@echo "make[omk]: $(pass) in $(RELATIVE_DIR)"
 endef
 
+mkdir-omk-work:
+       @$(call mkdir_def,$(OMK_WORK_DIR))
+
+
 
 # =======================
 # DEFAULT CONFIG PASS
index c939665de9a8d44725fa59f6415ec52cd97d5918..4a7318870980d0a38940614d43e455b3a29e47b1 100644 (file)
@@ -2,7 +2,7 @@
 ##################### -*- makefile-gmake -*-
 # Build pseudo-pass #
 #####################
-ifneq (,$(filter build-pseudo-pass,$(MAKECMDGOALS)))
+ifneq (,$(filter build,$(MAKECMDGOALS)))
 rule_targets = $(value $(1)_targets)
 rule_deps    = $(value $(1)_deps)
 rule_msg     = $(value $(1)_msg)
@@ -21,8 +21,8 @@ endef
 
 $(foreach rule,$(prepared_rules),$(eval $(call build_rule,$(rule))))
 
-.PHONY: build-pseudo-pass
+.PHONY: build
 
-build-pseudo-pass: $(omk_goals)
+build: $(omk_goals)
 
 endif # (,$(filter build,$(MAKECMDGOALS)))