/[gentoo-x86]/eclass/ruby-fakegem.eclass
Gentoo

Diff of /eclass/ruby-fakegem.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.5 Revision 1.36
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2012 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-fakegem.eclass,v 1.5 2009/12/16 09:51:30 flameeyes Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-fakegem.eclass,v 1.36 2012/08/15 15:06:09 flameeyes Exp $
4# 4
5# @ECLASS: ruby-fakegem.eclass 5# @ECLASS: ruby-fakegem.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Ruby herd <ruby@gentoo.org> 7# Ruby herd <ruby@gentoo.org>
8# 8# @AUTHOR:
9# Author: Diego E. Pettenò <flameeyes@gentoo.org> 9# Author: Diego E. Pettenò <flameeyes@gentoo.org>
10#
11# Author: Alex Legler <a3li@gentoo.org> 10# Author: Alex Legler <a3li@gentoo.org>
12#
13# @BLURB: An eclass for installing Ruby packages to behave like RubyGems. 11# @BLURB: An eclass for installing Ruby packages to behave like RubyGems.
14# @DESCRIPTION: 12# @DESCRIPTION:
15# This eclass allows to install arbitrary Ruby libraries (including Gems), 13# This eclass allows to install arbitrary Ruby libraries (including Gems),
16# providing integration into the RubyGems system even for "regular" packages. 14# providing integration into the RubyGems system even for "regular" packages.
17#
18 15
19inherit ruby-ng 16inherit ruby-ng
20 17
21# @ECLASS-VARIABLE: RUBY_FAKEGEM_NAME 18# @ECLASS-VARIABLE: RUBY_FAKEGEM_NAME
22# @DESCRIPTION: 19# @DESCRIPTION:
31# @ECLASS-VARIABLE: RUBY_FAKEGEM_TASK_DOC 28# @ECLASS-VARIABLE: RUBY_FAKEGEM_TASK_DOC
32# @DESCRIPTION: 29# @DESCRIPTION:
33# Specify the rake(1) task to run to generate documentation. 30# Specify the rake(1) task to run to generate documentation.
34# RUBY_FAKEGEM_TASK_DOC="rdoc" 31# RUBY_FAKEGEM_TASK_DOC="rdoc"
35 32
33# @ECLASS-VARIABLE: RUBY_FAKEGEM_RECIPE_TEST
34# @DESCRIPTION:
35# Specify one of the default testing function for ruby-fakegem:
36# - rake (default; see also RUBY_FAKEGEM_TASK_TEST)
37# - rspec (calls ruby-ng_rspec, adds dev-ruby/rspec:2 to the dependencies)
38# - cucumber (calls ruby-ng_cucumber, adds dev-util/cucumber to the
39# dependencies; does not work on JRuby).
40# - none
41# RUBY_FAKEGEM_RECIPE_TEST="rake"
42
36# @ECLASS-VARIABLE: RUBY_FAKEGEM_TASK_TEST 43# @ECLASS-VARIABLE: RUBY_FAKEGEM_TASK_TEST
37# @DESCRIPTION: 44# @DESCRIPTION:
38# Specify the rake(1) task used for executing tests. 45# Specify the rake(1) task used for executing tests. Only valid
46# if RUBY_FAKEGEM_RECIPE_TEST is set to "rake" (the default).
39# RUBY_FAKEGEM_TASK_TEST="test" 47# RUBY_FAKEGEM_TASK_TEST="test"
48
49# @ECLASS-VARIABLE: RUBY_FAKEGEM_RECIPE_DOC
50# @DESCRIPTION:
51# Specify one of the default API doc building function for ruby-fakegem:
52# - rake (default; see also RUBY_FAKEGEM_TASK_DOC)
53# - rdoc (calls `rdoc-2`, adds dev-ruby/rdoc to the dependencies);
54# - none
55# RUBY_FAKEGEM_RECIPE_DOC="rake"
40 56
41# @ECLASS-VARIABLE: RUBY_FAKEGEM_DOCDIR 57# @ECLASS-VARIABLE: RUBY_FAKEGEM_DOCDIR
42# @DESCRIPTION: 58# @DESCRIPTION:
43# Specify the directory under which the documentation is built; 59# Specify the directory under which the documentation is built;
44# if empty no documentation will be installed automatically. 60# if empty no documentation will be installed automatically.
61# Note: if RUBY_FAKEGEM_RECIPE_DOC is set to `rdoc`, this variable is
62# hardwired to `doc`.
45# RUBY_FAKEGEM_DOCDIR="" 63# RUBY_FAKEGEM_DOCDIR=""
46 64
47# @ECLASS-VARIABLE: RUBY_FAKEGEM_EXTRADOC 65# @ECLASS-VARIABLE: RUBY_FAKEGEM_EXTRADOC
48# @DESCRIPTION: 66# @DESCRIPTION:
49# Extra documentation to install (readme, changelogs, …). 67# Extra documentation to install (readme, changelogs, …).
50# RUBY_FAKEGEM_EXTRADOC="" 68# RUBY_FAKEGEM_EXTRADOC=""
51 69
70# @ECLASS-VARIABLE: RUBY_FAKEGEM_DOC_SOURCES
71# @DESCRIPTION:
72# Allow settings defined sources to scan for documentation.
73# This only applies if RUBY_FAKEGEM_DOC_TASK is set to `rdoc`.
74# RUBY_FAKEGEM_DOC_SOURCES="lib"
75
76# @ECLASS-VARIABLE: RUBY_FAKEGEM_BINWRAP
77# @DESCRIPTION:
78# Binaries to wrap around (relative to the bin/ directory)
79# RUBY_FAKEGEM_BINWRAP="*"
80
81# @ECLASS-VARIABLE: RUBY_FAKEGEM_REQUIRE_PATHS
82# @DESCRIPTION:
83# Extra require paths (beside lib) to add to the specification
84# RUBY_FAKEGEM_REQUIRE_PATHS=""
85
86# @ECLASS-VARIABLE: RUBY_FAKEGEM_GEMSPEC
87# @DESCRIPTION:
88# Filename of .gemspec file to install instead of generating a generic one.
89# RUBY_FAKEGEM_GEMSPEC=""
90
91# @ECLASS-VARIABLE: RUBY_FAKEGEM_EXTRAINSTALL
92# @DESCRIPTION:
93# List of files and directories relative to the top directory that also
94# get installed. Some gems provide extra files such as version information,
95# Rails generators, or data that needs to be installed as well.
96# RUBY_FAKEGEM_EXTRAINSTALL=""
97
52RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}" 98RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}"
53RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV}}" 99RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV/_pre/.pre}}"
100RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}"
54 101
102RUBY_FAKEGEM_RECIPE_DOC="${RUBY_FAKEGEM_RECIPE_DOC-rake}"
55RUBY_FAKEGEM_TASK_DOC="${RUBY_FAKEGEM_TASK_DOC-rdoc}" 103RUBY_FAKEGEM_TASK_DOC="${RUBY_FAKEGEM_TASK_DOC-rdoc}"
104RUBY_FAKEGEM_DOC_SOURCES="${RUBY_FAKEGEM_DOC_SOURCES-lib}"
105
106RUBY_FAKEGEM_RECIPE_TEST="${RUBY_FAKEGEM_RECIPE_TEST-rake}"
56RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}" 107RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}"
57 108
58if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then 109RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}"
110
111[[ ${RUBY_FAKEGEM_TASK_DOC} == "" ]] && RUBY_FAKEGEM_RECIPE_DOC="none"
112
113case ${RUBY_FAKEGEM_RECIPE_DOC} in
114 rake)
59 IUSE="$IUSE doc" 115 IUSE+=" doc"
60 ruby_add_bdepend doc "dev-ruby/rake" 116 ruby_add_bdepend "doc? ( dev-ruby/rake )"
61fi 117 ;;
118 rdoc)
119 IUSE+=" doc"
120 ruby_add_bdepend "doc? ( dev-ruby/rdoc )"
121 RUBY_FAKEGEM_DOCDIR="doc"
122 ;;
123 none)
124 [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && IUSE+=" doc"
125 ;;
126esac
62 127
63if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 128[[ ${RUBY_FAKEGEM_TASK_TEST} == "" ]] && RUBY_FAKEGEM_RECIPE_TEST="none"
129
130case ${RUBY_FAKEGEM_RECIPE_TEST} in
131 rake)
64 IUSE="$IUSE test" 132 IUSE+=" test"
65 ruby_add_bdepend test "dev-ruby/rake" 133 ruby_add_bdepend "test? ( dev-ruby/rake )"
66fi 134 ;;
135 rspec)
136 IUSE+=" test"
137 ruby_add_bdepend "test? ( dev-ruby/rspec:2 )"
138 ;;
139 cucumber)
140 IUSE+=" test"
141 # Unfortunately as of August 2012, cucumber is not supported on
142 # JRuby. We work it around here to avoid repeating the same
143 # code over and over again.
144 USE_RUBY="${USE_RUBY/jruby/}" ruby_add_bdepend "test? ( dev-util/cucumber )"
145 ;;
146 *)
147 RUBY_FAKEGEM_RECIPE_TEST="none"
148 ;;
149esac
67 150
68SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gem" 151SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem"
69 152
153ruby_add_bdepend virtual/rubygems
70ruby_add_rdepend virtual/rubygems 154ruby_add_rdepend virtual/rubygems
71 155
72# @FUNCTION: ruby_fakegem_gemsdir 156# @FUNCTION: ruby_fakegem_gemsdir
73# @RETURN: Returns the gem data directory 157# @RETURN: Returns the gem data directory
74# @DESCRIPTION: 158# @DESCRIPTION:
75# This function returns the gems data directory for the ruby 159# This function returns the gems data directory for the ruby
76# implementation in question. 160# implementation in question.
77ruby_fakegem_gemsdir() { 161ruby_fakegem_gemsdir() {
78 local _gemsitedir=$(${RUBY} -r rbconfig -e 'print Config::CONFIG["sitelibdir"]' | sed -e 's:site_ruby:gems:') 162 has "${EAPI}" 2 && ! use prefix && EPREFIX=
163
164 local _gemsitedir=$(ruby_rbconfig_value 'sitelibdir')
165 _gemsitedir=${_gemsitedir//site_ruby/gems}
166 _gemsitedir=${_gemsitedir#${EPREFIX}}
79 167
80 [[ -z ${_gemsitedir} ]] && { 168 [[ -z ${_gemsitedir} ]] && {
81 eerror "Unable to find the gems dir" 169 eerror "Unable to find the gems dir"
82 die "Unable to find the gems dir" 170 die "Unable to find the gems dir"
83 } 171 }
112 insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${newdirname} 200 insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${newdirname}
113 newins "$1" ${newbasename} 201 newins "$1" ${newbasename}
114 ) || die "failed $0 $@" 202 ) || die "failed $0 $@"
115} 203}
116 204
205# @FUNCTION: ruby_fakegem_install_gemspec
206# @DESCRIPTION:
207# Install a .gemspec file for this package. Either use the file indicated
208# by the RUBY_FAKEGEM_GEMSPEC variable, or generate one using
209# ruby_fakegem_genspec.
210ruby_fakegem_install_gemspec() {
211 local gemspec="${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation}
212
213 (
214 if [[ ${RUBY_FAKEGEM_GEMSPEC} != "" ]]; then
215 ruby_fakegem_gemspec_gemspec ${RUBY_FAKEGEM_GEMSPEC} ${gemspec}
216 else
217 local metadata="${WORKDIR}"/${_ruby_implementation}/metadata
218
219 if [[ -e ${metadata} ]]; then
220 ruby_fakegem_metadata_gemspec ${metadata} ${gemspec}
221 else
222 ruby_fakegem_genspec ${gemspec}
223 fi
224 fi
225 ) || die "Unable to generate gemspec file."
226
227 insinto $(ruby_fakegem_gemsdir)/specifications
228 newins ${gemspec} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec || die "Unable to install gemspec file."
229}
230
231# @FUNCTION: ruby_fakegem_gemspec_gemspec
232# @USAGE: gemspec-input gemspec-output
233# @DESCRIPTION:
234# Generates an installable version of the specification indicated by
235# RUBY_FAKEGEM_GEMSPEC. This file is eval'ed to produce a final specification
236# in a way similar to packaging the gemspec file.
237ruby_fakegem_gemspec_gemspec() {
238 ${RUBY} -e "puts eval(File::open('$1').read).to_ruby" > $2
239}
240
241# @FUNCTION: ruby_fakegem_metadata_gemspec
242# @USAGE: gemspec-metadata gemspec-output
243# @DESCRIPTION:
244# Generates an installable version of the specification indicated by
245# the metadata distributed by the gem itself. This is similar to how
246# rubygems creates an installation from a .gem file.
247ruby_fakegem_metadata_gemspec() {
248 ${RUBY} -r yaml -e "puts Gem::Specification.from_yaml(File::open('$1').read).to_ruby" > $2
249}
250
117# @FUNCTION: ruby_fakegem_genspec 251# @FUNCTION: ruby_fakegem_genspec
252# @USAGE: output-gemspec
118# @DESCRIPTION: 253# @DESCRIPTION:
119# Generates a gemspec for the package and places it into the "specifications" 254# Generates a gemspec for the package and places it into the "specifications"
120# directory of RubyGems. 255# directory of RubyGems.
256# If the metadata normally distributed with a gem is present then that is
257# used to generate the gemspec file.
258#
259# As a fallback we can generate our own version.
121# In the gemspec, the following values are set: name, version, summary, 260# In the gemspec, the following values are set: name, version, summary,
122# homepage, and require_paths=["lib"]. 261# homepage, and require_paths=["lib"].
123# See RUBY_FAKEGEM_NAME and RUBY_FAKEGEM_VERSION for setting name and version. 262# See RUBY_FAKEGEM_NAME and RUBY_FAKEGEM_VERSION for setting name and version.
263# See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths.
124ruby_fakegem_genspec() { 264ruby_fakegem_genspec() {
125 ( 265 local required_paths="'lib'"
266 for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do
267 required_paths="${required_paths}, '${path}'"
268 done
269
126 # We use the _ruby_implementation variable to avoid having stray 270 # We use the _ruby_implementation variable to avoid having stray
127 # copies with different implementations; while for now we're using 271 # copies with different implementations; while for now we're using
128 # the same exact content, we might have differences in the future, 272 # the same exact content, we might have differences in the future,
129 # so better taking this into consideration. 273 # so better taking this into consideration.
130 cat - > "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} <<EOF 274 local quoted_description=${DESCRIPTION//\"/\\\"}
275 cat - > $1 <<EOF
276# generated by ruby-fakegem.eclass $Revision: 1.36 $
131Gem::Specification.new do |s| 277Gem::Specification.new do |s|
132 s.name = "${RUBY_FAKEGEM_NAME}" 278 s.name = "${RUBY_FAKEGEM_NAME}"
133 s.version = "${RUBY_FAKEGEM_VERSION}" 279 s.version = "${RUBY_FAKEGEM_VERSION}"
134 s.summary = "${DESCRIPTION}" 280 s.summary = "${quoted_description}"
135 s.homepage = "${HOMEPAGE}" 281 s.homepage = "${HOMEPAGE}"
136 s.require_paths = ["lib"] 282 s.require_paths = [${required_paths}]
137end 283end
138EOF 284EOF
139
140 insinto $(ruby_fakegem_gemsdir)/specifications
141 newins "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec
142 ) || die "Unable to install fake gemspec"
143} 285}
144 286
145# @FUNCTION: ruby_fakegem_binwrapper 287# @FUNCTION: ruby_fakegem_binwrapper
146# @USAGE: command [path] 288# @USAGE: command [path]
147# @DESCRIPTION: 289# @DESCRIPTION:
150ruby_fakegem_binwrapper() { 292ruby_fakegem_binwrapper() {
151 ( 293 (
152 local gembinary=$1 294 local gembinary=$1
153 local newbinary=${2:-/usr/bin/$gembinary} 295 local newbinary=${2:-/usr/bin/$gembinary}
154 local relativegembinary=${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}/bin/${gembinary} 296 local relativegembinary=${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}/bin/${gembinary}
297 local binpath=$(dirname $newbinary)
298 [[ ${binpath} = . ]] && binpath=/usr/bin
299
300 # Try to find out whether the package is going to install for
301 # one or multiple implementations; if we're installing for a
302 # *single* implementation, no need to use “/usr/bin/env ruby”
303 # in the shebang, and we can actually avoid errors when
304 # calling the script by default (see for instance the
305 # JRuby-specific commands).
306 local rubycmd=
307 for implementation in ${USE_RUBY}; do
308 # ignore non-enabled implementations
309 use ruby_targets_${implementation} || continue
310 if [ -z $rubycmd ]; then
311 # if no other implementation was set before, set it.
312 rubycmd="$(ruby_implementation_command ${implementation})"
313 else
314 # if another implementation already arrived, then make
315 # it generic and break out of the loop. This ensures
316 # that we do at most two iterations.
317 rubycmd="/usr/bin/env ruby"
318 break
319 fi
320 done
155 321
156 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF 322 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF
157#!/usr/bin/env ruby 323#!${rubycmd}
158# This is a simplified version of the RubyGems wrapper 324# This is a simplified version of the RubyGems wrapper
159# 325#
160# Generated by ruby-fakegem.eclass 326# Generated by ruby-fakegem.eclass $Revision: 1.36 $
161 327
162require 'rubygems' 328require 'rubygems'
163 329
164load Gem::default_path[-1] + "/gems/${relativegembinary}" 330load Gem::default_path[-1] + "/gems/${relativegembinary}"
165 331
166EOF 332EOF
167 333
168 exeinto $(dirname $newbinary) 334 exeinto ${binpath:-/usr/bin}
169 newexe "${T}"/gembin-wrapper-${gembinary} $(basename $newbinary) 335 newexe "${T}"/gembin-wrapper-${gembinary} $(basename $newbinary)
170 ) || die "Unable to create fakegem wrapper" 336 ) || die "Unable to create fakegem wrapper"
171} 337}
172 338
173# @FUNCTION: all_fakegem_compile 339# @FUNCTION: all_fakegem_compile
174# @DESCRIPTION: 340# @DESCRIPTION:
175# Build documentation for the package if indicated by the doc USE flag 341# Build documentation for the package if indicated by the doc USE flag
176# and if there is a documetation task defined. 342# and if there is a documetation task defined.
177all_fakegem_compile() { 343all_fakegem_compile() {
178 if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]] && use doc; then 344 if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then
345 case ${RUBY_FAKEGEM_RECIPE_DOC} in
346 rake)
179 rake ${RUBY_FAKEGEM_TASK_DOC} || die "failed to (re)build documentation" 347 rake ${RUBY_FAKEGEM_TASK_DOC} || die "failed to (re)build documentation"
348 ;;
349 rdoc)
350 rdoc ${RUBY_FAKEGEM_DOC_SOURCES} || die "failed to (re)build documentation"
351 ;;
352 esac
180 fi 353 fi
181} 354}
182 355
183# @FUNCTION: all_ruby_unpack 356# @FUNCTION: all_ruby_unpack
184# @DESCRIPTION: 357# @DESCRIPTION:
185# Unpack the source archive, including support for unpacking gems. 358# Unpack the source archive, including support for unpacking gems.
186all_ruby_unpack() { 359all_ruby_unpack() {
187 # Special support for extracting .gem files; the file need to be 360 # Special support for extracting .gem files; the file need to be
188 # extracted twice and the mtime from the archive _has_ to be 361 # extracted twice and the mtime from the archive _has_ to be
189 # ignored (it's always set to epoch 0). 362 # ignored (it's always set to epoch 0).
190 # 363 for archive in ${A}; do
191 # This only works if there is exactly one archive and that archive 364 case "${archive}" in
192 # is a .gem file! 365 *.gem)
193 if [[ $(wc -w <<< ${A}) == 1 ]] && 366 # Make sure that we're not running unpack for more than
194 [[ ${A} == *.gem ]]; then 367 # one .gem file, since we won't support that at all.
368 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists"
369
195 ebegin "Unpacking .gem file..." 370 ebegin "Unpacking .gem file..."
196 tar -mxf ${DISTDIR}/${A} || die 371 tar -mxf ${DISTDIR}/${archive} || die
197 eend $? 372 eend $?
198 373
374 ebegin "Uncompressing metadata"
375 gunzip metadata.gz || die
376 eend $?
377
199 mkdir "${S}" 378 mkdir "${S}"
200 pushd "${S}" 379 pushd "${S}" &>/dev/null
201 380
202 ebegin "Unpacking data.tar.gz" 381 ebegin "Unpacking data.tar.gz"
203 tar -mxf "${my_WORKDIR}"/data.tar.gz || die 382 tar -mxf "${my_WORKDIR}"/data.tar.gz || die
204 eend $? 383 eend $?
205 else 384
206 [[ -n ${A} ]] && unpack ${A} 385 popd &>/dev/null
207 fi 386 ;;
387 *.patch.bz2)
388 # We apply the patches with RUBY_PATCHES directly from DISTDIR,
389 # as the WORKDIR variable changes value between the global-scope
390 # and the time all_ruby_unpack/_prepare are called. Since we can
391 # simply decompress them when applying, this is much easier to
392 # deal with for us.
393 einfo "Keeping ${archive} as-is"
394 ;;
395 *)
396 unpack ${archive}
397 ;;
398 esac
399 done
208} 400}
209 401
210# @FUNCTION: all_ruby_compile 402# @FUNCTION: all_ruby_compile
211# @DESCRIPTION: 403# @DESCRIPTION:
212# Compile the package. 404# Compile the package.
216 408
217# @FUNCTION: each_fakegem_test 409# @FUNCTION: each_fakegem_test
218# @DESCRIPTION: 410# @DESCRIPTION:
219# Run tests for the package for each ruby target if the test task is defined. 411# Run tests for the package for each ruby target if the test task is defined.
220each_fakegem_test() { 412each_fakegem_test() {
221 local rubyflags= 413 case ${RUBY_FAKEGEM_RECIPE_TEST} in
222 414 rake)
223 if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then
224 ${RUBY} ${rubyflags} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed" 415 ${RUBY} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed"
225 else 416 ;;
226 echo "No test task defined, skipping tests." 417 rspec)
227 fi 418 ruby-ng_rspec
419 ;;
420 cucumber)
421 ruby-ng_cucumber
422 ;;
423 none)
424 ewarn "each_fakegem_test called, but \${RUBY_FAKEGEM_RECIPE_TEST} is 'none'"
425 ;;
426 esac
228} 427}
229 428
429if [[ ${RUBY_FAKEGEM_RECIPE_TEST} != none ]]; then
230# @FUNCTION: each_ruby_test 430 # @FUNCTION: each_ruby_test
231# @DESCRIPTION: 431 # @DESCRIPTION:
232# Run the tests for this package. 432 # Run the tests for this package.
233each_ruby_test() { 433 each_ruby_test() {
234 each_fakegem_test 434 each_fakegem_test
235} 435 }
436fi
236 437
237# @FUNCTION: each_fakegem_install 438# @FUNCTION: each_fakegem_install
238# @DESCRIPTION: 439# @DESCRIPTION:
239# Install the package for each ruby target. 440# Install the package for each ruby target.
240each_fakegem_install() { 441each_fakegem_install() {
241 ruby_fakegem_genspec 442 ruby_fakegem_install_gemspec
242 443
243 local _gemlibdirs= 444 local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}"
244 for directory in bin lib ${RUBY_FAKEGEM_EXTRAINSTALL}; do 445 for directory in bin lib; do
245 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}" 446 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}"
246 done 447 done
247 448
449 [[ -n ${_gemlibdirs} ]] && \
248 ruby_fakegem_doins -r ${_gemlibdirs} 450 ruby_fakegem_doins -r ${_gemlibdirs}
249} 451}
250 452
251# @FUNCTION: each_ruby_install 453# @FUNCTION: each_ruby_install
252# @DESCRIPTION: 454# @DESCRIPTION:
253# Install the package for each target. 455# Install the package for each target.
258# @FUNCTION: all_fakegem_install 460# @FUNCTION: all_fakegem_install
259# @DESCRIPTION: 461# @DESCRIPTION:
260# Install files common to all ruby targets. 462# Install files common to all ruby targets.
261all_fakegem_install() { 463all_fakegem_install() {
262 if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then 464 if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then
263 pushd ${RUBY_FAKEGEM_DOCDIR} 465 for dir in ${RUBY_FAKEGEM_DOCDIR}; do
466 [[ -d ${dir} ]] || continue
467
468 pushd ${dir} &>/dev/null
264 dohtml -r * || die "failed to install documentation" 469 dohtml -r * || die "failed to install documentation"
265 popd 470 popd &>/dev/null
471 done
266 fi 472 fi
267 473
268 if [[ -n ${RUBY_FAKEGEM_EXTRADOC} ]]; then 474 if [[ -n ${RUBY_FAKEGEM_EXTRADOC} ]]; then
269 dodoc ${RUBY_FAKEGEM_EXTRADOC} || die "failed to install further documentation" 475 dodoc ${RUBY_FAKEGEM_EXTRADOC} || die "failed to install further documentation"
270 fi 476 fi
477
478 # binary wrappers; we assume that all the implementations get the
479 # same binaries, or something is wrong anyway, so...
480 if [[ -n ${RUBY_FAKEGEM_BINWRAP} ]]; then
481 local bindir=$(find "${D}" -type d -path "*/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}/bin" -print -quit)
482
483 if [[ -d "${bindir}" ]]; then
484 pushd "${bindir}" &>/dev/null
485 local binaries=$(eval ls ${RUBY_FAKEGEM_BINWRAP})
486 for binary in $binaries; do
487 ruby_fakegem_binwrapper $binary
488 done
489 popd &>/dev/null
490 fi
491 fi
271} 492}
272 493
273# @FUNCTION: all_ruby_install 494# @FUNCTION: all_ruby_install
274# @DESCRIPTION: 495# @DESCRIPTION:
275# Install files common to all ruby targets. 496# Install files common to all ruby targets.

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.36

  ViewVC Help
Powered by ViewVC 1.1.20