mirror of
https://github.com/motioneye-project/motioneyeos.git
synced 2025-07-28 21:56:31 +00:00
GENTARGETS: add support for scp://
This patch adds support for scp:// both for use in the package Makefiles, as for the BR2_PRIMARY_SITE variable. This patch was based on the work of Richard Guy Briggs (see https://bugs.busybox.net/show_bug.cgi?id=3343). [Peter: small whitespace fixes] Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
This commit is contained in:
parent
1d7299194c
commit
c61788f097
13
Config.in
13
Config.in
@ -36,6 +36,14 @@ config BR2_LOCALFILES
|
|||||||
string "Local files retrieval command"
|
string "Local files retrieval command"
|
||||||
default "cp"
|
default "cp"
|
||||||
|
|
||||||
|
config BR2_SCP
|
||||||
|
string "Secure copy (scp) command"
|
||||||
|
default "scp"
|
||||||
|
|
||||||
|
config BR2_SSH
|
||||||
|
string "Secure shell (ssh) command"
|
||||||
|
default "ssh"
|
||||||
|
|
||||||
config BR2_ZCAT
|
config BR2_ZCAT
|
||||||
string "zcat command"
|
string "zcat command"
|
||||||
default "gzip -d -c"
|
default "gzip -d -c"
|
||||||
@ -102,7 +110,10 @@ config BR2_PRIMARY_SITE
|
|||||||
Primary site to download from. If this option is set then buildroot
|
Primary site to download from. If this option is set then buildroot
|
||||||
will try to download package source first from this site and try the
|
will try to download package source first from this site and try the
|
||||||
default if the file is not found.
|
default if the file is not found.
|
||||||
NOTE: This only works for packages using the Makefile.autotools.in
|
Valid URIs are URIs recognized by $(WGET) and scp URIs of the form
|
||||||
|
scp://[user@]host:path.
|
||||||
|
NOTE: This works for all packages using the central package
|
||||||
|
infrastructure (generic, autotools, cmake, ...)
|
||||||
|
|
||||||
config BR2_BACKUP_SITE
|
config BR2_BACKUP_SITE
|
||||||
string "Backup download site"
|
string "Backup download site"
|
||||||
|
@ -92,6 +92,8 @@ WGET:=$(call qstrip,$(BR2_WGET)) $(QUIET)
|
|||||||
SVN:=$(call qstrip,$(BR2_SVN))
|
SVN:=$(call qstrip,$(BR2_SVN))
|
||||||
BZR:=$(call qstrip,$(BR2_BZR))
|
BZR:=$(call qstrip,$(BR2_BZR))
|
||||||
GIT:=$(call qstrip,$(BR2_GIT))
|
GIT:=$(call qstrip,$(BR2_GIT))
|
||||||
|
SCP:=$(call qstrip,$(BR2_SCP)) $(QUIET)
|
||||||
|
SSH:=$(call qstrip,$(BR2_SSH)) $(QUIET)
|
||||||
LOCALFILES:=$(call qstrip,$(BR2_LOCALFILES))
|
LOCALFILES:=$(call qstrip,$(BR2_LOCALFILES))
|
||||||
|
|
||||||
# Default spider mode is 'DOWNLOAD'. Other possible values are 'SOURCE_CHECK'
|
# Default spider mode is 'DOWNLOAD'. Other possible values are 'SOURCE_CHECK'
|
||||||
@ -104,20 +106,39 @@ ifeq ($(DL_DIR),)
|
|||||||
DL_DIR:=$(TOPDIR)/dl
|
DL_DIR:=$(TOPDIR)/dl
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
#
|
||||||
|
# URI scheme helper functions
|
||||||
|
# Example URIs:
|
||||||
|
# * http://www.example.com/dir/file
|
||||||
|
# * scp://www.example.com:dir/file (with domainseparator :)
|
||||||
|
#
|
||||||
|
# geturischeme: http
|
||||||
|
geturischeme=$(firstword $(subst ://, ,$(call qstrip,$(1))))
|
||||||
|
# stripurischeme: www.example.com/dir/file
|
||||||
|
stripurischeme=$(lastword $(subst ://, ,$(call qstrip,$(1))))
|
||||||
|
# domain: www.example.com
|
||||||
|
domain=$(firstword $(subst $(call domainseparator,$(2)), ,$(call stripurischeme,$(1))))
|
||||||
|
# notdomain: dir/file
|
||||||
|
notdomain=$(patsubst $(call domain,$(1),$(2))$(call domainseparator,$(2))%,%,$(call stripurischeme,$(1)))
|
||||||
|
#
|
||||||
|
# default domainseparator is /, specify alternative value as first argument
|
||||||
|
domainseparator=$(if $(1),$(1),/)
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
# The DOWNLOAD_{GIT,SVN,BZR,LOCALFILES} helpers are in charge of getting a
|
# The DOWNLOAD_{GIT,SVN,BZR,LOCALFILES} helpers are in charge of getting a
|
||||||
# working copy of the source repository for their corresponding SCM,
|
# working copy of the source repository for their corresponding SCM,
|
||||||
# checking out the requested version / commit / tag, and create an
|
# checking out the requested version / commit / tag, and create an
|
||||||
# archive out of it. DOWNLOAD_WGET is the normal wget-based download
|
# archive out of it. DOWNLOAD_SCP uses scp to obtain a remote file with
|
||||||
|
# ssh authentication. DOWNLOAD_WGET is the normal wget-based download
|
||||||
# mechanism.
|
# mechanism.
|
||||||
#
|
#
|
||||||
# The SOURCE_CHECK_{GIT,SVN,BZR,WGET,LOCALFILES} helpers are in charge of simply
|
# The SOURCE_CHECK_{GIT,SVN,BZR,WGET,LOCALFILES,SCP} helpers are in charge of
|
||||||
# checking that the source is available for download. This can be used
|
# simply checking that the source is available for download. This can be used
|
||||||
# to make sure one will be able to get all the sources needed for
|
# to make sure one will be able to get all the sources needed for
|
||||||
# one's build configuration.
|
# one's build configuration.
|
||||||
#
|
#
|
||||||
# The SHOW_EXTERNAL_DEPS_{GIT,SVN,BZR,WGET,LOCALFILES} helpers simply output to
|
# The SHOW_EXTERNAL_DEPS_{GIT,SVN,BZR,WGET,LOCALFILES,SCP} helpers simply output
|
||||||
# the console the names of the files that will be downloaded, or path
|
# to the console the names of the files that will be downloaded, or path
|
||||||
# and revision of the source repositories, producing a list of all the
|
# and revision of the source repositories, producing a list of all the
|
||||||
# "external dependencies" of a given build configuration.
|
# "external dependencies" of a given build configuration.
|
||||||
################################################################################
|
################################################################################
|
||||||
@ -176,6 +197,22 @@ define SHOW_EXTERNAL_DEPS_SVN
|
|||||||
echo $($(PKG)_SOURCE)
|
echo $($(PKG)_SOURCE)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
# SCP URIs should be of the form scp://[user@]host:filepath
|
||||||
|
# Note that filepath is relative to the user's home directory, so you may want
|
||||||
|
# to prepend the path with a slash: scp://[user@]host:/absolutepath
|
||||||
|
define DOWNLOAD_SCP
|
||||||
|
test -e $(DL_DIR)/$(2) || \
|
||||||
|
$(SCP) $(call stripurischeme,$(call qstrip,$(1)))/$(2) $(DL_DIR)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define SOURCE_CHECK_SCP
|
||||||
|
$(SSH) $(call domain,$(1),:) ls $(call notdomain,$(1)/$(2),:) > /dev/null
|
||||||
|
endef
|
||||||
|
|
||||||
|
define SHOW_EXTERNAL_DEPS_SCP
|
||||||
|
echo $(2)
|
||||||
|
endef
|
||||||
|
|
||||||
|
|
||||||
define DOWNLOAD_WGET
|
define DOWNLOAD_WGET
|
||||||
test -e $(DL_DIR)/$(2) || \
|
test -e $(DL_DIR)/$(2) || \
|
||||||
@ -218,7 +255,10 @@ endef
|
|||||||
|
|
||||||
define DOWNLOAD
|
define DOWNLOAD
|
||||||
$(Q)if test -n "$(call qstrip,$(BR2_PRIMARY_SITE))" ; then \
|
$(Q)if test -n "$(call qstrip,$(BR2_PRIMARY_SITE))" ; then \
|
||||||
$(call $(DL_MODE)_WGET,$(BR2_PRIMARY_SITE),$(2)) && exit ; \
|
case "$(call geturischeme,$(BR2_PRIMARY_SITE))" in \
|
||||||
|
scp) $(call $(DL_MODE)_SCP,$(BR2_PRIMARY_SITE),$(2)) && exit ;; \
|
||||||
|
*) $(call $(DL_MODE)_WGET,$(BR2_PRIMARY_SITE),$(2)) && exit ;; \
|
||||||
|
esac ; \
|
||||||
fi ; \
|
fi ; \
|
||||||
if test -n "$(1)" ; then \
|
if test -n "$(1)" ; then \
|
||||||
case "$($(PKG)_SITE_METHOD)" in \
|
case "$($(PKG)_SITE_METHOD)" in \
|
||||||
@ -226,6 +266,7 @@ define DOWNLOAD
|
|||||||
svn) $($(DL_MODE)_SVN) && exit ;; \
|
svn) $($(DL_MODE)_SVN) && exit ;; \
|
||||||
bzr) $($(DL_MODE)_BZR) && exit ;; \
|
bzr) $($(DL_MODE)_BZR) && exit ;; \
|
||||||
file) $($(DL_MODE)_LOCALFILES) && exit ;; \
|
file) $($(DL_MODE)_LOCALFILES) && exit ;; \
|
||||||
|
scp) $($(DL_MODE)_SCP) && exit ;; \
|
||||||
*) $(call $(DL_MODE)_WGET,$(1),$(2)) && exit ;; \
|
*) $(call $(DL_MODE)_WGET,$(1),$(2)) && exit ;; \
|
||||||
esac ; \
|
esac ; \
|
||||||
fi ; \
|
fi ; \
|
||||||
@ -655,6 +696,8 @@ else ifeq ($$($(2)_SITE_METHOD),git)
|
|||||||
DL_TOOLS_DEPENDENCIES += git
|
DL_TOOLS_DEPENDENCIES += git
|
||||||
else ifeq ($$($(2)_SITE_METHOD),bzr)
|
else ifeq ($$($(2)_SITE_METHOD),bzr)
|
||||||
DL_TOOLS_DEPENDENCIES += bzr
|
DL_TOOLS_DEPENDENCIES += bzr
|
||||||
|
else ifeq ($$($(2)_SITE_METHOD),scp)
|
||||||
|
DL_TOOLS_DEPENDENCIES += scp ssh
|
||||||
endif # SITE_METHOD
|
endif # SITE_METHOD
|
||||||
|
|
||||||
endif # $(2)_KCONFIG_VAR
|
endif # $(2)_KCONFIG_VAR
|
||||||
|
Loading…
x
Reference in New Issue
Block a user