/[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.25 Revision 1.34
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.25 2010/12/18 09:50:08 graaff Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-fakegem.eclass,v 1.34 2012/08/13 22:21:26 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"
40 48
41# @ECLASS-VARIABLE: RUBY_FAKEGEM_DOCDIR 49# @ECLASS-VARIABLE: RUBY_FAKEGEM_DOCDIR
42# @DESCRIPTION: 50# @DESCRIPTION:
43# Specify the directory under which the documentation is built; 51# Specify the directory under which the documentation is built;
62# @ECLASS-VARIABLE: RUBY_FAKEGEM_GEMSPEC 70# @ECLASS-VARIABLE: RUBY_FAKEGEM_GEMSPEC
63# @DESCRIPTION: 71# @DESCRIPTION:
64# Filename of .gemspec file to install instead of generating a generic one. 72# Filename of .gemspec file to install instead of generating a generic one.
65# RUBY_FAKEGEM_GEMSPEC="" 73# RUBY_FAKEGEM_GEMSPEC=""
66 74
75# @ECLASS-VARIABLE: RUBY_FAKEGEM_EXTRAINSTALL
76# @DESCRIPTION:
77# List of files and directories relative to the top directory that also
78# get installed. Some gems provide extra files such as version information,
79# Rails generators, or data that needs to be installed as well.
80# RUBY_FAKEGEM_EXTRAINSTALL=""
81
67RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}" 82RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN}}"
68RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV/_pre/.pre}}" 83RUBY_FAKEGEM_VERSION="${RUBY_FAKEGEM_VERSION:-${PV/_pre/.pre}}"
69RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}" 84RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}"
70 85
71RUBY_FAKEGEM_TASK_DOC="${RUBY_FAKEGEM_TASK_DOC-rdoc}" 86RUBY_FAKEGEM_TASK_DOC="${RUBY_FAKEGEM_TASK_DOC-rdoc}"
87RUBY_FAKEGEM_RECIPE_TEST="${RUBY_FAKEGEM_RECIPE_TEST-rake}"
72RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}" 88RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}"
73 89
74RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}" 90RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}"
75 91
76if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then 92if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then
80 96
81if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]]; then 97if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]]; then
82 IUSE="$IUSE doc" 98 IUSE="$IUSE doc"
83fi 99fi
84 100
85if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 101[[ ${RUBY_FAKEGEM_TASK_TEST} == "" ]] && RUBY_FAKEGEM_RECIPE_TEST="none"
102
103case ${RUBY_FAKEGEM_RECIPE_TEST} in
104 rake)
86 IUSE="$IUSE test" 105 IUSE+=" test"
87 ruby_add_bdepend "test? ( dev-ruby/rake )" 106 ruby_add_bdepend "test? ( dev-ruby/rake )"
88fi 107 ;;
108 rspec)
109 IUSE+=" test"
110 ruby_add_bdepend "test? ( dev-ruby/rspec:2 )"
111 ;;
112 cucumber)
113 IUSE+=" test"
114 # Unfortunately as of August 2012, cucumber is not supported on
115 # JRuby. We work it around here to avoid repeating the same
116 # code over and over again.
117 USE_RUBY="${USE_RUBY/jruby/}" ruby_add_bdepend "test? ( dev-util/cucumber )"
118 ;;
119 *)
120 RUBY_FAKEGEM_RECIPE_TEST="none"
121 ;;
122esac
89 123
90SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem" 124SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem"
91 125
126ruby_add_bdepend virtual/rubygems
92ruby_add_rdepend dev-ruby/rubygems 127ruby_add_rdepend virtual/rubygems
93 128
94# @FUNCTION: ruby_fakegem_gemsdir 129# @FUNCTION: ruby_fakegem_gemsdir
95# @RETURN: Returns the gem data directory 130# @RETURN: Returns the gem data directory
96# @DESCRIPTION: 131# @DESCRIPTION:
97# This function returns the gems data directory for the ruby 132# This function returns the gems data directory for the ruby
138 insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${newdirname} 173 insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${newdirname}
139 newins "$1" ${newbasename} 174 newins "$1" ${newbasename}
140 ) || die "failed $0 $@" 175 ) || die "failed $0 $@"
141} 176}
142 177
143# @FUNCTION: ruby_fakegem_gemspec 178# @FUNCTION: ruby_fakegem_install_gemspec
144# @DESCRIPTION: 179# @DESCRIPTION:
145# Install a .gemspec file for this package. Either use the file indicated 180# Install a .gemspec file for this package. Either use the file indicated
146# by the RUBY_FAKEGEM_GEMSPEC variable, or generate one using 181# by the RUBY_FAKEGEM_GEMSPEC variable, or generate one using
147# ruby_fakegem_genspec 182# ruby_fakegem_genspec.
148ruby_fakegem_gemspec() { 183ruby_fakegem_install_gemspec() {
184 local gemspec="${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation}
185
186 (
149 if [[ ${RUBY_FAKEGEM_GEMSPEC} != "" ]]; then 187 if [[ ${RUBY_FAKEGEM_GEMSPEC} != "" ]]; then
150 ( 188 ruby_fakegem_gemspec_gemspec ${RUBY_FAKEGEM_GEMSPEC} ${gemspec}
189 else
190 local metadata="${WORKDIR}"/${_ruby_implementation}/metadata
191
192 if [[ -e ${metadata} ]]; then
193 ruby_fakegem_metadata_gemspec ${metadata} ${gemspec}
194 else
195 ruby_fakegem_genspec ${gemspec}
196 fi
197 fi
198 ) || die "Unable to generate gemspec file."
199
151 insinto $(ruby_fakegem_gemsdir)/specifications 200 insinto $(ruby_fakegem_gemsdir)/specifications
152 newins "${RUBY_FAKEGEM_GEMSPEC}" ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec 201 newins ${gemspec} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec || die "Unable to install gemspec file."
153 ) || die "Unable to install ${RUBY_FAKEGEM_GEMSPEC} gemspec" 202}
154 else 203
155 ruby_fakegem_genspec 204# @FUNCTION: ruby_fakegem_gemspec_gemspec
156 fi 205# @USAGE: gemspec-input gemspec-output
206# @DESCRIPTION:
207# Generates an installable version of the specification indicated by
208# RUBY_FAKEGEM_GEMSPEC. This file is eval'ed to produce a final specification
209# in a way similar to packaging the gemspec file.
210ruby_fakegem_gemspec_gemspec() {
211 ${RUBY} -e "puts eval(File::open('$1').read).to_ruby" > $2
212}
213
214# @FUNCTION: ruby_fakegem_metadata_gemspec
215# @USAGE: gemspec-metadata gemspec-output
216# @DESCRIPTION:
217# Generates an installable version of the specification indicated by
218# the metadata distributed by the gem itself. This is similar to how
219# rubygems creates an installation from a .gem file.
220ruby_fakegem_metadata_gemspec() {
221 ${RUBY} -r yaml -e "puts Gem::Specification.from_yaml(File::open('$1').read).to_ruby" > $2
157} 222}
158 223
159# @FUNCTION: ruby_fakegem_genspec 224# @FUNCTION: ruby_fakegem_genspec
225# @USAGE: output-gemspec
160# @DESCRIPTION: 226# @DESCRIPTION:
161# Generates a gemspec for the package and places it into the "specifications" 227# Generates a gemspec for the package and places it into the "specifications"
162# directory of RubyGems. 228# directory of RubyGems.
229# If the metadata normally distributed with a gem is present then that is
230# used to generate the gemspec file.
231#
232# As a fallback we can generate our own version.
163# In the gemspec, the following values are set: name, version, summary, 233# In the gemspec, the following values are set: name, version, summary,
164# homepage, and require_paths=["lib"]. 234# homepage, and require_paths=["lib"].
165# See RUBY_FAKEGEM_NAME and RUBY_FAKEGEM_VERSION for setting name and version. 235# See RUBY_FAKEGEM_NAME and RUBY_FAKEGEM_VERSION for setting name and version.
166# See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths. 236# See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths.
167ruby_fakegem_genspec() { 237ruby_fakegem_genspec() {
168 (
169 local required_paths="'lib'" 238 local required_paths="'lib'"
170 for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do 239 for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do
171 required_paths="${required_paths}, '${path}'" 240 required_paths="${required_paths}, '${path}'"
172 done 241 done
173 242
174 # We use the _ruby_implementation variable to avoid having stray 243 # We use the _ruby_implementation variable to avoid having stray
175 # copies with different implementations; while for now we're using 244 # copies with different implementations; while for now we're using
176 # the same exact content, we might have differences in the future, 245 # the same exact content, we might have differences in the future,
177 # so better taking this into consideration. 246 # so better taking this into consideration.
178 local quoted_description=${DESCRIPTION//\"/\\\"} 247 local quoted_description=${DESCRIPTION//\"/\\\"}
179 cat - > "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} <<EOF 248 cat - > $1 <<EOF
180# generated by ruby-fakegem.eclass $Revision: 1.25 $ 249# generated by ruby-fakegem.eclass $Revision: 1.34 $
181Gem::Specification.new do |s| 250Gem::Specification.new do |s|
182 s.name = "${RUBY_FAKEGEM_NAME}" 251 s.name = "${RUBY_FAKEGEM_NAME}"
183 s.version = "${RUBY_FAKEGEM_VERSION}" 252 s.version = "${RUBY_FAKEGEM_VERSION}"
184 s.summary = "${quoted_description}" 253 s.summary = "${quoted_description}"
185 s.homepage = "${HOMEPAGE}" 254 s.homepage = "${HOMEPAGE}"
186 s.require_paths = [${required_paths}] 255 s.require_paths = [${required_paths}]
187end 256end
188EOF 257EOF
189
190 insinto $(ruby_fakegem_gemsdir)/specifications
191 newins "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec
192 ) || die "Unable to install fake gemspec"
193} 258}
194 259
195# @FUNCTION: ruby_fakegem_binwrapper 260# @FUNCTION: ruby_fakegem_binwrapper
196# @USAGE: command [path] 261# @USAGE: command [path]
197# @DESCRIPTION: 262# @DESCRIPTION:
229 294
230 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF 295 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF
231#!${rubycmd} 296#!${rubycmd}
232# This is a simplified version of the RubyGems wrapper 297# This is a simplified version of the RubyGems wrapper
233# 298#
234# Generated by ruby-fakegem.eclass $Revision: 1.25 $ 299# Generated by ruby-fakegem.eclass $Revision: 1.34 $
235 300
236require 'rubygems' 301require 'rubygems'
237 302
238load Gem::default_path[-1] + "/gems/${relativegembinary}" 303load Gem::default_path[-1] + "/gems/${relativegembinary}"
239 304
262 # extracted twice and the mtime from the archive _has_ to be 327 # extracted twice and the mtime from the archive _has_ to be
263 # ignored (it's always set to epoch 0). 328 # ignored (it's always set to epoch 0).
264 for archive in ${A}; do 329 for archive in ${A}; do
265 case "${archive}" in 330 case "${archive}" in
266 *.gem) 331 *.gem)
267 # Make sure that we're not running unoack for more than 332 # Make sure that we're not running unpack for more than
268 # one .gem file, since we won't support that at all. 333 # one .gem file, since we won't support that at all.
269 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists" 334 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists"
270 335
271 ebegin "Unpacking .gem file..." 336 ebegin "Unpacking .gem file..."
272 tar -mxf ${DISTDIR}/${archive} || die 337 tar -mxf ${DISTDIR}/${archive} || die
273 eend $? 338 eend $?
274 339
340 ebegin "Uncompressing metadata"
341 gunzip metadata.gz || die
342 eend $?
343
275 mkdir "${S}" 344 mkdir "${S}"
276 pushd "${S}" &>/dev/null 345 pushd "${S}" &>/dev/null
277 346
278 ebegin "Unpacking data.tar.gz" 347 ebegin "Unpacking data.tar.gz"
279 tar -mxf "${my_WORKDIR}"/data.tar.gz || die 348 tar -mxf "${my_WORKDIR}"/data.tar.gz || die
280 eend $? 349 eend $?
350
281 popd &>/dev/null 351 popd &>/dev/null
282 ;; 352 ;;
283 *.patch.bz2) 353 *.patch.bz2)
284 # We apply the patches with RUBY_PATCHES directly from DISTDIR, 354 # We apply the patches with RUBY_PATCHES directly from DISTDIR,
285 # as the WORKDIR variable changes value between the global-scope 355 # as the WORKDIR variable changes value between the global-scope
304 374
305# @FUNCTION: each_fakegem_test 375# @FUNCTION: each_fakegem_test
306# @DESCRIPTION: 376# @DESCRIPTION:
307# Run tests for the package for each ruby target if the test task is defined. 377# Run tests for the package for each ruby target if the test task is defined.
308each_fakegem_test() { 378each_fakegem_test() {
309 local rubyflags= 379 case ${RUBY_FAKEGEM_RECIPE_TEST} in
380 rake)
310 ${RUBY} ${rubyflags} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed" 381 ${RUBY} -S rake ${RUBY_FAKEGEM_TASK_TEST} || die "tests failed"
382 ;;
383 rspec)
384 ruby-ng_rspec
385 ;;
386 cucumber)
387 ruby-ng_cucumber
388 ;;
389 none)
390 ewarn "each_fakegem_test called, but \${RUBY_FAKEGEM_RECIPE_TEST} is 'none'"
391 ;;
392 esac
311} 393}
312 394
313if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 395if [[ ${RUBY_FAKEGEM_RECIPE_TEST} != none ]]; then
314 # @FUNCTION: each_ruby_test 396 # @FUNCTION: each_ruby_test
315 # @DESCRIPTION: 397 # @DESCRIPTION:
316 # Run the tests for this package. 398 # Run the tests for this package.
317 each_ruby_test() { 399 each_ruby_test() {
318 each_fakegem_test 400 each_fakegem_test
319 } 401 }
320fi 402fi
321 403
322# @FUNCTION: each_fakegem_install 404# @FUNCTION: each_fakegem_install
323# @DESCRIPTION: 405# @DESCRIPTION:
324# Install the package for each ruby target. 406# Install the package for each ruby target.
325each_fakegem_install() { 407each_fakegem_install() {
326 ruby_fakegem_gemspec 408 ruby_fakegem_install_gemspec
327 409
328 local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}" 410 local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}"
329 for directory in bin lib; do 411 for directory in bin lib; do
330 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}" 412 [[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}"
331 done 413 done

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.34

  ViewVC Help
Powered by ViewVC 1.1.20