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

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

  ViewVC Help
Powered by ViewVC 1.1.20