X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/ff603530b7a12875b609bcbb25b547a102f167ad..9b29bbab657731f7f37fab4a6761505dabdaab8d:/include/prereq-build.mk diff --git a/include/prereq-build.mk b/include/prereq-build.mk index 11403c2fd..b0114f0b9 100644 --- a/include/prereq-build.mk +++ b/include/prereq-build.mk @@ -7,6 +7,9 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/prereq.mk +include $(INCLUDE_DIR)/host.mk + +PKG_NAME:=Build dependency define Require/non-root [ "$$(shell whoami)" != "root" ] @@ -17,17 +20,23 @@ $(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, \ Please install GNU make v3.81 or later. (This version has bugs) \ )) +define Require/case-sensitive-fs + rm -f $(TMP_DIR)/test.* + touch $(TMP_DIR)/test.fs + [ \! -f $(TMP_DIR)/test.FS ] +endef + +$(eval $(call Require,case-sensitive-fs, \ + OpenWrt can only be built on a case-sensitive filesystem \ +)) + define Require/working-gcc echo 'int main(int argc, char **argv) { return 0; }' | \ gcc -x c -o $(TMP_DIR)/a.out - @@ -39,7 +48,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++, \ @@ -65,6 +75,9 @@ $(eval $(call Require,zlib, \ Please install zlib. (Missing libz.so or zlib.h) \ )) +$(eval $(call RequireCommand,gawk, \ + Please install GNU awk. \ +)) $(eval $(call RequireCommand,bison, \ Please install GNU bison. \ @@ -74,10 +87,6 @@ $(eval $(call RequireCommand,flex, \ Please install flex. \ )) -$(eval $(call RequireCommand,python, \ - Please install python. \ -)) - $(eval $(call RequireCommand,unzip, \ Please install unzip. \ )) @@ -93,3 +102,31 @@ $(eval $(call RequireCommand,patch, \ $(eval $(call RequireCommand,perl, \ Please install perl. \ )) + +$(eval $(call RequireCommand,wget, \ + Please install wget. \ +)) + +define Require/gnutar + $(TAR) --version 2>&1 | grep GNU > /dev/null +endef + +$(eval $(call Require,gnutar, \ + Please install GNU tar. \ +)) + +$(eval $(call RequireCommand,svn, \ + Please install the subversion client. \ +)) + +$(eval $(call RequireCommand,autoconf, \ + Please install GNU autoconf. \ +)) + +define Require/gnu-find + $(FIND) $(TMP_DIR) -lname foo +endef + +$(eval $(call Require,gnu-find, \ + Please install GNU find \ +))