summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--Makefile.test2
-rw-r--r--Rules.make5
2 files changed, 4 insertions, 3 deletions
diff --git a/Makefile.test b/Makefile.test
index 392ea37..cf9f28c 100644
--- a/Makefile.test
+++ b/Makefile.test
@@ -1,39 +1,41 @@
1#!/usr/bin/make -f 1#!/usr/bin/make -f
2export OPIEDIR:=$(shell pwd) 2export OPIEDIR:=$(shell pwd)
3export TOPDIR:=$(OPIEDIR) 3export TOPDIR:=$(OPIEDIR)
4 4
5export QMAKESPECSDIR=$(OPIEDIR)/mkspecs 5export QMAKESPECSDIR=$(OPIEDIR)/mkspecs
6export QMAKESPEC=$(QMAKESPECSDIR)/qws/linux-generic-g++ 6export QMAKESPEC=$(QMAKESPECSDIR)/qws/linux-generic-g++
7 7
8configs += $(TOPDIR)/core/applets/restartapplet2/config.in $(TOPDIR)/core/applets/config.in $(TOPDIR)/core/apps/config.in $(TOPDIR)/core/multimedia/config.in $(TOPDIR)/core/pim/config.in $(TOPDIR)/core/pim/today/plugins/config.in $(TOPDIR)/core/settings/config.in $(TOPDIR)/core/config.in $(TOPDIR)/development/config.in $(TOPDIR)/inputmethods/config.in $(TOPDIR)/libopie/ofileselector/config.in $(TOPDIR)/libopie/pim/config.in $(TOPDIR)/libsql/config.in $(TOPDIR)/noncore/applets/config.in $(TOPDIR)/noncore/apps/opie-console/test/config.in $(TOPDIR)/noncore/apps/config.in $(TOPDIR)/noncore/comm/config.in $(TOPDIR)/noncore/decorations/config.in $(TOPDIR)/noncore/games/config.in $(TOPDIR)/noncore/graphics/config.in $(TOPDIR)/noncore/multimedia/config.in $(TOPDIR)/noncore/net/config.in $(TOPDIR)/noncore/net/opietooth/config.in $(TOPDIR)/noncore/settings/config.in $(TOPDIR)/noncore/styles/config.in $(TOPDIR)/noncore/tools/calc2/config.in $(TOPDIR)/noncore/tools/config.in $(TOPDIR)/noncore/unsupported/opiemail/ifaces/config.in $(TOPDIR)/noncore/unsupported/config.in $(TOPDIR)/noncore/config.in $(TOPDIR)/noncore/todayplugins/config.in $(TOPDIR)/x11/ipc/server/config.in $(TOPDIR)/x11/ipc/config.in $(TOPDIR)/x11/config.in /usr/src/coding/projects/userspace/opie/config.in
9
8# $(TOPDIR)/.config depends on .depends.cfgs, as it depends on $(configs) 10# $(TOPDIR)/.config depends on .depends.cfgs, as it depends on $(configs)
9# in order to have a full set of config.in files. 11# in order to have a full set of config.in files.
10# .depends depends on $(TOPDIR)/.config 12# .depends depends on $(TOPDIR)/.config
11# everything else depends on .depends, to ensure the dependencies are 13# everything else depends on .depends, to ensure the dependencies are
12# intact. 14# intact.
13# 15#
14# NOTE: The order in which things happen in this makefile is 16# NOTE: The order in which things happen in this makefile is
15 # -critical-. Do not rearrange this! 17 # -critical-. Do not rearrange this!
16 18
17all : $(TOPDIR)/.config 19all : $(TOPDIR)/.config
18 20
19$(TOPDIR)/.config : $(TOPDIR)/.depends.cfgs 21$(TOPDIR)/.config : $(TOPDIR)/.depends.cfgs
20 22
21all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(TOPDIR)/.depends 23all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(TOPDIR)/.depends
22 24
23clean-configs : $(TOPDIR)/.depends.cfgs 25clean-configs : $(TOPDIR)/.depends.cfgs
24 @echo "Wiping generated config.in files..." 26 @echo "Wiping generated config.in files..."
25 @-rm -f $(configs) 27 @-rm -f $(configs)
26 28
27-include $(TOPDIR)/.depends.cfgs 29-include $(TOPDIR)/.depends.cfgs
28 30
29all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(configs) 31all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(configs)
30 32
31$(TOPDIR)/.config: $(TOPDIR)/.depends.cfgs $(configs) 33$(TOPDIR)/.config: $(TOPDIR)/.depends.cfgs $(configs)
32 $(call descend,scripts/kconfig,conf) 34 $(call descend,scripts/kconfig,conf)
33 @if [ ! -e $@ ]; then \ 35 @if [ ! -e $@ ]; then \
34 cp $(TOPDIR)/def-configs/opie $@; \ 36 cp $(TOPDIR)/def-configs/opie $@; \
35 fi; 37 fi;
36 @$(MAKE) -C scripts/kconfig conf; 38 @$(MAKE) -C scripts/kconfig conf;
37 ./scripts/kconfig/conf -s ./config.in 39 ./scripts/kconfig/conf -s ./config.in
38 40
39# config rules must have the $(configs) var defined 41# config rules must have the $(configs) var defined
diff --git a/Rules.make b/Rules.make
index 33ff350..1342b49 100644
--- a/Rules.make
+++ b/Rules.make
@@ -1,43 +1,42 @@
1## targets ## 1## targets ##
2 2
3$(configs) : 3$(configs) :
4 $(call makecfg,$@) 4 $(call makecfg,$@)
5 5
6$(TOPDIR)/.depends : $(shell if [ -e $(TOPDIR)/config.in ]\; then echo $(TOPDIR)/config.in\; fi\;) $(TOPDIR)/.config $(TOPDIR)/packages 6$(TOPDIR)/.depends : $(shell if [ -e $(TOPDIR)/config.in ]\; then echo $(TOPDIR)/config.in\; fi\;) $(TOPDIR)/.config $(TOPDIR)/packages
7 @echo Generating dependency information... 7 @echo Generating dependency information...
8# add to subdir-y, and add descend rules 8# add to subdir-y, and add descend rules
9 @cat $(TOPDIR)/packages | \ 9 @cat $(TOPDIR)/packages | \
10 awk '/^#/ { next }; {print \ 10 awk '/^#/ { next }; {print \
11 ".PHONY : " $$2 "\n" \ 11 ".PHONY : " $$2 "\n" \
12 "subdir-$$(" $$1 ") += " $$2 "\n\n" \ 12 "subdir-$$(" $$1 ") += " $$2 "\n\n" \
13 $$2 "/Makefile : " $$2 "/" $$3 " $$(TOPDIR)/qmake/qmake\n\t" \ 13 $$2 "/Makefile : " $$2 "/" $$3 " $$(TOPDIR)/qmake/qmake\n\t" \
14 "$$(call makefilegen,$$@)\n\n" \ 14 "$$(call makefilegen,$$@)\n\n" \
15 $$2 " : " $$2 "/Makefile\n\t$$(call descend,$$@)\n"}'\ 15 $$2 " : " $$2 "/Makefile\n\t$$(call descend,$$@)\n"}'\
16 > $(TOPDIR)/.depends 16 > $(TOPDIR)/.depends
17# interpackage dependency generation 17# interpackage dependency generation
18 @cat $(TOPDIR)/packages | \ 18 @cat $(TOPDIR)/packages | \
19 $(TOPDIR)/scripts/deps.pl >> $(TOPDIR)/.depends 19 $(TOPDIR)/scripts/deps.pl >> $(TOPDIR)/.depends
20 20
21$(TOPDIR)/.depends.cfgs: 21$(TOPDIR)/.depends.cfgs:
22# generation of config.in files, and config.in interdependencies 22# config.in interdependencies
23 @find $(TOPDIR)/ -name config.in | ( for cfg in `cat`; do dir=`dirname $$cfg`; name=`basename $$dir`; if [ ! -e $$dir/$$name.pro ]; then echo $$dir; fi; done; ) > dirs 23 @echo $(configs) | sed -e 's,/config.in,,g' | ( for i in `cat`; do echo $$i; done ) > dirs
24 @echo "configs += `echo \`cat dirs | sed -e's,^$(TOPDIR)/,$$(TOPDIR)/,g' -e's,$$,/config.in,g'\``" >> $@
25 @cat dirs | ( for i in `cat`; do if [ "`cat dirs|grep $$i 2>/dev/null|wc -l`" -ne "1" ]; then deps=`cat dirs|grep $$i| grep -v "^$$i$$"|for i in \`cat|sed -e's,^$(TOPDIR)/,$$(TOPDIR)/,g'\`; do echo $$i/config.in; done`; echo `echo $$i/config.in|sed -e 's,^$(TOPDIR)/,$$(TOPDIR)/,'` : $$deps; fi; done ) >> $@ 24 @cat dirs | ( for i in `cat`; do if [ "`cat dirs|grep $$i 2>/dev/null|wc -l`" -ne "1" ]; then deps=`cat dirs|grep $$i| grep -v "^$$i$$"|for i in \`cat|sed -e's,^$(TOPDIR)/,$$(TOPDIR)/,g'\`; do echo $$i/config.in; done`; echo `echo $$i/config.in|sed -e 's,^$(TOPDIR)/,$$(TOPDIR)/,'` : $$deps; fi; done ) >> $@
26 @-rm -f dirs 25 @-rm -f dirs
27 26
28$(TOPDIR)/scripts/lxdialog/lxdialog $(TOPDIR)/scripts/kconfig/conf scripts/kconfig/conf $(TOPDIR)/scripts/kconfig/mconf scripts/kconfig/mconf $(TOPDIR)/scripts/kconfig/qconf scripts/kconfig/qconf $(TOPDIR)/qmake/qmake : 27$(TOPDIR)/scripts/lxdialog/lxdialog $(TOPDIR)/scripts/kconfig/conf scripts/kconfig/conf $(TOPDIR)/scripts/kconfig/mconf scripts/kconfig/mconf $(TOPDIR)/scripts/kconfig/qconf scripts/kconfig/qconf $(TOPDIR)/qmake/qmake :
29 $(call descend,$(shell dirname $@),$(shell basename $@)) 28 $(call descend,$(shell dirname $@),$(shell basename $@))
30 29
31## general rules ## 30## general rules ##
32 31
33define descend 32define descend
34 $(MAKE) -C $(1) $(2) 33 $(MAKE) -C $(1) $(2)
35endef 34endef
36 35
37define makefilegen 36define makefilegen
38 cd $(shell dirname $(1)); $(TOPDIR)/qmake/qmake $(3) -o $(shell basename $(1)) `echo $(1)|sed -e 's,/Makefile$$,,g' -e 's,.*/,,g'`.pro 37 cd $(shell dirname $(1)); $(TOPDIR)/qmake/qmake $(3) -o $(shell basename $(1)) `echo $(1)|sed -e 's,/Makefile$$,,g' -e 's,.*/,,g'`.pro
39endef 38endef
40 39
41define makecfg 40define makecfg
42 $(TOPDIR)/scripts/makecfg.pl $1 41 $(TOPDIR)/scripts/makecfg.pl $1
43endef 42endef