X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=blobdiff_plain;f=include%2Fprereq-build.mk;h=0b396c83dd6278529d2469faa299d2d7029c82a9;hp=7355b9e31c1e3c8cad24fd54897159717c3d8555;hb=964ef07aa7c8ec4220ba33eadf21141e5cb5f257;hpb=95b5853f7c748bc36840eff9f8f2a881a69ba69e diff --git a/include/prereq-build.mk b/include/prereq-build.mk index 7355b9e31c..0b396c83dd 100644 --- a/include/prereq-build.mk +++ b/include/prereq-build.mk @@ -20,11 +20,7 @@ $(eval $(call Require,non-root, \ # Required for the toolchain define Require/working-make - echo 'all: test' > $(TMP_DIR)/check.mk - echo 'e0 = $$$$(foreach s,foobar,$$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk - echo 'e1 = $$$$(foreach s,foobar, $$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk - echo 'test: $$$$(strip $$$$(e0)) $$$$(strip $$$$(e1))' >> $(TMP_DIR)/check.mk - $(NO_TRACE_MAKE) -f $(TMP_DIR)/check.mk + $(MAKE) -v | awk '($$$$1 == "GNU") && ($$$$2 = "Make") && ($$$$3 >= "3.81") { print "ok" }' | grep ok > /dev/null endef $(eval $(call Require,working-make, \ @@ -41,6 +37,20 @@ $(eval $(call Require,case-sensitive-fs, \ OpenWrt can only be built on a case-sensitive filesystem \ )) +define Require/getopt + getopt --help 2>&1 | grep long >/dev/null +endef +$(eval $(call Require,getopt, \ + Please install GNU getopt \ +)) + +define Require/fileutils + gcp --help || cp --help +endef +$(eval $(call Require,fileutils, \ + Please install GNU fileutils \ +)) + define Require/working-gcc echo 'int main(int argc, char **argv) { return 0; }' | \ gcc -x c -o $(TMP_DIR)/a.out - @@ -52,7 +62,8 @@ $(eval $(call Require,working-gcc, \ define Require/working-g++ echo 'int main(int argc, char **argv) { return 0; }' | \ - g++ -x c++ -o $(TMP_DIR)/a.out -lstdc++ - + g++ -x c++ -o $(TMP_DIR)/a.out -lstdc++ - && \ + $(TMP_DIR)/a.out endef $(eval $(call Require,working-g++, \ @@ -82,10 +93,6 @@ $(eval $(call RequireCommand,gawk, \ Please install GNU awk. \ )) -$(eval $(call RequireCommand,bison, \ - Please install GNU bison. \ -)) - $(eval $(call RequireCommand,flex, \ Please install flex. \ )) @@ -106,6 +113,10 @@ $(eval $(call RequireCommand,perl, \ Please install perl. \ )) +$(eval $(call RequireCommand,python, \ + Please install python. \ +)) + $(eval $(call RequireCommand,wget, \ Please install wget. \ )) @@ -118,14 +129,22 @@ $(eval $(call Require,gnutar, \ Please install GNU tar. \ )) -$(eval $(call RequireCommand,autoconf, \ - Please install GNU autoconf. \ +$(eval $(call RequireCommand,svn, \ + Please install the subversion client. \ +)) + +define Require/gnu-find + $(FIND) $(TMP_DIR) -lname foo +endef + +$(eval $(call Require,gnu-find, \ + Please install GNU find \ )) -define Require/find - find . -maxdepth 1 -exec ls {} + > /dev/null 2>&1 +define Require/getopt-extended + getopt --long - - >/dev/null endef -$(eval $(call Require,find, \ - Please install GNU find 4.2.12 or better. \ +$(eval $(call Require,getopt-extended, \ + Please install an extended getopt version that supports --long \ ))