X-Git-Url: http://git.ozo.com/?a=blobdiff_plain;f=include%2Fquilt.mk;h=c310fd99acd2081a572dc96f1a4be1dd0feeb3e2;hb=baeea7e3b71e42698e9b27864c4b48b18aa7c8c1;hp=1b191ddcba962e3ae9f6d30ca0e63deca3e9a41b;hpb=559432f6fd39d56c43fd0eab4f56d287814a4405;p=openwrt-10.03%2F.git diff --git a/include/quilt.mk b/include/quilt.mk index 1b191ddcb..c310fd99a 100644 --- a/include/quilt.mk +++ b/include/quilt.mk @@ -12,6 +12,7 @@ ifeq ($(TARGET_BUILD),1) PKG_BUILD_DIR:=$(LINUX_DIR) endif PATCH_DIR?=./patches +FILES_DIR?=./files ifeq ($(MAKECMDGOALS),refresh) override QUILT=1 @@ -23,8 +24,8 @@ endef define PatchDir/Quilt @if [ -s $(1)/series ]; then \ - mkdir -p $(PKG_BUILD_DIR)/patches$(if $(2),/$(2)); \ - cp $(1)/series $(PKG_BUILD_DIR)/patches$(if $(2),/$(2))/; \ + mkdir -p $(PKG_BUILD_DIR)/patches/$(2); \ + cp $(1)/series $(PKG_BUILD_DIR)/patches/$(2); \ fi @for patch in $$$$( (cd $(1) && if [ -f series ]; then $(call filter_series,series); else ls; fi; ) 2>/dev/null ); do ( \ cp "$(1)/$$$$patch" $(PKG_BUILD_DIR); \ @@ -56,7 +57,6 @@ ifneq ($(QUILT),) STAMP_PATCHED:=$(PKG_BUILD_DIR)/.quilt_patched STAMP_CHECKED:=$(PKG_BUILD_DIR)/.quilt_checked override CONFIG_AUTOREBUILD= - $(STAMP_CONFIGURED): $(STAMP_CHECKED) FORCE prepare: $(STAMP_PATCHED) quilt-check: $(STAMP_CHECKED) endif @@ -68,8 +68,11 @@ endef define Kernel/Patch/Default $(if $(QUILT),rm -rf $(PKG_BUILD_DIR)/patches; mkdir -p $(PKG_BUILD_DIR)/patches) - if [ -d $(GENERIC_PLATFORM_DIR)/files ]; then $(CP) $(GENERIC_PLATFORM_DIR)/files/* $(LINUX_DIR)/; fi - if [ -d ./files ]; then $(CP) ./files/* $(LINUX_DIR)/; fi + if [ -d $(GENERIC_FILES_DIR) ]; then $(CP) $(GENERIC_FILES_DIR)/* $(LINUX_DIR)/; fi + if [ -d $(FILES_DIR) ]; then \ + $(CP) $(FILES_DIR)/* $(LINUX_DIR)/; \ + find $(LINUX_DIR)/ -name \*.rej | xargs rm -f; \ + fi $(call PatchDir,$(GENERIC_PATCH_DIR),generic/) $(call PatchDir,$(PATCH_DIR),platform/) endef @@ -101,32 +104,33 @@ define Quilt/Refresh $(if $(TARGET_BUILD),$(Quilt/Refresh/Kernel),$(Quilt/Refresh/Package)) endef -$(STAMP_PATCHED): $(STAMP_PREPARED) +define Build/Quilt + $(STAMP_PATCHED): $(STAMP_PREPARED) @( \ cd $(PKG_BUILD_DIR)/patches; \ quilt pop -a -f >/dev/null 2>/dev/null; \ if [ -s ".subdirs" ]; then \ rm -f series; \ - for file in $$(cat .subdirs); do \ - if [ -f $$file/series ]; then \ + for file in $$$$(cat .subdirs); do \ + if [ -f $$$$file/series ]; then \ echo "Converting $$file/series"; \ - $(call filter_series,$$file/series) | awk -v file="$$file/" '$$0 !~ /^#/ { print file $$0 }' >> series; \ + $$(call filter_series,$$$$file/series) | awk -v file="$$$$file/" '$$$$0 !~ /^#/ { print file $$$$0 }' | sed -e s,//,/,g >> series; \ else \ - echo "Sorting patches in $$file"; \ - find $$file/* -type f \! -name series | sort >> series; \ + echo "Sorting patches in $$$$file"; \ + find $$$$file/* -type f \! -name series | sed -e s,//,/,g | sort >> series; \ fi; \ done; \ else \ find * -type f \! -name series | sort > series; \ fi; \ ) - touch $@ + touch $$@ -$(STAMP_CHECKED): $(STAMP_PATCHED) + $(STAMP_CONFIGURED): $(STAMP_CHECKED) FORCE + $(STAMP_CHECKED): $(STAMP_PATCHED) if [ -s "$(PKG_BUILD_DIR)/patches/series" ]; then (cd $(PKG_BUILD_DIR); quilt next >/dev/null 2>&1 && quilt push -a || quilt top >/dev/null 2>&1); fi - touch $@ + touch $$@ -define Build/Quilt quilt-check: $(STAMP_PREPARED) FORCE @[ -f "$(PKG_BUILD_DIR)/.quilt_used" ] || { \ echo "The source directory was not unpacked using quilt. Please rebuild with QUILT=1"; \