Merge changes from topic "tproto" am: cd128891ed
am: 0f0e4d23e5
am: 40bd79e8b7
am: aa3348dd1b
Original change: https://android-review.googlesource.com/c/platform/build/+/1865920 Change-Id: Ia163cbaab749ed1a051ab28701e1c33656b67e48
This commit is contained in:
@@ -608,10 +608,25 @@ $(_dir)/$(1).meta_lic: PRIVATE_INSTALL_MAP := $(_map)
|
||||
$(_dir)/$(1).meta_lic: PRIVATE_MODULE_TYPE := $(ALL_MODULES.$(1).MODULE_TYPE)
|
||||
$(_dir)/$(1).meta_lic: PRIVATE_MODULE_CLASS := $(ALL_MODULES.$(1).MODULE_CLASS)
|
||||
$(_dir)/$(1).meta_lic: PRIVATE_INSTALL_MAP := $(_map)
|
||||
$(_dir)/$(1).meta_lic : $(foreach d,$(_deps),$(call word-colon,1,$(d))) $(foreach n,$(_notices),$(call word-colon,1,$(n)) )build/make/tools/build-license-metadata.sh
|
||||
$(_dir)/$(1).meta_lic: $(BUILD_LICENSE_METADATA)
|
||||
$(_dir)/$(1).meta_lic : $(foreach d,$(_deps),$(call word-colon,1,$(d))) $(foreach n,$(_notices),$(call word-colon,1,$(n)) )
|
||||
rm -f $$@
|
||||
mkdir -p $$(dir $$@)
|
||||
build/make/tools/build-license-metadata.sh -k $$(PRIVATE_KINDS) -c $$(PRIVATE_CONDITIONS) -n $$(PRIVATE_NOTICES) -d $$(PRIVATE_NOTICE_DEPS) -s $$(PRIVATE_SOURCES) -m $$(PRIVATE_INSTALL_MAP) -t $$(PRIVATE_TARGETS) -i $$(PRIVATE_INSTALLED) $$(if $$(PRIVATE_IS_CONTAINER),-is_container) -p '$$(PRIVATE_PACKAGE_NAME)' -mt $$(PRIVATE_MODULE_TYPE) -mc $$(PRIVATE_MODULE_CLASS) -r $$(PRIVATE_PATH) -o $$@
|
||||
$(BUILD_LICENSE_METADATA) \
|
||||
$$(addprefix -mt ,$$(PRIVATE_MODULE_TYPE)) \
|
||||
$$(addprefix -mc ,$$(PRIVATE_MODULE_CLASS)) \
|
||||
$$(addprefix -k ,$$(PRIVATE_KINDS)) \
|
||||
$$(addprefix -c ,$$(PRIVATE_CONDITIONS)) \
|
||||
$$(addprefix -n ,$$(PRIVATE_NOTICES)) \
|
||||
$$(addprefix -d ,$$(PRIVATE_NOTICE_DEPS)) \
|
||||
$$(addprefix -s ,$$(PRIVATE_SOURCES)) \
|
||||
$$(addprefix -m ,$$(PRIVATE_INSTALL_MAP)) \
|
||||
$$(addprefix -t ,$$(PRIVATE_TARGETS)) \
|
||||
$$(addprefix -i ,$$(PRIVATE_INSTALLED)) \
|
||||
$$(if $$(PRIVATE_IS_CONTAINER),-is_container) \
|
||||
-p '$$(PRIVATE_PACKAGE_NAME)' \
|
||||
$$(addprefix -r ,$$(PRIVATE_PATH)) \
|
||||
-o $$@
|
||||
|
||||
$(strip $(eval _mifs := $(sort $(ALL_MODULES.$(1).MODULE_INSTALLED_FILENAMES))))
|
||||
$(strip $(eval _infs := $(sort $(ALL_MODULES.$(1).INSTALLED_NOTICE_FILE))))
|
||||
@@ -662,10 +677,23 @@ $(_dir)/$(_tgt).meta_lic: PRIVATE_PATH := $(_path)
|
||||
$(_dir)/$(_tgt).meta_lic: PRIVATE_IS_CONTAINER := $(ALL_NON_MODULES.$(_tgt).IS_CONTAINER)
|
||||
$(_dir)/$(_tgt).meta_lic: PRIVATE_PACKAGE_NAME := $(strip $(ALL_NON_MODULES.$(_tgt).LICENSE_PACKAGE_NAME))
|
||||
$(_dir)/$(_tgt).meta_lic: PRIVATE_INSTALL_MAP := $(strip $(_install_map))
|
||||
$(_dir)/$(_tgt).meta_lic : $(foreach d,$(_deps),$(call word-colon,1,$(d))) $(foreach n,$(_notices),$(call word-colon,1,$(n)) )build/make/tools/build-license-metadata.sh
|
||||
$(_dir)/$(_tgt).meta_lic: $(BUILD_LICENSE_METADATA)
|
||||
$(_dir)/$(_tgt).meta_lic : $(foreach d,$(_deps),$(call word-colon,1,$(d))) $(foreach n,$(_notices),$(call word-colon,1,$(n)) )
|
||||
rm -f $$@
|
||||
mkdir -p $$(dir $$@)
|
||||
build/make/tools/build-license-metadata.sh -k $$(PRIVATE_KINDS) -c $$(PRIVATE_CONDITIONS) -n $$(PRIVATE_NOTICES) -d $$(PRIVATE_NOTICE_DEPS) -s $$(PRIVATE_SOURCES) -m $$(PRIVATE_INSTALL_MAP) -t $$(PRIVATE_TARGETS) $$(if $$(PRIVATE_IS_CONTAINER),-is_container) -p '$$(PRIVATE_PACKAGE_NAME)' -mt raw -mc unknown -r $$(PRIVATE_PATH) -o $$@
|
||||
$(BUILD_LICENSE_METADATA) \
|
||||
-mt raw -mc unknown \
|
||||
$$(addprefix -k ,$$(PRIVATE_KINDS)) \
|
||||
$$(addprefix -c ,$$(PRIVATE_CONDITIONS)) \
|
||||
$$(addprefix -n ,$$(PRIVATE_NOTICES)) \
|
||||
$$(addprefix -d ,$$(PRIVATE_NOTICE_DEPS)) \
|
||||
$$(addprefix -s ,$$(PRIVATE_SOURCES)) \
|
||||
$$(addprefix -m ,$$(PRIVATE_INSTALL_MAP)) \
|
||||
$$(addprefix -t ,$$(PRIVATE_TARGETS)) \
|
||||
$$(if $$(PRIVATE_IS_CONTAINER),-is_container) \
|
||||
-p '$$(PRIVATE_PACKAGE_NAME)' \
|
||||
$$(addprefix -r ,$$(PRIVATE_PATH)) \
|
||||
-o $$@
|
||||
|
||||
endef
|
||||
|
||||
|
@@ -1,236 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -u
|
||||
|
||||
ME=$(basename $0)
|
||||
|
||||
USAGE="Usage: ${ME} {options}
|
||||
|
||||
Builds a license metadata specification and outputs it to stdout or {outfile}.
|
||||
|
||||
The available options are:
|
||||
|
||||
-k kind... license kinds
|
||||
-c condition... license conditions
|
||||
-p package... license package name
|
||||
-n notice... license notice file
|
||||
-d dependency... license metadata file dependency
|
||||
-s dependency... source (input) dependency
|
||||
-t target... built targets
|
||||
-i target... installed targets
|
||||
-r root... root directory of project
|
||||
-m target:installed... map dependent targets to their installed names
|
||||
-mc module_class... module class
|
||||
-mt module_type... module type
|
||||
-is_container preserved dependent target name when given
|
||||
-o outfile output file
|
||||
"
|
||||
|
||||
# Global flag variables
|
||||
license_kinds=
|
||||
license_conditions=
|
||||
license_package_name=
|
||||
license_notice=
|
||||
license_deps=
|
||||
module_class=
|
||||
module_type=
|
||||
source_deps=
|
||||
targets=
|
||||
installed=
|
||||
installmap=
|
||||
is_container=false
|
||||
ofile=
|
||||
roots=
|
||||
|
||||
# Global variables
|
||||
depfiles=" "
|
||||
|
||||
|
||||
# Exits with a message.
|
||||
#
|
||||
# When the exit status is 2, assumes a usage error and outputs the usage message
|
||||
# to stderr before outputting the specific error message to stderr.
|
||||
#
|
||||
# Parameters:
|
||||
# Optional numeric exit status (defaults to 2, i.e. a usage error.)
|
||||
# Remaining args treated as an error message sent to stderr.
|
||||
die() {
|
||||
lstatus=2
|
||||
case "${1:-}" in *[^0-9]*) ;; *) lstatus="$1"; shift ;; esac
|
||||
case "${lstatus}" in 2) echo "${USAGE}" >&2; echo >&2 ;; esac
|
||||
if [ -n "$*" ]; then
|
||||
echo -e "$*\n" >&2
|
||||
fi
|
||||
exit $lstatus
|
||||
}
|
||||
|
||||
|
||||
# Sets the flag variables based on the command-line.
|
||||
#
|
||||
# invoke with: process_args "$@"
|
||||
process_args() {
|
||||
lcurr_flag=
|
||||
while [ "$#" -gt '0' ]; do
|
||||
case "${1}" in
|
||||
-h)
|
||||
echo "${USAGE}"
|
||||
exit 0
|
||||
;;
|
||||
-k)
|
||||
lcurr_flag=kind
|
||||
;;
|
||||
-c)
|
||||
lcurr_flag=condition
|
||||
;;
|
||||
-p)
|
||||
lcurr_flag=package
|
||||
;;
|
||||
-n)
|
||||
lcurr_flag=notice
|
||||
;;
|
||||
-d)
|
||||
lcurr_flag=dependency
|
||||
;;
|
||||
-s)
|
||||
lcurr_flag=source
|
||||
;;
|
||||
-t)
|
||||
lcurr_flag=target
|
||||
;;
|
||||
-i)
|
||||
lcurr_flag=install
|
||||
;;
|
||||
-m)
|
||||
lcurr_flag=installmap
|
||||
;;
|
||||
-mc)
|
||||
lcurr_flag=class
|
||||
;;
|
||||
-mt)
|
||||
lcurr_flag=type
|
||||
;;
|
||||
-o)
|
||||
lcurr_flag=ofile
|
||||
;;
|
||||
-r)
|
||||
lcurr_flag=root
|
||||
;;
|
||||
-is_container)
|
||||
lcurr_flag=
|
||||
is_container=true
|
||||
;;
|
||||
-*)
|
||||
die "Unknown flag: \"${1}\""
|
||||
;;
|
||||
*)
|
||||
case "${lcurr_flag}" in
|
||||
kind)
|
||||
license_kinds="${license_kinds}${license_kinds:+ }${1}"
|
||||
;;
|
||||
condition)
|
||||
license_conditions="${license_conditions}${license_conditions:+ }${1}"
|
||||
;;
|
||||
package)
|
||||
license_package_name="${license_package_name}${license_package_name:+ }${1}"
|
||||
;;
|
||||
notice)
|
||||
license_notice="${license_notice}${license_notice:+ }${1}"
|
||||
;;
|
||||
dependency)
|
||||
license_deps="${license_deps}${license_deps:+ }${1}"
|
||||
;;
|
||||
source)
|
||||
source_deps="${source_deps}${source_deps:+ }${1}"
|
||||
;;
|
||||
target)
|
||||
targets="${targets}${targets:+ }${1}"
|
||||
;;
|
||||
install)
|
||||
installed="${installed}${installed:+ }${1}"
|
||||
;;
|
||||
installmap)
|
||||
installmap="${installmap}${installmap:+ }${1}"
|
||||
;;
|
||||
class)
|
||||
module_class="${module_class}${module_class:+ }${1}"
|
||||
;;
|
||||
type)
|
||||
module_type="${module_type}${module_type:+ }${1}"
|
||||
;;
|
||||
root)
|
||||
root="${1}"
|
||||
while [ -n "${root}" ] && ! [ "${root}" == '.' ] && \
|
||||
! [ "${root}" == '/' ]; \
|
||||
do
|
||||
if [ -d "${root}/.git" ]; then
|
||||
roots="${roots}${roots:+ }${root}"
|
||||
break
|
||||
fi
|
||||
root=$(dirname "${root}")
|
||||
done
|
||||
;;
|
||||
ofile)
|
||||
if [ -n "${ofile}" ]; then
|
||||
die "Output file -o appears twice as \"${ofile}\" and \"${1}\""
|
||||
fi
|
||||
ofile="${1}"
|
||||
;;
|
||||
*)
|
||||
die "Must precede argument \"${1}\" with type flag."
|
||||
;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
}
|
||||
|
||||
|
||||
process_args "$@"
|
||||
|
||||
if [ -n "${ofile}" ]; then
|
||||
# truncate the output file before appending results
|
||||
: >"${ofile}"
|
||||
else
|
||||
ofile=/dev/stdout
|
||||
fi
|
||||
|
||||
# spit out the license metadata file content
|
||||
(
|
||||
echo 'license_package_name: "'"${license_package_name}"'"'
|
||||
for t in ${module_type}; do
|
||||
echo 'module_type: "'"${t}"'"'
|
||||
done
|
||||
for c in ${module_class}; do
|
||||
echo 'module_class: "'"${c}"'"'
|
||||
done
|
||||
for r in ${roots}; do
|
||||
echo 'root: "'"${r}"'"'
|
||||
done
|
||||
for kind in ${license_kinds}; do
|
||||
echo 'license_kind: "'"${kind}"'"'
|
||||
done
|
||||
for condition in ${license_conditions}; do
|
||||
echo 'license_condition: "'"${condition}"'"'
|
||||
done
|
||||
for f in ${license_notice}; do
|
||||
echo 'license_text: "'"${f}"'"'
|
||||
done
|
||||
echo "is_container: ${is_container}"
|
||||
for t in ${targets}; do
|
||||
echo 'built: "'"${t}"'"'
|
||||
done
|
||||
for i in ${installed}; do
|
||||
echo 'installed: "'"${i}"'"'
|
||||
done
|
||||
for m in ${installmap}; do
|
||||
echo 'install_map: "'"${m}"'"'
|
||||
done
|
||||
for s in ${source_deps}; do
|
||||
echo 'source: "'"${s}"'"'
|
||||
done
|
||||
) >>"${ofile}"
|
||||
depfiles=" $(echo $(echo ${license_deps} | tr ' ' '\n' | sort -u)) "
|
||||
for dep in ${depfiles}; do
|
||||
echo 'dep: "'"${dep}"'"'
|
||||
done >>"${ofile}"
|
Reference in New Issue
Block a user