/[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.17 Revision 1.22
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2009 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.17 2010/02/19 11:59:38 flameeyes Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/ruby-fakegem.eclass,v 1.22 2010/07/29 09:38: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#
68 68
69RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}" 69RUBY_FAKEGEM_BINWRAP="${RUBY_FAKEGEM_BINWRAP-*}"
70 70
71if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then 71if [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]]; then
72 IUSE="$IUSE doc" 72 IUSE="$IUSE doc"
73 ruby_add_bdepend doc "dev-ruby/rake" 73 ruby_add_bdepend "doc? ( dev-ruby/rake )"
74fi
75
76if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]]; then
77 IUSE="$IUSE doc"
74fi 78fi
75 79
76if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then 80if [[ ${RUBY_FAKEGEM_TASK_TEST} != "" ]]; then
77 IUSE="$IUSE test" 81 IUSE="$IUSE test"
78 ruby_add_bdepend test "dev-ruby/rake" 82 ruby_add_bdepend "test? ( dev-ruby/rake )"
79fi 83fi
80 84
81SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem" 85SRC_URI="mirror://rubygems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${RUBY_FAKEGEM_SUFFIX:+-${RUBY_FAKEGEM_SUFFIX}}.gem"
82 86
83ruby_add_rdepend virtual/rubygems 87ruby_add_rdepend virtual/rubygems
146 # copies with different implementations; while for now we're using 150 # copies with different implementations; while for now we're using
147 # the same exact content, we might have differences in the future, 151 # the same exact content, we might have differences in the future,
148 # so better taking this into consideration. 152 # so better taking this into consideration.
149 local quoted_description=${DESCRIPTION//\"/\\\"} 153 local quoted_description=${DESCRIPTION//\"/\\\"}
150 cat - > "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} <<EOF 154 cat - > "${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation} <<EOF
151# generated by ruby-fakegem.eclass $Revision: 1.17 $ 155# generated by ruby-fakegem.eclass $Revision: 1.22 $
152Gem::Specification.new do |s| 156Gem::Specification.new do |s|
153 s.name = "${RUBY_FAKEGEM_NAME}" 157 s.name = "${RUBY_FAKEGEM_NAME}"
154 s.version = "${RUBY_FAKEGEM_VERSION}" 158 s.version = "${RUBY_FAKEGEM_VERSION}"
155 s.summary = "${quoted_description}" 159 s.summary = "${quoted_description}"
156 s.homepage = "${HOMEPAGE}" 160 s.homepage = "${HOMEPAGE}"
200 204
201 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF 205 cat - > "${T}"/gembin-wrapper-${gembinary} <<EOF
202#!${rubycmd} 206#!${rubycmd}
203# This is a simplified version of the RubyGems wrapper 207# This is a simplified version of the RubyGems wrapper
204# 208#
205# Generated by ruby-fakegem.eclass $Revision: 1.17 $ 209# Generated by ruby-fakegem.eclass $Revision: 1.22 $
206 210
207require 'rubygems' 211require 'rubygems'
208 212
209load Gem::default_path[-1] + "/gems/${relativegembinary}" 213load Gem::default_path[-1] + "/gems/${relativegembinary}"
210 214
230# Unpack the source archive, including support for unpacking gems. 234# Unpack the source archive, including support for unpacking gems.
231all_ruby_unpack() { 235all_ruby_unpack() {
232 # Special support for extracting .gem files; the file need to be 236 # Special support for extracting .gem files; the file need to be
233 # extracted twice and the mtime from the archive _has_ to be 237 # extracted twice and the mtime from the archive _has_ to be
234 # ignored (it's always set to epoch 0). 238 # ignored (it's always set to epoch 0).
235 # 239 for archive in ${A}; do
236 # This only works if there is exactly one archive and that archive 240 case "${archive}" in
237 # is a .gem file! 241 *.gem)
238 if [[ $(wc -w <<< ${A}) == 1 ]] && 242 # Make sure that we're not running unoack for more than
239 [[ ${A} == *.gem ]]; then 243 # one .gem file, since we won't support that at all.
244 [[ -d "${S}" ]] && die "Unable to unpack ${archive}, ${S} exists"
245
240 ebegin "Unpacking .gem file..." 246 ebegin "Unpacking .gem file..."
241 tar -mxf ${DISTDIR}/${A} || die 247 tar -mxf ${DISTDIR}/${archive} || die
242 eend $? 248 eend $?
243 249
244 mkdir "${S}" 250 mkdir "${S}"
245 pushd "${S}" &>/dev/null 251 pushd "${S}" &>/dev/null
246 252
247 ebegin "Unpacking data.tar.gz" 253 ebegin "Unpacking data.tar.gz"
248 tar -mxf "${my_WORKDIR}"/data.tar.gz || die 254 tar -mxf "${my_WORKDIR}"/data.tar.gz || die
249 eend $? 255 eend $?
250 popd &>/dev/null 256 popd &>/dev/null
251 else 257 ;;
252 [[ -n ${A} ]] && unpack ${A} 258 *.patch.bz2)
253 fi 259 # We apply the patches with RUBY_PATCHES directly from DISTDIR,
260 # as the WORKDIR variable changes value between the global-scope
261 # and the time all_ruby_unpack/_prepare are called. Since we can
262 # simply decompress them when applying, this is much easier to
263 # deal with for us.
264 einfo "Keeping ${archive} as-is"
265 ;;
266 *)
267 unpack ${archive}
268 ;;
269 esac
270 done
254} 271}
255 272
256# @FUNCTION: all_ruby_compile 273# @FUNCTION: all_ruby_compile
257# @DESCRIPTION: 274# @DESCRIPTION:
258# Compile the package. 275# Compile the package.
301 318
302# @FUNCTION: all_fakegem_install 319# @FUNCTION: all_fakegem_install
303# @DESCRIPTION: 320# @DESCRIPTION:
304# Install files common to all ruby targets. 321# Install files common to all ruby targets.
305all_fakegem_install() { 322all_fakegem_install() {
306 if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && [[ ${RUBY_FAKEGEM_TASK_DOC} != "" ]] && use doc; then 323 if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then
307 for dir in ${RUBY_FAKEGEM_DOCDIR}; do 324 for dir in ${RUBY_FAKEGEM_DOCDIR}; do
325 [[ -d ${dir} ]] || continue
326
308 pushd ${dir} &>/dev/null 327 pushd ${dir} &>/dev/null
309 dohtml -r * || die "failed to install documentation" 328 dohtml -r * || die "failed to install documentation"
310 popd &>/dev/null 329 popd &>/dev/null
311 done 330 done
312 fi 331 fi

Legend:
Removed from v.1.17  
changed lines
  Added in v.1.22

  ViewVC Help
Powered by ViewVC 1.1.20