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