/[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.24 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.24 2010/09/23 06:47:01 grobian 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
60# RUBY_FAKEGEM_REQUIRE_PATHS="" 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=""
61 97
62RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}" 98RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}"
63RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV/_pre/.pre}}" 99RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV/_pre/.pre}}"
64RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}" 100RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}"
65 101
102RUBY_FAKEGEM_RECIPE_DOC="${RUBY_FAKEGEM_RECIPE_DOC-rake}"
66RUBY_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}"
67RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}" 107RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}"
68 108
69RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}" 109RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}"
70 110
71if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then 111[[ ${RUBY_FAKEGEM_TASK_DOC} == "" ]] && RUBY_FAKEGEM_RECIPE_DOC="none"
112
113case ${RUBY_FAKEGEM_RECIPE_DOC} in
114 rake)
72 IUSE="$IUSE doc" 115 IUSE+=" doc"
73 ruby_add_bdepend "doc? ( dev-ruby/rake )" 116 ruby_add_bdepend "doc? ( dev-ruby/rake )"
74fi 117 RUBY_FAKEGEM_DOCDIR="doc"
75 118 ;;
76if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]]; then 119 rdoc)
77 IUSE="$IUSE doc" 120 IUSE+=" doc"
78fi 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
79 128
80if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 129[[ ${RUBY_FAKEGEM_TASK_TEST} == "" ]] && RUBY_FAKEGEM_RECIPE_TEST="none"
130
131case ${RUBY_FAKEGEM_RECIPE_TEST} in
132 rake)
81 IUSE="$IUSE test" 133 IUSE+=" test"
82 ruby_add_bdepend "test? ( dev-ruby/rake )" 134 ruby_add_bdepend "test? ( dev-ruby/rake )"
83fi 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
84 151
85SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem" 152SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem"
86 153
154ruby_add_bdepend virtual/rubygems
87ruby_add_rdepend virtual/rubygems 155ruby_add_rdepend virtual/rubygems
88 156
89# @FUNCTION: ruby_fakegem_gemsdir 157# @FUNCTION: ruby_fakegem_gemsdir
90# @RETURN: Returns the gem data directory 158# @RETURN: Returns the gem data directory
91# @DESCRIPTION: 159# @DESCRIPTION:
133 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}
134 newins "$1" ${newbasename} 202 newins "$1" ${newbasename}
135 ) || die "failed $0 $@" 203 ) || die "failed $0 $@"
136} 204}
137 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
138# @FUNCTION: ruby_fakegem_genspec 259# @FUNCTION: ruby_fakegem_genspec
260# @USAGE: output-gemspec
139# @DESCRIPTION: 261# @DESCRIPTION:
140# 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"
141# 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.
142# In the gemspec, the following values are set: name, version, summary, 268# In the gemspec, the following values are set: name, version, summary,
143# homepage, and require_paths=["lib"]. 269# homepage, and require_paths=["lib"].
144# 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.
145# See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths. 271# See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths.
146ruby_fakegem_genspec() { 272ruby_fakegem_genspec() {
147 (
148 local required_paths="'lib'" 273 local required_paths="'lib'"
149 for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do 274 for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do
150 required_paths="${required_paths}, '${path}'" 275 required_paths="${required_paths}, '${path}'"
151 done 276 done
152 277
153 # We use the _ruby_implementation variable to avoid having stray 278 # We use the _ruby_implementation variable to avoid having stray
154 # copies with different implementations; while for now we're using 279 # copies with different implementations; while for now we're using
155 # the same exact content, we might have differences in the future, 280 # the same exact content, we might have differences in the future,
156 # so better taking this into consideration. 281 # so better taking this into consideration.
157 local quoted_description=${DESCRIPTION//\"/\\\"} 282 local quoted_description=${DESCRIPTION//\"/\\\"}
158 cat - > "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} <<EOF 283 cat - > $1 <<EOF
159# generated by ruby-fakegem.eclass $Revision: 1.24 $ 284# generated by ruby-fakegem.eclass $Revision: 1.38 $
160Gem::Specification.new do |s| 285Gem::Specification.new do |s|
161 s.name = "${RUBY_FAKEGEM_NAME}" 286 s.name = "${RUBY_FAKEGEM_NAME}"
162 s.version = "${RUBY_FAKEGEM_VERSION}" 287 s.version = "${RUBY_FAKEGEM_VERSION}"
163 s.summary = "${quoted_description}" 288 s.summary = "${quoted_description}"
164 s.homepage = "${HOMEPAGE}" 289 s.homepage = "${HOMEPAGE}"
165 s.require_paths = [${required_paths}] 290 s.require_paths = [${required_paths}]
166end 291end
167EOF 292EOF
168
169 insinto $(ruby_fakegem_gemsdir)/specifications
170 newins "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec
171 ) || die "Unable to install fake gemspec"
172} 293}
173 294
174# @FUNCTION: ruby_fakegem_binwrapper 295# @FUNCTION: ruby_fakegem_binwrapper
175# @USAGE: command [path] 296# @USAGE: command [path]
176# @DESCRIPTION: 297# @DESCRIPTION:
208 329
209 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF 330 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF
210#!${rubycmd} 331#!${rubycmd}
211# This is a simplified version of the RubyGems wrapper 332# This is a simplified version of the RubyGems wrapper
212# 333#
213# Generated by ruby-fakegem.eclass $Revision: 1.24 $ 334# Generated by ruby-fakegem.eclass $Revision: 1.38 $
214 335
215require 'rubygems' 336require 'rubygems'
216 337
217load Gem::default_path[-1] + "/gems/${relativegembinary}" 338load Gem::default_path[-1] + "/gems/${relativegembinary}"
218 339
226# @FUNCTION: all_fakegem_compile 347# @FUNCTION: all_fakegem_compile
227# @DESCRIPTION: 348# @DESCRIPTION:
228# 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
229# and if there is a documetation task defined. 350# and if there is a documetation task defined.
230all_fakegem_compile() { 351all_fakegem_compile() {
231 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)
232 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
233 fi 361 fi
234} 362}
235 363
236# @FUNCTION: all_ruby_unpack 364# @FUNCTION: all_ruby_unpack
237# @DESCRIPTION: 365# @DESCRIPTION:
241 # extracted twice and the mtime from the archive _has_ to be 369 # extracted twice and the mtime from the archive _has_ to be
242 # ignored (it's always set to epoch 0). 370 # ignored (it's always set to epoch 0).
243 for archive in ${A}; do 371 for archive in ${A}; do
244 case "${archive}" in 372 case "${archive}" in
245 *.gem) 373 *.gem)
246 # Make sure that we're not running unoack for more than 374 # Make sure that we're not running unpack for more than
247 # one .gem file, since we won't support that at all. 375 # one .gem file, since we won't support that at all.
248 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists" 376 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists"
249 377
250 ebegin "Unpacking .gem file..." 378 ebegin "Unpacking .gem file..."
251 tar -mxf ${DISTDIR}/${archive} || die 379 tar -mxf ${DISTDIR}/${archive} || die
252 eend $? 380 eend $?
253 381
382 ebegin "Uncompressing metadata"
383 gunzip metadata.gz || die
384 eend $?
385
254 mkdir "${S}" 386 mkdir "${S}"
255 pushd "${S}" &>/dev/null 387 pushd "${S}" &>/dev/null
256 388
257 ebegin "Unpacking data.tar.gz" 389 ebegin "Unpacking data.tar.gz"
258 tar -mxf "${my_WORKDIR}"/data.tar.gz || die 390 tar -mxf "${my_WORKDIR}"/data.tar.gz || die
259 eend $? 391 eend $?
392
260 popd &>/dev/null 393 popd &>/dev/null
261 ;; 394 ;;
262 *.patch.bz2) 395 *.patch.bz2)
263 # We apply the patches with RUBY_PATCHES directly from DISTDIR, 396 # We apply the patches with RUBY_PATCHES directly from DISTDIR,
264 # as the WORKDIR variable changes value between the global-scope 397 # as the WORKDIR variable changes value between the global-scope
283 416
284# @FUNCTION: each_fakegem_test 417# @FUNCTION: each_fakegem_test
285# @DESCRIPTION: 418# @DESCRIPTION:
286# 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.
287each_fakegem_test() { 420each_fakegem_test() {
288 local rubyflags= 421 case ${RUBY_FAKEGEM_RECIPE_TEST} in
422 rake)
289 ${RUBY} ${rubyflags} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed" 423 ${RUBY} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed"
424 ;;
425 rspec)
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
290} 435}
291 436
292if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 437if [[ ${RUBY_FAKEGEM_RECIPE_TEST} != none ]]; then
293 # @FUNCTION: each_ruby_test 438 # @FUNCTION: each_ruby_test
294 # @DESCRIPTION: 439 # @DESCRIPTION:
295 # Run the tests for this package. 440 # Run the tests for this package.
296 each_ruby_test() { 441 each_ruby_test() {
297 each_fakegem_test 442 each_fakegem_test
298 } 443 }
299fi 444fi
300 445
301# @FUNCTION: each_fakegem_install 446# @FUNCTION: each_fakegem_install
302# @DESCRIPTION: 447# @DESCRIPTION:
303# Install the package for each ruby target. 448# Install the package for each ruby target.
304each_fakegem_install() { 449each_fakegem_install() {
305 ruby_fakegem_genspec 450 ruby_fakegem_install_gemspec
306 451
307 local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}" 452 local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}"
308 for directory in bin lib; do 453 for directory in bin lib; do
309 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}" 454 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}"
310 done 455 done

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

  ViewVC Help
Powered by ViewVC 1.1.20