X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/0251db4d4bb07fa5400c8d73411269a04e31674d..389529fe3599b90544f09cdae2d6318eefbe2352:/Makefile?ds=sidebyside diff --git a/Makefile b/Makefile index 85091f618..92b84bb2a 100644 --- a/Makefile +++ b/Makefile @@ -7,110 +7,38 @@ # See /LICENSE for more information. # -RELEASE:=Kamikaze -#VERSION:=2.0 # uncomment for final release - -#-------------------------------------------------------------- -# Just run 'make menuconfig', configure stuff, then run 'make'. -# You shouldn't need to mess with anything beyond this point... -#-------------------------------------------------------------- -TOPDIR=${shell pwd} -export TOPDIR -include $(TOPDIR)/include/verbose.mk - -OPENWRTVERSION:=$(RELEASE) -ifneq ($(VERSION),) -OPENWRTVERSION:=$(VERSION) ($(OPENWRTVERSION)) -else -REV:=$(shell LANG=C svn info | awk '/^Revision:/ { print$$2 }' ) -ifneq ($(REV),) -OPENWRTVERSION:=$(OPENWRTVERSION)/r$(REV) -endif -endif -export OPENWRTVERSION - all: world -ifneq ($(shell ./scripts/timestamp.pl -p .pkginfo package Makefile),.pkginfo) -.pkginfo: FORCE -.config: FORCE -endif - -.pkginfo: - @echo Collecting package info... - @-for dir in package/*/; do \ - echo Source-Makefile: $${dir}Makefile; \ - $(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $$dir 2>&- || true; \ - done > $@ - -.config.in: .pkginfo - @./scripts/gen_menuconfig.pl < $< > $@ || rm -f $@ - -pkginfo-clean: FORCE - -rm -f .pkginfo .config.in - -./scripts/config/mconf: .config.in - @$(MAKE) -C scripts/config all - -./scripts/config/conf: .config.in - @$(MAKE) -C scripts/config conf - -config: ./scripts/config/conf FORCE - $< Config.in - -defconfig: ./scripts/config/conf FORCE - touch .config - $< -D .config Config.in - -oldconfig: ./scripts/config/conf FORCE - $< -o Config.in -menuconfig: ./scripts/config/mconf FORCE - $< Config.in +TOPDIR:=${CURDIR} +LC_ALL:=C +LANG:=C +IS_TTY:=${shell tty -s && echo 1 || echo 0} +export TOPDIR LC_ALL LANG IS_TTY -config-clean: FORCE - $(NO_TRACE_MAKE) -C scripts/config clean +include rules.mk -package/%: .pkginfo FORCE - $(MAKE) -C package $(patsubst package/%,%,$@) - -target/%: .pkginfo FORCE - $(MAKE) -C target $(patsubst target/%,%,$@) - -toolchain/%: FORCE - $(MAKE) -C toolchain $(patsubst toolchain/%,%,$@) - -.config: ./scripts/config/conf - @[ -f .config ] || $(NO_TRACE_MAKE) menuconfig - @$< -D .config Config.in &> /dev/null +ifneq ($(OPENWRT_BUILD),1) + export OPENWRT_BUILD:=1 + include $(INCLUDE_DIR)/toplevel.mk +else + include $(INCLUDE_DIR)/depends.mk + include $(INCLUDE_DIR)/subdir.mk + include tools/Makefile -.prereq-build: $(TOPDIR)/include/prereq-build.mk - @$(NO_TRACE_MAKE) -s -f $(TOPDIR)/include/prereq-build.mk prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ - false; \ - } - @touch $@ +clean: FORCE + rm -rf build_* bin tmp -.prereq-packages: $(TOPDIR)/include/prereq.mk .pkginfo .config - @$(NO_TRACE_MAKE) -s -C package prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ - false; \ - } - @touch $@ - -prereq: .prereq-build .prereq-packages FORCE +dirclean: clean + rm -rf staging_dir_* toolchain_build_* tool_build -download: .config FORCE - $(MAKE) toolchain/download - $(MAKE) package/download - $(MAKE) target/download +distclean: dirclean config-clean symlinkclean docs/clean + rm -rf dl -ifeq ($(FORCE),) -.config ./scripts/config/conf ./scripts/config/mconf: .prereq-build -world: .prereq-packages -endif +toolchain/% package/% target/%: FORCE + $(MAKE) -C $(patsubst %/$*,%,$@) $* -world: .config FORCE +world: .config $(tools/stamp) FORCE $(MAKE) toolchain/install $(MAKE) target/compile $(MAKE) package/compile @@ -118,16 +46,4 @@ world: .config FORCE $(MAKE) target/install $(MAKE) package/index -clean: FORCE - rm -rf build_* bin - -dirclean: clean - rm -rf staging_dir_* toolchain_build_* - -distclean: dirclean config-clean - rm -rf dl .*config* .pkg* .prereq - - -.SILENT: clean dirclean distclean config-clean download world -.PHONY: FORCE -FORCE: +endif