Merge "Remove patch-iso-debian's xmllint pkg requirement"
This commit is contained in:
commit
1da9fa200f
@ -38,6 +38,18 @@ function usage() {
|
|||||||
echo ""
|
echo ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function extract_ostree_commit_from_metadata_xml() {
|
||||||
|
local XML_PATH=$1
|
||||||
|
local XPATH="//contents/ostree/commit1/commit"
|
||||||
|
|
||||||
|
# Check if xmllint is available. Otherwise, use python's xml standard lib
|
||||||
|
if (which xmllint &>/dev/null); then
|
||||||
|
xmllint --xpath "string(${XPATH})" ${XML_PATH}
|
||||||
|
else
|
||||||
|
python3 -c "import xml.etree.ElementTree as ET ; print(ET.parse('${XML_PATH}').find('.${XPATH}').text, end='')"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
function extract_metadata() {
|
function extract_metadata() {
|
||||||
local patchesdir=${BUILDDIR}/patches
|
local patchesdir=${BUILDDIR}/patches
|
||||||
local patchfile=$1
|
local patchfile=$1
|
||||||
@ -53,11 +65,11 @@ function extract_metadata() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Verify if top commit from metadata exist in ostree log
|
# Verify if top commit from metadata exist in ostree log
|
||||||
xml_base=$(xmllint --xpath "string(//contents/ostree/commit1/commit)" ${patchesdir}/${patchid}-metadata.xml)
|
ostree_commit=$(extract_ostree_commit_from_metadata_xml ${patchesdir}/${patchid}-metadata.xml)
|
||||||
if [[ "$ostree_log" != *"$xml_base"* ]]; then
|
if [[ "$ostree_log" != *"$ostree_commit"* ]]; then
|
||||||
echo "Error, xml base commit does not exist in ostree log."
|
echo "Error: Patch ${patchid} ostree commit does not exist in ISO ostree log."
|
||||||
echo "patch base: ${xml_base}"
|
echo "patch's ostree commit: ${ostree_commit}"
|
||||||
echo "ostree log:"
|
echo "ISO ostree log:"
|
||||||
ostree --repo=${BUILDDIR}/ostree_repo log starlingx
|
ostree --repo=${BUILDDIR}/ostree_repo log starlingx
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@ -120,13 +132,15 @@ declare MNTDIR=
|
|||||||
declare BUILDDIR=
|
declare BUILDDIR=
|
||||||
|
|
||||||
function check_requirements {
|
function check_requirements {
|
||||||
|
|
||||||
|
# Declare "require reqA or reqB" as "reqA__reqB"
|
||||||
local -a required_utils=(
|
local -a required_utils=(
|
||||||
rsync
|
rsync
|
||||||
mkisofs
|
mkisofs
|
||||||
isohybrid
|
isohybrid
|
||||||
implantisomd5
|
implantisomd5
|
||||||
ostree
|
ostree
|
||||||
xmllint
|
xmllint__python3
|
||||||
)
|
)
|
||||||
if [ $UID -ne 0 ]; then
|
if [ $UID -ne 0 ]; then
|
||||||
# If running as non-root user, additional utils are required
|
# If running as non-root user, additional utils are required
|
||||||
@ -137,13 +151,25 @@ function check_requirements {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
local -i missing=0
|
local -i missing=0
|
||||||
|
local reqA
|
||||||
|
local reqB
|
||||||
|
|
||||||
for req in ${required_utils[@]}; do
|
for req in ${required_utils[@]}; do
|
||||||
which ${req} >&/dev/null
|
if [[ "$req" = *"__"* ]]; then
|
||||||
if [ $? -ne 0 ]; then
|
reqA="${req%__*}" # select everything before "__"
|
||||||
|
reqB="${req#*__}" # select everything after "__"
|
||||||
|
|
||||||
|
if ! (which ${reqA} &>/dev/null) && ! (which ${reqB} &>/dev/null); then
|
||||||
|
echo "Unable to find required utility: either ${reqA} or ${reqB}" >&2
|
||||||
|
let missing++
|
||||||
|
fi
|
||||||
|
|
||||||
|
else
|
||||||
|
if ! (which ${req} &>/dev/null); then
|
||||||
echo "Unable to find required utility: ${req}" >&2
|
echo "Unable to find required utility: ${req}" >&2
|
||||||
let missing++
|
let missing++
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ ${missing} -gt 0 ]; then
|
if [ ${missing} -gt 0 ]; then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user