X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/900c05f6e102b84281efcd2fc5297b72d9253ba7..b49b13bfa0437a99f2f7419c5d25d265a0c7b77c:/include/download.mk diff --git a/include/download.mk b/include/download.mk index 1f227e221..0558d4979 100644 --- a/include/download.mk +++ b/include/download.mk @@ -14,7 +14,9 @@ $(strip \ $(if $(filter @GNU/% @KERNEL/% @SF/% ftp://% http://%,$(1)),default, \ $(if $(filter git://%,$(1)),git, \ $(if $(filter svn://%,$(1)),svn, \ - unknown \ + $(if $(filter cvs://%,$(1)),cvs, \ + unknown \ + ) \ ) \ ) \ ) \ @@ -22,9 +24,9 @@ $(strip \ ) endef -# code for creating tarballs from svn/git checkouts - useful for mirror support -dl_pack/bz2=tar cfj $(1) $(2) -dl_pack/gz=tar cfz $(1) $(2) +# code for creating tarballs from cvs/svn/git checkouts - useful for mirror support +dl_pack/bz2=$(TAR) cfj $(1) $(2) +dl_pack/gz=$(TAR) cfz $(1) $(2) dl_pack/unknown=echo "ERROR: Unknown pack format for file $(1)"; false define dl_pack $(if $(dl_pack/$(call ext,$(1))),$(dl_pack/$(call ext,$(1))),$(dl_pack/unknown)) @@ -39,14 +41,28 @@ define DownloadMethod/default endef define wrap_mirror - @$(if $(CONFIG_LOCALMIRROR),$(SCRIPT_DIR)/download.pl "$(DL_DIR)" "$(FILE)" "x" || ) \ - ( $(1) ) \ - $(if $(CONFIG_LOCALMIRROR),, || $(SCRIPT_DIR)/download.pl "$(DL_DIR)" "$(FILE)" "x") + @$(SCRIPT_DIR)/download.pl "$(DL_DIR)" "$(FILE)" "x" || ( $(1) ) endef +define DownloadMethod/cvs + $(call wrap_mirror, \ + echo "Checking out files from the cvs repository..."; \ + mkdir -p $(TMP_DIR)/dl && \ + cd $(TMP_DIR)/dl && \ + rm -rf $(SUBDIR) && \ + [ \! -d $(SUBDIR) ] && \ + cvs co -r$(VERSION) $(URL) $(SUBDIR) && \ + find $(SUBDIR) -name CVS | xargs rm -rf && \ + echo "Packing checkout..." && \ + $(call dl_pack,$(TMP_DIR)/dl/$(FILE),$(SUBDIR)) && \ + mv $(TMP_DIR)/dl/$(FILE) $(DL_DIR)/; \ + ) +endef + + define DownloadMethod/svn $(call wrap_mirror, \ - echo "Checking out files from svn repository..."; \ + echo "Checking out files from the svn repository..."; \ mkdir -p $(TMP_DIR)/dl && \ cd $(TMP_DIR)/dl && \ rm -rf $(SUBDIR) && \ @@ -59,8 +75,25 @@ define DownloadMethod/svn ) endef +define DownloadMethod/git + $(call wrap_mirror, \ + echo "Checking out files from the git repository..."; \ + mkdir -p $(TMP_DIR)/dl && \ + cd $(TMP_DIR)/dl && \ + rm -rf $(SUBDIR) && \ + [ \! -d $(SUBDIR) ] && \ + git-clone $(URL) $(SUBDIR) && \ + (cd $(SUBDIR) && git-checkout $(VERSION)) && \ + echo "Packing checkout..." && \ + rm -rf $(SUBDIR)/.git && \ + $(call dl_pack,$(TMP_DIR)/dl/$(FILE),$(SUBDIR)) && \ + mv $(TMP_DIR)/dl/$(FILE) $(DL_DIR)/; \ + ) +endef + +Validate/cvs=VERSION SUBDIR Validate/svn=VERSION SUBDIR -#Validate/git=VERSION SUBDIR +Validate/git=VERSION SUBDIR define Download/Defaults URL:=