summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--eclass/ruby-ng.eclass108
1 files changed, 49 insertions, 59 deletions
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index 8bcf93704d5f..11516aebb7f7 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -1,6 +1,6 @@
# Copyright 1999-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-ng.eclass,v 1.15 2010/05/22 03:39:50 flameeyes Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-ng.eclass,v 1.16 2010/05/22 12:18:07 flameeyes Exp $
#
# @ECLASS: ruby-ng.eclass
# @MAINTAINER:
@@ -116,38 +116,12 @@ _ruby_implementation_depend() {
echo "ruby_targets_${1}? ( ${2}[ruby_targets_${1}] )"
}
-_ruby_add_bdepend() {
- local atom=$1
- local conditions=$2
-
- for condition in $conditions; do
- hasq $condition "$IUSE" || IUSE="${IUSE} $condition"
- atom="${condition}? ( ${atom} )"
- done
-
- DEPEND="${DEPEND} ${atom}"
- RDEPEND="${RDEPEND}"
-}
-
-_ruby_add_rdepend() {
- local atom=$1
- local conditions=$2
-
- for condition in $conditions; do
- hasq $condition "$IUSE" || IUSE="${IUSE} $condition"
- atom="${condition}? ( ${atom} )"
- done
-
- RDEPEND="${RDEPEND} ${atom}"
- _ruby_add_bdepend "$atom" test
-}
-
_ruby_atoms_samelib() {
local samelib=$(ruby_samelib)
for token in $*; do
case "$token" in
- "||" | "(" | ")" )
+ "||" | "(" | ")" | *"?")
echo "${token}" ;;
*)
echo "${token}${samelib}" ;;
@@ -155,61 +129,77 @@ _ruby_atoms_samelib() {
done
}
+_ruby_wrap_conditions() {
+ local conditions="$1"
+ local atoms="$2"
+
+ for condition in $conditions; do
+ hasq $condition "$IUSE" || IUSE="${IUSE} $condition"
+ atoms="${condition}? ( ${atoms} )"
+ done
+
+ echo "$atoms"
+}
+
# @FUNCTION: ruby_add_rdepend
-# @USAGE: [conditions] atom
+# @USAGE: dependencies
# @DESCRIPTION:
-# Adds the specified atom(s) with optional use condition(s) to
-# RDEPEND, taking the current set of ruby targets into account. This
-# makes sure that all ruby dependencies of the package are installed
-# for the same ruby targets. Use this function for all ruby
-# dependencies instead of setting RDEPEND yourself. Both atom and
-# conditions can be a space-separated list of atoms or conditions.
+# Adds the specified dependencies, with use condition(s) to RDEPEND,
+# taking the current set of ruby targets into account. This makes sure
+# that all ruby dependencies of the package are installed for the same
+# ruby targets. Use this function for all ruby dependencies instead of
+# setting RDEPEND yourself. The list of atoms uses the same syntax as
+# normal dependencies.
+#
+# Note: runtime dependencies are also added as build-time test
+# dependencies.
ruby_add_rdepend() {
- local atoms=
- local conditions=
case $# in
- 1)
- atoms=$1
- ;;
+ 1) ;;
2)
- conditions=$1
- atoms=$2
+ [[ "${GENTOO_DEV}" == "yes" ]] && eqawarn "You can now use the usual syntax in ruby_add_rdepend for $CATEGORY/$PF"
+ ruby_add_rdepend "$(_ruby_wrap_conditions "$1" "$2")"
+ return
;;
*)
die "bad number of arguments to $0"
;;
esac
- _ruby_add_rdepend "$(_ruby_atoms_samelib "${atoms}")" "$conditions"
+ local dependency=$(_ruby_atoms_samelib "$1")
+
+ RDEPEND="${RDEPEND} $dependency"
+
+ # Add the dependency as a test-dependency since we're going to
+ # execute the code during test phase.
+ DEPEND="${DEPEND} $(_ruby_wrap_conditions test "${dependency}")"
}
# @FUNCTION: ruby_add_bdepend
-# @USAGE: [conditions] atom
+# @USAGE: dependencies
# @DESCRIPTION:
-# Adds the specified atom(s) with optional use condition(s) to both
-# DEPEND and RDEPEND, taking the current set of ruby targets into
-# account. This makes sure that all ruby dependencies of the package
-# are installed for the same ruby targets. Use this function for all
-# ruby dependencies instead of setting DEPEND and RDEPEND
-# yourself. Both atom and conditions can be a space-separated list of
-# atoms or conditions.
+# Adds the specified dependencies, with use condition(s) to DEPEND,
+# taking the current set of ruby targets into account. This makes sure
+# that all ruby dependencies of the package are installed for the same
+# ruby targets. Use this function for all ruby dependencies instead of
+# setting DEPEND yourself. The list of atoms uses the same syntax as
+# normal dependencies.
ruby_add_bdepend() {
- local atoms=
- local conditions=
case $# in
- 1)
- atoms=$1
- ;;
+ 1) ;;
2)
- conditions=$1
- atoms=$2
+ [[ "${GENTOO_DEV}" == "yes" ]] && eqawarn "You can now use the usual syntax in ruby_add_bdepend for $CATEGORY/$PF"
+ ruby_add_bdepend "$(_ruby_wrap_conditions "$1" "$2")"
+ return
;;
*)
die "bad number of arguments to $0"
;;
esac
- _ruby_add_bdepend "$(_ruby_atoms_samelib "${atoms}")" "$conditions"
+ local dependency=$(_ruby_atoms_samelib "$1")
+
+ DEPEND="${DEPEND} $dependency"
}
for _ruby_implementation in $USE_RUBY; do