summaryrefslogtreecommitdiff
path: root/eclass
diff options
context:
space:
mode:
authorKrzysztof Pawlik <nelchael@gentoo.org>2006-07-28 08:17:29 +0000
committerKrzysztof Pawlik <nelchael@gentoo.org>2006-07-28 08:17:29 +0000
commita5b5a05d24cdccacc58c66fe5e4db932860a4f94 (patch)
tree125593c0f8c535f60c0d26f5c7c4e87da4daddb2 /eclass
parentversion bump suggested in bug #141688. added kernel incompatibility warnings (diff)
downloadgentoo-2-a5b5a05d24cdccacc58c66fe5e4db932860a4f94.tar.gz
gentoo-2-a5b5a05d24cdccacc58c66fe5e4db932860a4f94.tar.bz2
gentoo-2-a5b5a05d24cdccacc58c66fe5e4db932860a4f94.zip
Split fixing build files to separate function, which can be used by ebuilds. Allows to handle strange and obscure cases (and is more flexible).
Diffstat (limited to 'eclass')
-rw-r--r--eclass/java-ant-2.eclass54
1 files changed, 36 insertions, 18 deletions
diff --git a/eclass/java-ant-2.eclass b/eclass/java-ant-2.eclass
index 372583974072..6d6806471161 100644
--- a/eclass/java-ant-2.eclass
+++ b/eclass/java-ant-2.eclass
@@ -95,19 +95,17 @@ post_src_unpack() {
# JAVA_PKG_BSFIX
# JAVA_PKG_BSFIX_ALL
# JAVA_PKG_BSFIX_NAME,
-# JAVA_PKG_BSFIX_SOURCE_TAGS
-# JAVA_PKG_BSFIX_TARGET_TAGS)
# ------------------------------------------------------------------------------
java-ant_bsfix() {
debug-print-function ${FUNCNAME} $*
- [[ "${JAVA_PKG_BSFIX}" != "on" ]] && return
- if ! java-pkg_needs-vm; then
+ [[ "${JAVA_PKG_BSFIX}" != "on" ]] && return
+ if ! java-pkg_needs-vm; then
echo "QA Notice: Package is using java-ant, but doesn't depend on a Java VM"
fi
cd "${S}"
-
+
local find_args="-type f"
if [[ "${JAVA_PKG_BSFIX_ALL}" == "yes" ]]; then
find_args="${find_args} -name ${JAVA_PKG_BSFIX_NAME// / -o -name }"
@@ -125,31 +123,51 @@ java-ant_bsfix() {
$(find . ${find_args})
EOF
+ for (( i = 0 ; i < ${#bsfix_these[@]} ; i++ )); do
+ local file="${bsfix_these[${i}]}"
+ java-ant_bsfix_one "${file}"
+ done
+}
+
+# ------------------------------------------------------------------------------
+# @public java-ant_bsfix_one
+#
+# Attempts to fix named build file. The following variables will affect its behavior
+# as listed above:
+# JAVA_PKG_BSFIX_SOURCE_TAGS
+# JAVA_PKG_BSFIX_TARGET_TAGS
+# ------------------------------------------------------------------------------
+java-ant_bsfix_one() {
+ debug-print-function ${FUNCNAME} $*
+
+ if [ -z "${1}" ]; then
+ eerror "java-ant_bsfix_one needs one argument"
+ die "java-ant_bsfix_one needs one argument"
+ fi
+
local want_source="$(java-pkg_get-source)"
local want_target="$(java-pkg_get-target)"
- debug-print "bsfix: target: ${want_target} source: ${want_source}"
+ debug-print "bsfix_one: target: ${want_target} source: ${want_source}"
if [ -z "${want_source}" -o -z "${want_target}" ]; then
eerror "Could not find valid -source/-target values"
eerror "Please file a bug about this on bugs.gentoo.org"
die "Could not find valid -source/-target values"
else
- for (( i = 0 ; i < ${#bsfix_these[@]} ; i++ )); do
- local file="${bsfix_these[${i}]}"
- echo "Rewriting ${file}"
- debug-print "bsfix: ${file}"
+ local file="${1}"
+ echo "Rewriting ${file}"
+ debug-print "bsfix: ${file}"
- cp "${file}" "${file}.orig" || die "failed to copy ${file}"
+ cp "${file}" "${file}.orig" || die "failed to copy ${file}"
- chmod u+w "${file}"
+ chmod u+w "${file}"
- xml-rewrite.py -f "${file}" -c -e ${JAVA_PKG_BSFIX_SOURCE_TAGS// / -e } -a source -v ${want_source} || die "xml-rewrite failed: ${file}"
- xml-rewrite.py -f "${file}" -c -e ${JAVA_PKG_BSFIX_TARGET_TAGS// / -e } -a target -v ${want_target} || die "xml-rewrite failed: ${file}"
+ xml-rewrite.py -f "${file}" -c -e ${JAVA_PKG_BSFIX_SOURCE_TAGS// / -e } -a source -v ${want_source} || die "xml-rewrite failed: ${file}"
+ xml-rewrite.py -f "${file}" -c -e ${JAVA_PKG_BSFIX_TARGET_TAGS// / -e } -a target -v ${want_target} || die "xml-rewrite failed: ${file}"
- if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
- diff -NurbB "${file}.orig" "${file}"
- fi
- done
+ if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
+ diff -NurbB "${file}.orig" "${file}"
+ fi
fi
}