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

Legend:
Removed from v.1.9  
changed lines
  Added in v.1.38

  ViewVC Help
Powered by ViewVC 1.1.20