author | kergoth <kergoth> | 2002-11-06 00:23:35 (UTC) |
---|---|---|
committer | kergoth <kergoth> | 2002-11-06 00:23:35 (UTC) |
commit | 2129e9cd500a7755062c93f3b9ea325b9368ea37 (patch) (unidiff) | |
tree | a35fac4ec75b5533142b4aac6a3a708d55e060e9 | |
parent | b461afb1563d0af5cdd1705b61f9c920ad124907 (diff) | |
download | opie-2129e9cd500a7755062c93f3b9ea325b9368ea37.zip opie-2129e9cd500a7755062c93f3b9ea325b9368ea37.tar.gz opie-2129e9cd500a7755062c93f3b9ea325b9368ea37.tar.bz2 |
custom.h rule
-rw-r--r-- | Makefile.test | 14 | ||||
-rw-r--r-- | Rules.make | 9 | ||||
-rw-r--r-- | config.in.in | 5 |
3 files changed, 17 insertions, 11 deletions
diff --git a/Makefile.test b/Makefile.test index a98eb0d..9af15dc 100644 --- a/Makefile.test +++ b/Makefile.test | |||
@@ -27,33 +27,33 @@ clean-configs : $(TOPDIR)/.depends.cfgs | |||
27 | 27 | ||
28 | -include $(TOPDIR)/.depends.cfgs | 28 | -include $(TOPDIR)/.depends.cfgs |
29 | 29 | ||
30 | all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(configs) | 30 | all menuconfig xconfig oldconfig config randconfig allyesconfig allnoconfig defconfig : $(configs) |
31 | 31 | ||
32 | $(TOPDIR)/.config: $(TOPDIR)/.depends.cfgs $(configs) | 32 | $(TOPDIR)/.config: $(TOPDIR)/.depends.cfgs $(configs) |
33 | $(call descend,scripts/kconfig,conf) | 33 | $(call descend,scripts/kconfig,conf) |
34 | @if [ ! -e $@ ]; then \ | 34 | @if [ ! -e $@ ]; then \ |
35 | cp $(TOPDIR)/def-configs/opie $@; \ | 35 | cp $(TOPDIR)/def-configs/opie $@; \ |
36 | fi; | 36 | fi; |
37 | @$(MAKE) -C scripts/kconfig conf; | 37 | @$(MAKE) -C scripts/kconfig conf; |
38 | ./scripts/kconfig/conf -s ./config.in | 38 | ./scripts/kconfig/conf -s ./config.in |
39 | 39 | ||
40 | # config rules must have the $(configs) var defined | 40 | # config rules must have the $(configs) var defined |
41 | # at the time that they run. we must ensure that .depends.cfgs | 41 | # at the time that they run. we must ensure that .depends.cfgs |
42 | # is built and included by the time we reach this point. | 42 | # is built and included by the time we reach this point. |
43 | 43 | ||
44 | xconfig : | 44 | xconfig : |
45 | $(call descend,scripts/kconfig,qconf) | 45 | $(call descend,scripts/kconfig,qconf) |
46 | LD_LIBRARY_PATH=$$LD_LIBRARY_PATH:$(TOPDIR)/scripts/kconfig \ | 46 | LD_LIBRARY_PATH=$$LD_LIBRARY_PATH:$(TOPDIR)/scripts/kconfig \ |
47 | ./scripts/kconfig/qconf ./config.in | 47 | ./scripts/kconfig/qconf ./config.in |
48 | 48 | ||
49 | menuconfig : scripts/lxdialog/lxdialog | 49 | menuconfig : scripts/lxdialog/lxdialog |
50 | $(call descend,scripts/kconfig,mconf) | 50 | $(call descend,scripts/kconfig,mconf) |
51 | ./scripts/kconfig/mconf ./config.in | 51 | ./scripts/kconfig/mconf ./config.in |
52 | 52 | ||
53 | config : | 53 | config : |
54 | $(call descend,scripts/kconfig,conf) | 54 | $(call descend,scripts/kconfig,conf) |
55 | ./scripts/kconfig/conf ./config.in | 55 | ./scripts/kconfig/conf ./config.in |
56 | 56 | ||
57 | oldconfig : | 57 | oldconfig : |
58 | $(call descend,scripts/kconfig,conf) | 58 | $(call descend,scripts/kconfig,conf) |
59 | ./scripts/kconfig/conf -o ./config.in | 59 | ./scripts/kconfig/conf -o ./config.in |
@@ -62,33 +62,29 @@ randconfig : | |||
62 | $(call descend,scripts/kconfig,conf) | 62 | $(call descend,scripts/kconfig,conf) |
63 | ./scripts/kconfig/conf -r ./config.in | 63 | ./scripts/kconfig/conf -r ./config.in |
64 | 64 | ||
65 | allyesconfig : | 65 | allyesconfig : |
66 | $(call descend,scripts/kconfig,conf) | 66 | $(call descend,scripts/kconfig,conf) |
67 | ./scripts/kconfig/conf -y ./config.in | 67 | ./scripts/kconfig/conf -y ./config.in |
68 | 68 | ||
69 | allnoconfig : | 69 | allnoconfig : |
70 | $(call descend,scripts/kconfig,conf) | 70 | $(call descend,scripts/kconfig,conf) |
71 | ./scripts/kconfig/conf -n ./config.in | 71 | ./scripts/kconfig/conf -n ./config.in |
72 | 72 | ||
73 | defconfig : | 73 | defconfig : |
74 | $(call descend,scripts/kconfig,conf) | 74 | $(call descend,scripts/kconfig,conf) |
75 | ./scripts/kconfig/conf -d ./config.in | 75 | ./scripts/kconfig/conf -d ./config.in |
76 | 76 | ||
77 | 77 | ||
78 | ifeq ($(if $(filter clean%,$(MAKECMDGOALS)),clean,notclean),notclean) | ||
79 | -include $(TOPDIR)/.config | 78 | -include $(TOPDIR)/.config |
80 | endif | ||
81 | ifeq ($(shell if [ -e $(TOPDIR)/..config.cmd ]; then echo exists; fi),exists) | ||
82 | -include $(TOPDIR)/..config.cmd | 79 | -include $(TOPDIR)/..config.cmd |
83 | endif | ||
84 | ifeq ($(if $(filter clean%,$(MAKECMDGOALS)),clean,notclean),notclean) | ||
85 | -include $(TOPDIR)/.depends | 80 | -include $(TOPDIR)/.depends |
86 | endif | ||
87 | 81 | ||
88 | export QMAKESPEC=$(QMAKESPECSDIR)/qws/$(patsubst "%",%,$(CONFIG_SPECFILE)) | 82 | export QMAKESPEC=$(QMAKESPECSDIR)/qws/$(patsubst "%",%,$(CONFIG_SPECFILE)) |
89 | 83 | ||
90 | all : $(subdir-y) | 84 | all clean: $(subdir-y) |
85 | |||
86 | $(subdir-y) : $(TOPDIR)/stamp-headers $(TOPDIR)/library/custom.h | ||
91 | 87 | ||
92 | $(subdir-y) : $(TOPDIR)/stamp-headers | 88 | clean : $(TOPDIR)/.config |
93 | 89 | ||
94 | include $(TOPDIR)/Rules.make | 90 | include $(TOPDIR)/Rules.make |
@@ -1,56 +1,61 @@ | |||
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 | grep -v '^#' | \ | 9 | cat $(TOPDIR)/packages | grep -v '^#' | \ |
10 | awk '{print \ | 10 | awk '{print \ |
11 | ".PHONY : " $$2 "\n" \ | 11 | ".PHONY : " $$2 "\n" \ |
12 | "subdir-$$(" $$1 ") += " $$2 "\n\n"; \ | 12 | "subdir-$$(" $$1 ") += " $$2 "\n\n"; \ |
13 | print $$2 " : " $$2 "/Makefile\n\t$$(call descend,$$@)\n"; }' > $(TOPDIR)/.depends | 13 | print $$2 " : " $$2 "/Makefile\n\t$$(call descend,$$@,$(filter-out $$@,$$(MAKECMDGOALS)))\n"; }' > $(TOPDIR)/.depends |
14 | cat $(TOPDIR)/packages | grep -v '^#' | \ | 14 | cat $(TOPDIR)/packages | grep -v '^#' | \ |
15 | perl -ne '($$cfg, $$dir, $$pro) = $$_ =~ /^(\S+)\s+(\S+)\s+(\S+)/; if ( -e "$$dir/$$pro" ) { print "$$dir/Makefile : $$dir/$$pro \$$(TOPDIR)/qmake/qmake\n\t\$$(call makefilegen,\$$@)\n\n"; }' \ | 15 | perl -ne '($$cfg, $$dir, $$pro) = $$_ =~ /^(\S+)\s+(\S+)\s+(\S+)/; if ( -e "$$dir/$$pro" ) { print "$$dir/Makefile : $$dir/$$pro \$$(TOPDIR)/qmake/qmake\n\t\$$(call makefilegen,\$$@)\n\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 | # config.in interdependencies | 22 | # config.in interdependencies |
23 | @echo $(configs) | sed -e 's,/config.in,,g' | ( for i in `cat`; do echo $$i; done ) > dirs | 23 | @echo $(configs) | sed -e 's,/config.in,,g' | ( for i in `cat`; do echo $$i; done ) > dirs |
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 ) >> $@ | 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 ) >> $@ |
25 | @-rm -f dirs | 25 | @-rm -f dirs |
26 | 26 | ||
27 | $(TOPDIR)/stamp-headers : | 27 | $(TOPDIR)/stamp-headers : |
28 | mkdir -p $(TOPDIR)/include/qpe $(TOPDIR)/include/qtopia \ | 28 | mkdir -p $(TOPDIR)/include/qpe $(TOPDIR)/include/qtopia \ |
29 | $(TOPDIR)/include/opie $(TOPDIR)/include/qtopia/private | 29 | $(TOPDIR)/include/opie $(TOPDIR)/include/qtopia/private |
30 | ( cd include/qpe && rm -f *.h; ln -sf ../../library/*.h .; ln -sf ../../library/backend/*.h .; rm -f *_p.h; ) | 30 | ( cd include/qpe && rm -f *.h; ln -sf ../../library/*.h .; ln -sf ../../library/backend/*.h .; rm -f *_p.h; ) |
31 | ( cd include/qtopia && rm -f *.h; ln -sf ../../library/*.h .; ) | 31 | ( cd include/qtopia && rm -f *.h; ln -sf ../../library/*.h .; ) |
32 | ( cd include/qtopia/private && rm -f *.h; ln -sf ../../../library/backend/*.h .; ) | 32 | ( cd include/qtopia/private && rm -f *.h; ln -sf ../../../library/backend/*.h .; ) |
33 | ( cd include/opie && rm -f *.h; ln -sf ../../libopie/*.h .; rm -f *_p.h; ) | 33 | ( cd include/opie && rm -f *.h; ln -sf ../../libopie/*.h .; rm -f *_p.h; ) |
34 | ( cd include/opie && ln -sf ../../libsql/*.h .; ) | 34 | ( cd include/opie && ln -sf ../../libsql/*.h .; ) |
35 | ( cd include/opie && ln -sf ../../libopie/pim/*.h .; ) | 35 | ( cd include/opie && ln -sf ../../libopie/pim/*.h .; ) |
36 | ( cd include/opie; for generatedHeader in `cd ../../libopie; ls *.ui | sed -e "s,\.ui,\.h,g"`; do \ | 36 | ( cd include/opie; for generatedHeader in `cd ../../libopie; ls *.ui | sed -e "s,\.ui,\.h,g"`; do \ |
37 | ln -sf ../../libopie/$$generatedHeader $$generatedHeader; done ) | 37 | ln -sf ../../libopie/$$generatedHeader $$generatedHeader; done ) |
38 | touch $@ | 38 | touch $@ |
39 | 39 | ||
40 | 40 | $(TOPDIR)/library/custom.h : $(TOPDIR)/.config | |
41 | @-rm -f $@ | ||
42 | $(if $(patsubst "%",%,$(CONFIG_CUSTOMFILE)),\ | ||
43 | ln -sf $(patsubst "%",%,$(CONFIG_CUSTOMFILE)) $@,\ | ||
44 | touch $@\ | ||
45 | ) | ||
41 | 46 | ||
42 | $(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 : | 47 | $(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 : |
43 | $(call descend,$(shell dirname $@),$(shell basename $@)) | 48 | $(call descend,$(shell dirname $@),$(shell basename $@)) |
44 | 49 | ||
45 | $(TOPDIR)/qmake/qmake : $(TOPDIR)/mkspecs/default | 50 | $(TOPDIR)/qmake/qmake : $(TOPDIR)/mkspecs/default |
46 | 51 | ||
47 | $(TOPDIR)/mkspecs/default : | 52 | $(TOPDIR)/mkspecs/default : |
48 | ln -sf linux-g++ $@ | 53 | ln -sf linux-g++ $@ |
49 | 54 | ||
50 | ## general rules ## | 55 | ## general rules ## |
51 | 56 | ||
52 | define descend | 57 | define descend |
53 | $(MAKE) -C $(1) $(2) | 58 | $(MAKE) -C $(1) $(2) |
54 | endef | 59 | endef |
55 | 60 | ||
56 | define makefilegen | 61 | define makefilegen |
diff --git a/config.in.in b/config.in.in index 2de0cbc..41998d4 100644 --- a/config.in.in +++ b/config.in.in | |||
@@ -28,27 +28,32 @@ choice | |||
28 | 28 | ||
29 | # config TARGET_OZ | 29 | # config TARGET_OZ |
30 | # boolean "Sharp Zaurus SL-5x00 - OpenZaurus" | 30 | # boolean "Sharp Zaurus SL-5x00 - OpenZaurus" |
31 | 31 | ||
32 | config TARGET_IPAQ | 32 | config TARGET_IPAQ |
33 | boolean "Ipaq" | 33 | boolean "Ipaq" |
34 | 34 | ||
35 | endchoice | 35 | endchoice |
36 | 36 | ||
37 | config SPECFILE | 37 | config SPECFILE |
38 | string | 38 | string |
39 | default "linux-generic-g++" if TARGET_X86 | 39 | default "linux-generic-g++" if TARGET_X86 |
40 | default "linux-sharp-g++" if TARGET_SHARP | 40 | default "linux-sharp-g++" if TARGET_SHARP |
41 | # default "linux-oz-g++" if TARGET_OZ | 41 | # default "linux-oz-g++" if TARGET_OZ |
42 | default "linux-ipaq-g++" if TARGET_IPAQ | 42 | default "linux-ipaq-g++" if TARGET_IPAQ |
43 | 43 | ||
44 | config CUSTOMFILE | ||
45 | string | ||
46 | default "custom-ipaq.h" if TARGET_IPAQ | ||
47 | default "custom-sharp.h" if TARGET_SHARP | ||
48 | |||
44 | #config CROSS | 49 | #config CROSS |
45 | # string "Crosscompilation prefix" | 50 | # string "Crosscompilation prefix" |
46 | # default "arm-linux-" | 51 | # default "arm-linux-" |
47 | # help | 52 | # help |
48 | # Crosscompilation prefix is the prefix which will be prepended | 53 | # Crosscompilation prefix is the prefix which will be prepended |
49 | # to all compilation commands. For example, a crosscompilation prefix | 54 | # to all compilation commands. For example, a crosscompilation prefix |
50 | # of arm-linux-, results in the build calling arm-linux-gcc as its CC. | 55 | # of arm-linux-, results in the build calling arm-linux-gcc as its CC. |
51 | 56 | ||
52 | endmenu | 57 | endmenu |
53 | 58 | ||
54 | @sources@ | 59 | @sources@ |