X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=ruby.spec;h=1949b611128ce6738d84aab9a734ef03bfecbd82;hb=2c4fda496ce728e49dc141aa2a85e5d27d2ba237;hp=2e68700a605e393320112e45991af142dffbbb67;hpb=38c47f7a48f8555bb8dd97bf2c3085969390737b;p=packages%2Fruby.git diff --git a/ruby.spec b/ruby.spec index 2e68700..1949b61 100644 --- a/ruby.spec +++ b/ruby.spec @@ -2,35 +2,33 @@ # - include ext/ in docs # - replace ri with fastri # - patch ri to search multiple indexes (one per package), so RPMs can install ri docs -# - fix inconsistencies with versioned vs not-versioned dirs (see dirname hacks in configure) -# - fix requires/provides 'ruby(abi) = ' -# - fix tk build # # Conditional build: %bcond_without doc # skip (time-consuming) docs generating; intended for speed up test builds -%bcond_without tk # skip building package with Tk bindings +%bcond_with tk # build Tk bindings (tcl8.6 is not supported) %bcond_without batteries # Don't include rubygems, json, rake, minitest %bcond_without default_ruby # use this Ruby as default system Ruby %bcond_with bootstrap # build bootstrap version +%bcond_with tests # build without tests -%define rel 0.4 -%define ruby_version 2.0 -%define basever 2.0.0 -%define patchlevel 451 +%define rel 1 +%define ruby_version 2.1 +%define basever 2.1 +%define patchlevel 7 %define ruby_suffix %{!?with_default_ruby:%{ruby_version}} -%define doc_version 2_0_0 +%define doc_version 2_1_0 -%define bigdecimal_ver 1.2.0 -%define io_console_ver 0.4.2 +%define bigdecimal_ver 1.2.4 +%define io_console_ver 0.4.3 %define irb_ver 0.9.6 -%define json_ver 1.7.7 -%define minitest_ver 4.3.2 -%define psych_ver 2.0.0 -%define rake_ver 0.9.6 -%define rdoc_ver 4.0.0 -%define rubygems_ver 2.0.14 -%define test_unit_ver 2.0.0.0 +%define json_ver 1.8.1 +%define minitest_ver 4.7.5 +%define psych_ver 2.0.5 +%define rake_ver 10.1.0 +%define rdoc_ver 4.1.0 +%define rubygems_ver 2.2.3 +%define test_unit_ver 2.1.6.0 %define oname ruby Summary: Ruby - interpreted scripting language @@ -45,36 +43,32 @@ Epoch: 1 # Public Domain for example for: include/ruby/st.h, strftime.c, ... License: (Ruby or BSD) and Public Domain Group: Development/Languages -Source0: ftp://ftp.ruby-lang.org/pub/ruby/2.0/%{oname}-%{basever}-p%{patchlevel}.tar.bz2 -# Source0-md5: 908e4d1dbfe7362b15892f16af05adf8 +# https://www.ruby-lang.org/en/downloads/ +Source0: https://ftp.ruby-lang.org/pub/ruby/2.1/%{oname}-%{basever}.%{patchlevel}.tar.xz +# Source0-md5: 2e43a1d32cc16975a6b5d3ffce399199 Source1: http://www.ruby-doc.org/download/%{oname}-doc-bundle.tar.gz # Source1-md5: ad1af0043be98ba1a4f6d0185df63876 Source2: http://www.ruby-doc.org/downloads/%{oname}_%{doc_version}_stdlib_rdocs.tgz -# Source2-md5: e93307804295a43512cafbf660a4cbe0 +# Source2-md5: bf479c714ba189f9df633600b40aeef5 Source3: http://www.ruby-doc.org/downloads/%{oname}_%{doc_version}_core_rdocs.tgz -# Source3-md5: 900186f317b51edfbb2f5317f8855719 +# Source3-md5: 3515d672874a1e48d4a8fd32c50639e7 Source100: ftp://ftp.ruby-lang.org/pub/ruby/1.8/%{oname}-1.8.7-p330.tar.gz # Source100-md5: 50a49edb787211598d08e756e733e42e Source4: rdoc.1 Source5: testrb.1 +Source6: operating_system.rb Patch0: %{oname}-lib64.patch Patch1: %{oname}-ffs.patch Patch2: fix-bison-invocation.patch -# http://redmine.ruby-lang.org/issues/5231 -#Patch3: disable-versioned-paths.patch -# TODO: Should be submitted upstream? -#Patch4: arch-specific-dir.patch -# http://redmine.ruby-lang.org/issues/5281 -#Patch5: site-and-vendor-arch-flags.patch -# Make mkmf verbose by default -Patch6: mkmf-verbose.patch -Patch7: strip-ccache.patch -Patch8: duplicated-paths.patch -Patch9: DESTDIR.patch -Patch10: empty-ruby-version.patch -Patch11: rubygems-2.0.0-binary-extensions.patch -Patch12: custom-rubygems-location.patch -Patch13: readline-6.3.patch +Patch3: mkmf-verbose.patch +Patch4: strip-ccache.patch +Patch5: duplicated-paths.patch +Patch7: empty-ruby-version.patch +Patch8: rubygems-2.0.0-binary-extensions.patch +Patch9: custom-rubygems-location.patch +Patch10: %{oname}-posixsh.patch +Patch11: x32-asm.patch +Patch12: archlibdir.patch URL: http://www.ruby-lang.org/ BuildRequires: autoconf >= 2.60 BuildRequires: automake @@ -87,12 +81,16 @@ BuildRequires: openssl-devel BuildRequires: pkgconfig BuildRequires: readline-devel >= 4.2 BuildRequires: rpm-build >= 5.4.10-49 -# boostrap needs ruby binary, erb module -%{!?with_bootstrap:BuildRequires: rpm-rubyprov} -%{!?with_bootstrap:BuildRequires: ruby-modules} -%{!?with_bootstrap:BuildRequires: ruby} BuildRequires: sed >= 4.0 +BuildRequires: tar >= 1:1.22 +BuildRequires: xz BuildRequires: yaml-devel +%if %{without bootstrap} +# bootstrap needs ruby binary, erb module +BuildRequires: rpm-rubyprov +BuildRequires: ruby +BuildRequires: ruby-modules +%endif %if %{with tk} BuildRequires: tk-devel %endif @@ -101,14 +99,14 @@ Provides: ruby(ver) = %{ruby_version} Obsoletes: ruby-REXML <= 2.4.0-2 Obsoletes: ruby-doc < 1.8.4 Obsoletes: ruby-fastthread <= 0.6.3 +Conflicts: rpm-build-macros < 1.695 Conflicts: ruby-activesupport < 2.3.11-2 Conflicts: ruby-activesupport2 < 2.3.11-2 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) -%define ruby_ridir %{_datadir}/ri/%{ruby_version}/system -#%define gem_dir %{_datadir}/gems -#%define gem_dir %{_datadir}/%{oname}/gems/%{ruby_version} -%define gem_dir %{_datadir}/%{oname}/%{ruby_version}/gems +%define ruby_ridir %{_datadir}/ri/system +%define gem_dir %{_datadir}/gems +%define gem_libdir %{_libdir}/gems/%{oname} # location where rubygems is installed %define rubygems_dir %{ruby_libdir} @@ -119,31 +117,14 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) # This is the local lib/arch and should not be used for packaging. %define sitedir site_ruby -%define ruby_sitedir %{_prefix}/local/share/%{oname}/%{sitedir} %define ruby_sitearchdir %{_prefix}/local/%{_lib}/%{oname}/%{sitedir}/%{ruby_version} -%define ruby_sitelibdir %{_prefix}/local/share/%{oname}/%{sitedir}/%{ruby_version} +%define ruby_sitelibdir %{_prefix}/local/share/%{oname}/%{sitedir} # This is the general location for libs/archs compatible with all # or most of the Ruby versions available in the PLD repositories. %define vendordir vendor_ruby -%define ruby_vendordir %{_datadir}/%{oname}/%{vendordir} %define ruby_vendorarchdir %{_libdir}/%{oname}/%{vendordir}/%{ruby_version} -%define ruby_vendorlibdir %{_datadir}/%{oname}/%{vendordir}/%{ruby_version} - -# TODO: drop legacy loadpaths after all ruby modules rebuilt in Th -%define legacy_libdir %{_libdir}/%{oname}/%{ruby_version} -%define legacy_archdir %{_libdir}/%{oname}/%{ruby_version}/%{_target_cpu}-linux -%define legacy_sitedir %{_libdir}/%{oname}/%{sitedir} -%define legacy_sitelibdir %{_libdir}/%{oname}/%{sitedir}/%{ruby_version} -%define legacy_sitearchdir %{_libdir}/%{oname}/%{sitedir}/%{ruby_version}/%{_target_cpu}-linux -%define legacy_vendordir %{_libdir}/%{oname}/%{vendordir} -%define legacy_vendorlibdir %{_libdir}/%{oname}/%{vendordir}/%{ruby_version} -%define legacy_vendorarchdir %{_libdir}/%{oname}/%{vendordir}/%{ruby_version}/%{_target_cpu}-linux - -%define legacy_siteloadpath %{legacy_sitelibdir}\\0%{legacy_sitearchdir}\\0%{legacy_sitedir} -%define legacy_vendorloadpath %{legacy_vendorarchdir} -%define legacy_loadpath %{legacy_archdir} -%define legacy_loadpaths %{legacy_siteloadpath}\\0%{legacy_vendorloadpath}\\0%{legacy_loadpath} +%define ruby_vendorlibdir %{_datadir}/%{oname}/%{vendordir} # bleh, some nasty (gcc or ruby) bug still not fixed # (SEGV or "unexpected break" on miniruby run during build) @@ -198,6 +179,7 @@ Obsoletes: ruby-minitest <= 1.5.0 %endif # FIXME later Provides: ruby(abi) = %{ruby_version} +%requires_ge_to openssl openssl-devel %description modules Ruby standard modules and utilities: @@ -321,6 +303,8 @@ Release: %{basever}.%{patchlevel}.%{rel} Epoch: 0 License: GPL v2 and Ruby and MIT Group: Development/Libraries +Requires: %{name}-irb >= %{irb_ver} +Requires: %{name}-json >= %{json_ver} Requires: %{name}-modules = 1:%{basever}.%{patchlevel}-%{rel} Obsoletes: rdoc <= 0.9.0 %if "%{_rpmversion}" >= "5" @@ -421,35 +405,36 @@ This is a JSON implementation as a Ruby extension in C. Biblioteka JSON dla języka Ruby. %prep -%if %{with bootstrap} -%setup -q -n %{oname}-%{basever}-p%{patchlevel} -a1 -a2 -a3 -a100 -%else -%setup -q -n %{oname}-%{basever}-p%{patchlevel} -a1 -a2 -a3 -%endif +%setup -q -n %{oname}-%{basever}.%{patchlevel} -a1 -a2 -a3 %{?with_bootstrap:-a100} %patch0 -p1 %patch1 -p1 %patch2 -p1 -#%patch3 -p1 -#%patch4 -p1 -#%patch5 -p1 -%patch6 -p1 -%patch7 -p1 -%patch8 -p1 +%patch3 -p1 +%patch4 -p1 +%patch5 -p1 +#%patch7 -p1 +#%patch8 -p1 %patch9 -p1 -%patch10 -p1 -%patch11 -p1 +#%patch10 -p1 +#%patch11 -p1 %patch12 -p1 -%patch13 -p1 # must be regenerated with new bison %{__rm} parse.{c,h} +# Install custom operating_system.rb. +install -d lib/rubygems/defaults +cp -p %{SOURCE6} lib/rubygems/defaults + find '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f find -type f '(' -name '*.rb' -o -name '*.cgi' -o -name '*.test' \ -o -name 'ruby.1' -o -name '*.html' -o -name '*.tcl' ')' \ | xargs %{__sed} -i 's,/usr/local/bin/,%{_bindir}/,' +# no configure option to disable, so just rm +%{!?with_tk:rm -rf ext/tk} + %build rubygems_ver=$(awk '/VERSION =/ && $1 == "VERSION" {print $3}' lib/rubygems.rb | xargs) if [ $rubygems_ver != %{rubygems_ver} ]; then @@ -476,6 +461,7 @@ cd .. %configure \ %{?with_bootstrap:--with-baseruby=%{oname}-1.8.7-p330/miniruby} \ --program-suffix=%{ruby_suffix} \ + --with-archlibdir=%{_libdir} \ --with-rubygemsdir=%{rubygems_dir} \ --with-rubylibprefix=%{ruby_libdir} \ --with-rubyarchprefix=%{ruby_archdir} \ @@ -492,7 +478,7 @@ cd .. --enable-multiarch \ --disable-rubygems \ --disable-install-doc \ - --with-ruby-version='' + --with-ruby-version='' \ %{__make} -j1 main \ COPY="cp -p" Q= \ @@ -502,16 +488,73 @@ cd .. %{__make} -j1 rdoc %endif +%if %{with tests} +# unset these, as testsuite does "git commit" somewhere, which points to pld .spec repo. doh +unset GIT_DIR GIT_WORK_TREE + +unset GIT +DISABLE_TESTS="" + +%ifarch armv7l armv7hl armv7hnl +# test_call_double(DL::TestDL) fails on ARM HardFP +# http://bugs.ruby-lang.org/issues/6592 +DISABLE_TESTS="-x test_dl2.rb $DISABLE_TESTS" +%endif + +# test_debug(TestRubyOptions) fails due to LoadError reported in debug mode, +# when abrt.rb cannot be required (seems to be easier way then customizing +# the test suite). +touch abrt.rb + +# TestSignal#test_hup_me hangs up the test suite. +# http://bugs.ruby-lang.org/issues/8997 +sed -i '/def test_hup_me/,/end if Process.respond_to/ s/^/#/' test/ruby/test_signal.rb + +# Fix "Could not find 'minitest'" error. +# http://bugs.ruby-lang.org/issues/9259 +sed -i "/^ gem 'minitest', '~> 4.0'/ s/^/#/" lib/rubygems/test_case.rb + +# Segmentation fault. +# https://bugs.ruby-lang.org/issues/9198 +sed -i '/^ def test_machine_stackoverflow/,/^ end/ s/^/#/' test/ruby/test_exception.rb + +# Don't test wrap ciphers to prevent "OpenSSL::Cipher::CipherError: wrap mode +# not allowed" error. +# https://bugs.ruby-lang.org/issues/10229 +sed -i '/assert(OpenSSL::Cipher::Cipher.new(name).is_a?(OpenSSL::Cipher::Cipher))/i \ + next if /wrap/ =~ name' test/openssl/test_cipher.rb + +# Test is broken due to SSLv3 disabled in Fedora. +# https://bugs.ruby-lang.org/issues/10046 +sed -i '/def test_ctx_server_session_cb$/,/^ end$/ s/^/#/' test/openssl/test_ssl_session.rb + +%{__make} check TESTS="-v $DISABLE_TESTS" +%endif + %install rm -rf $RPM_BUILD_ROOT install -d $RPM_BUILD_ROOT{%{ruby_rdocdir},%{ruby_ridir}} \ $RPM_BUILD_ROOT%{ruby_vendorarchdir} \ $RPM_BUILD_ROOT%{ruby_vendorlibdir}/net \ - $RPM_BUILD_ROOT%{ruby_vendordir}/data \ + $RPM_BUILD_ROOT%{ruby_vendorlibdir}/data \ -%{__make} install %{?with_doc:install-doc} \ +%{__make} install %{?with_doc:install-doc -j1} \ DESTDIR=$RPM_BUILD_ROOT +# Version is empty if --with-ruby-version is specified. +# http://bugs.ruby-lang.org/issues/7807 +sed -i -e 's/Version: \${ruby_version}/Version: %{ruby_version}/' $RPM_BUILD_ROOT%{_pkgconfigdir}/%{oname}-%{ruby_version}.pc + +# Kill bundled certificates, as they should be part of ca-certificates. +for cert in \ + Class3PublicPrimaryCertificationAuthority.pem \ + DigiCertHighAssuranceEVRootCA.pem \ + EntrustnetSecureServerCertificationAuthority.pem \ + GeoTrustGlobalCA.pem \ +; do + %{__rm} $RPM_BUILD_ROOT%{rubygems_dir}/rubygems/ssl_certs/$cert +done + install -d $RPM_BUILD_ROOT%{_examplesdir}/%{oname}-%{basever}.%{patchlevel} cp -Rf sample/* $RPM_BUILD_ROOT%{_examplesdir}/%{oname}-%{basever}.%{patchlevel} cp -p %{SOURCE4} $RPM_BUILD_ROOT%{_mandir}/man1/rdoc%{ruby_suffix}.1 @@ -519,6 +562,101 @@ cp -p %{SOURCE5} $RPM_BUILD_ROOT%{_mandir}/man1/testrb%{ruby_suffix}.1 %{__rm} -rf $RPM_BUILD_ROOT%{_docdir}/%{name}/html +# detect this runtime, "make install" is affected by operating_system.rb what is installed in system! +gem_dir=$(./miniruby -Ilib -I. -I.ext/common ./tool/runruby.rb -- --disable-gems -r$(basename *-linux*-fake.rb .rb) -r rubygems -e 'puts Gem.default_dir') + +# Move gems root into common directory, out of Ruby directory structure. +install -d $RPM_BUILD_ROOT%{gem_dir} +mv $RPM_BUILD_ROOT${gem_dir}/{gems,specifications} $RPM_BUILD_ROOT%{gem_dir} + +# Move bundled rubygems to %gem_dir +# make symlinks for io-console and bigdecimal, which are considered to be part of stdlib by other Gems +# make symlinks for all packages, so they would work without rubygems +# NOTE: when making symlinks, do not symlink paths that could be directories, +# as there may came files from other packages as well. actually, unlikely as +# the links to got system dir and only ruby may package there (other distro +# packages should go to vendor dirs) +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/rake-%{rake_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/rake* $RPM_BUILD_ROOT%{gem_dir}/gems/rake-%{rake_ver}/lib +ln -s %{gem_dir}/gems/rake-%{rake_ver}/lib/rake $RPM_BUILD_ROOT%{ruby_libdir} +ln -s %{gem_dir}/gems/rake-%{rake_ver}/lib/rake.rb $RPM_BUILD_ROOT%{ruby_libdir} +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/rake-%{rake_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/rdoc-%{rdoc_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/rdoc* $RPM_BUILD_ROOT%{gem_dir}/gems/rdoc-%{rdoc_ver}/lib +ln -s %{gem_dir}/gems/rdoc-%{rdoc_ver}/lib/rdoc $RPM_BUILD_ROOT%{ruby_libdir} +ln -s %{gem_dir}/gems/rdoc-%{rdoc_ver}/lib/rdoc.rb $RPM_BUILD_ROOT%{ruby_libdir} +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/rdoc-%{rdoc_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/bigdecimal-%{bigdecimal_ver}/lib +install -d $RPM_BUILD_ROOT%{gem_libdir}/bigdecimal-%{bigdecimal_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/bigdecimal $RPM_BUILD_ROOT%{gem_dir}/gems/bigdecimal-%{bigdecimal_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libarchdir}/bigdecimal.so $RPM_BUILD_ROOT%{gem_libdir}/bigdecimal-%{bigdecimal_ver}/lib +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/bigdecimal-%{bigdecimal_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications +ln -s %{gem_dir}/gems/bigdecimal-%{bigdecimal_ver}/lib/bigdecimal $RPM_BUILD_ROOT%{ruby_libdir}/bigdecimal +ln -s %{gem_libdir}/bigdecimal-%{bigdecimal_ver}/lib/bigdecimal.so $RPM_BUILD_ROOT%{ruby_libarchdir}/bigdecimal.so + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/io-console-%{io_console_ver}/lib +install -d $RPM_BUILD_ROOT%{gem_libdir}/io-console-%{io_console_ver}/lib/io +mv $RPM_BUILD_ROOT%{ruby_libdir}/io $RPM_BUILD_ROOT%{gem_dir}/gems/io-console-%{io_console_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libarchdir}/io/console.so $RPM_BUILD_ROOT%{gem_libdir}/io-console-%{io_console_ver}/lib/io +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/io-console-%{io_console_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications +ln -s %{gem_dir}/gems/io-console-%{io_console_ver}/lib/io $RPM_BUILD_ROOT%{ruby_libdir}/io +ln -s %{gem_libdir}/io-console-%{io_console_ver}/lib/io/console.so $RPM_BUILD_ROOT%{ruby_libarchdir}/io/console.so + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/json-%{json_ver}/lib +install -d $RPM_BUILD_ROOT%{gem_libdir}/json-%{json_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/json* $RPM_BUILD_ROOT%{gem_dir}/gems/json-%{json_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libarchdir}/json $RPM_BUILD_ROOT%{gem_libdir}/json-%{json_ver}/lib +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/json-%{json_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications +ln -s %{gem_dir}/gems/json-%{json_ver}/lib/json $RPM_BUILD_ROOT%{ruby_libdir}/json +ln -s %{gem_dir}/gems/json-%{json_ver}/lib/json.rb $RPM_BUILD_ROOT%{ruby_libdir}/json.rb +install -d $RPM_BUILD_ROOT%{ruby_libarchdir}/json/ext +ln -s %{gem_libdir}/json-%{json_ver}/lib/json/ext/parser.so $RPM_BUILD_ROOT%{ruby_libarchdir}/json/ext +ln -s %{gem_libdir}/json-%{json_ver}/lib/json/ext/generator.so $RPM_BUILD_ROOT%{ruby_libarchdir}/json/ext + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/minitest-%{minitest_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/minitest $RPM_BUILD_ROOT%{gem_dir}/gems/minitest-%{minitest_ver}/lib +ln -s %{gem_dir}/gems/minitest-%{minitest_ver}/lib/minitest $RPM_BUILD_ROOT%{ruby_libdir} +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/minitest-%{minitest_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/test-unit-%{test_unit_ver}/lib +install -d $RPM_BUILD_ROOT%{ruby_libdir}/test +mv $RPM_BUILD_ROOT%{ruby_libdir}/test/unit $RPM_BUILD_ROOT%{gem_dir}/gems/test-unit-%{test_unit_ver}/lib +ln -s %{gem_dir}/gems/test-unit-%{test_unit_ver}/lib/unit $RPM_BUILD_ROOT%{ruby_libdir}/test +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/test-unit-%{test_unit_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications + +install -d $RPM_BUILD_ROOT%{gem_dir}/gems/psych-%{psych_ver}/lib +install -d $RPM_BUILD_ROOT%{gem_libdir}/psych-%{psych_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libdir}/psych* $RPM_BUILD_ROOT%{gem_dir}/gems/psych-%{psych_ver}/lib +mv $RPM_BUILD_ROOT%{ruby_libarchdir}/psych.so $RPM_BUILD_ROOT%{gem_libdir}/psych-%{psych_ver}/lib/ +mv $RPM_BUILD_ROOT%{gem_dir}/specifications/default/psych-%{psych_ver}.gemspec $RPM_BUILD_ROOT%{gem_dir}/specifications +ln -s %{gem_dir}/gems/psych-%{psych_ver}/lib/psych $RPM_BUILD_ROOT%{ruby_libdir}/psych +ln -s %{gem_dir}/gems/psych-%{psych_ver}/lib/psych.rb $RPM_BUILD_ROOT%{ruby_libdir}/psych.rb +ln -s %{gem_libdir}/psych-%{psych_ver}/lib/psych.so $RPM_BUILD_ROOT%{ruby_archdir}/psych.so + +# Adjust the gemspec files so that the gems will load properly +sed -i '/^end$/ i\ + s.require_paths = ["lib"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/rake-%{rake_ver}.gemspec + +sed -i '/^end$/ i\ + s.require_paths = ["lib"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/rdoc-%{rdoc_ver}.gemspec + +sed -i '/^end$/ i\ + s.require_paths = ["lib"]\ + s.extensions = ["bigdecimal.so"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/bigdecimal-%{bigdecimal_ver}.gemspec + +sed -i '/^end$/ i\ + s.require_paths = ["lib"]\ + s.extensions = ["io/console.so"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/io-console-%{io_console_ver}.gemspec + +sed -i '/^end$/ i\ + s.require_paths = ["lib"]\ + s.extensions = ["json/ext/parser.so", "json/ext/generator.so"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/json-%{json_ver}.gemspec + +sed -i '/^end$/ i\ + s.require_paths = ["lib"]' $RPM_BUILD_ROOT%{gem_dir}/specifications/minitest-%{minitest_ver}.gemspec + ln -sf %{gem_dir}/gems/rake-%{rake_ver}/bin/rake $RPM_BUILD_ROOT%{_bindir}/rake%{ruby_suffix} %if %{without batteries} @@ -535,8 +673,8 @@ ln -sf %{gem_dir}/gems/rake-%{rake_ver}/bin/rake $RPM_BUILD_ROOT%{_bindir}/rake% %if %{with doc} # too much .ri -#%{__rm} $RPM_BUILD_ROOT%{ruby_ridir}/cache.ri -#%{__rm} $RPM_BUILD_ROOT%{ruby_ridir}/created.rid +%{__rm} $RPM_BUILD_ROOT%{ruby_ridir}/cache.ri +%{__rm} $RPM_BUILD_ROOT%{ruby_ridir}/created.rid %endif %clean @@ -559,36 +697,22 @@ rm -rf $RPM_BUILD_ROOT %dir %{ruby_libdir} %dir %{ruby_archdir} -%dir %{ruby_vendordir} -#%dir %{ruby_vendordir}/data %dir %{ruby_vendorlibdir} %dir %{ruby_vendorarchdir} -%dir %{_datadir}/ri -%dir %{_datadir}/ri/%{ruby_version} +%dir %{dirname:%{ruby_ridir}} %dir %{ruby_ridir} - -#%dir %{ruby_rdocdir} +%dir %{ruby_rdocdir} # common dirs for ruby vendor modules -#%dir %{ruby_vendorlibdir}/net - -%if 0 -# legacy dirs. when everything rebuilt in Th not using these dirs. drop them -%dir %{legacy_archdir} -%dir %{legacy_sitedir} -%dir %{legacy_sitelibdir} -%dir %{legacy_sitearchdir} -%dir %{legacy_vendorarchdir} -%dir %{legacy_libdir}/tasks -%dir %{legacy_archdir}/racc -%endif +%dir %{ruby_vendorlibdir}/data +%dir %{ruby_vendorlibdir}/net %files devel %defattr(644,root,root,755) %attr(755,root,root) %{_libdir}/libruby.so %{_includedir}/%{oname}-%{ruby_version} -%{_pkgconfigdir}/ruby-%{ruby_version}.pc +%{_pkgconfigdir}/%{oname}-%{ruby_version}.pc %{ruby_libdir}/mkmf.rb %files static @@ -619,16 +743,16 @@ rm -rf $RPM_BUILD_ROOT %{_mandir}/man1/rdoc%{ruby_suffix}.1* %{ruby_libdir}/rdoc %dir %{gem_dir}/gems/rdoc-%{rdoc_ver} +%{gem_dir}/gems/rdoc-%{rdoc_ver}/lib %dir %{gem_dir}/gems/rdoc-%{rdoc_ver}/bin %attr(755,root,root) %{gem_dir}/gems/rdoc-%{rdoc_ver}/bin/rdoc -%{gem_dir}/specifications/default/rdoc-%{rdoc_ver}.gemspec +%{gem_dir}/specifications/rdoc-%{rdoc_ver}.gemspec %attr(755,root,root) %{gem_dir}/gems/rdoc-%{rdoc_ver}/bin/ri %if %{with batteries} %files rubygems %defattr(644,root,root,755) %attr(755,root,root) %{_bindir}/gem%{ruby_suffix} -%dir %{rubygems_dir} %{rubygems_dir}/rubygems %{rubygems_dir}/rubygems.rb %{rubygems_dir}/ubygems.rb @@ -639,10 +763,12 @@ rm -rf $RPM_BUILD_ROOT %attr(755,root,root) %{_bindir}/rake%{ruby_suffix} %{_mandir}/man1/rake%{ruby_suffix}.1* %{ruby_libdir}/rake +%{ruby_libdir}/rake.rb %dir %{gem_dir}/gems/rake-%{rake_ver} +%{gem_dir}/gems/rake-%{rake_ver}/lib %dir %{gem_dir}/gems/rake-%{rake_ver}/bin %attr(755,root,root) %{gem_dir}/gems/rake-%{rake_ver}/bin/rake -%{gem_dir}/specifications/default/rake-%{rake_ver}.gemspec +%{gem_dir}/specifications/rake-%{rake_ver}.gemspec %files json %defattr(644,root,root,755) @@ -650,14 +776,21 @@ rm -rf $RPM_BUILD_ROOT %dir %{ruby_archdir}/json %dir %{ruby_archdir}/json/ext %attr(755,root,root) %{ruby_archdir}/json/ext/*.so -%{gem_dir}/specifications/default/json-%{json_ver}.gemspec + +%dir %{gem_libdir}/json-%{json_ver} +%dir %{gem_libdir}/json-%{json_ver}/lib +%dir %{gem_libdir}/json-%{json_ver}/lib/json +%dir %{gem_libdir}/json-%{json_ver}/lib/json/ext +%attr(755,root,root) %{gem_libdir}/json-%{json_ver}/lib/json/ext/generator.so +%attr(755,root,root) %{gem_libdir}/json-%{json_ver}/lib/json/ext/parser.so + +%{gem_dir}/gems/json-%{json_ver} +%{gem_dir}/specifications/json-%{json_ver}.gemspec %endif %files modules %defattr(644,root,root,755) %attr(755,root,root) %{_bindir}/erb%{ruby_suffix} -%attr(755,root,root) %{_bindir}/testrb%{ruby_suffix} -%{ruby_libdir}/bigdecimal %{ruby_libdir}/cgi %{ruby_libdir}/date %{ruby_libdir}/digest @@ -669,7 +802,6 @@ rm -rf $RPM_BUILD_ROOT %{ruby_libdir}/net %{ruby_libdir}/openssl %{ruby_libdir}/optparse -%{ruby_libdir}/psych %{ruby_libdir}/racc %{ruby_libdir}/rbconfig %{ruby_libdir}/rexml @@ -684,16 +816,80 @@ rm -rf $RPM_BUILD_ROOT %{ruby_libdir}/webrick %{ruby_libdir}/xmlrpc %{ruby_libdir}/yaml -%{ruby_libdir}/[A-Za-s]*.rb + +%{ruby_libdir}/English.rb +%{ruby_libdir}/abbrev.rb +%{ruby_libdir}/base64.rb +%{ruby_libdir}/benchmark.rb +%{ruby_libdir}/cgi.rb +%{ruby_libdir}/cmath.rb +%{ruby_libdir}/complex.rb +%{ruby_libdir}/csv.rb +%{ruby_libdir}/date.rb +%{ruby_libdir}/debug.rb +%{ruby_libdir}/delegate.rb +%{ruby_libdir}/digest.rb +%{ruby_libdir}/dl.rb +%{ruby_libdir}/drb.rb +%{ruby_libdir}/e2mmap.rb +%{ruby_libdir}/erb.rb +%{ruby_libdir}/expect.rb +%{ruby_libdir}/fiddle.rb +%{ruby_libdir}/fileutils.rb +%{ruby_libdir}/find.rb +%{ruby_libdir}/forwardable.rb +%{ruby_libdir}/getoptlong.rb +%{ruby_libdir}/gserver.rb +%{ruby_libdir}/ipaddr.rb +%{ruby_libdir}/json.rb +%{ruby_libdir}/kconv.rb +%{ruby_libdir}/logger.rb +%{ruby_libdir}/mathn.rb +%{ruby_libdir}/matrix.rb +%{ruby_libdir}/monitor.rb +%{ruby_libdir}/mutex_m.rb +%{ruby_libdir}/observer.rb +%{ruby_libdir}/open-uri.rb +%{ruby_libdir}/open3.rb +%{ruby_libdir}/openssl.rb +%{ruby_libdir}/optparse.rb +%{ruby_libdir}/ostruct.rb +%{ruby_libdir}/pathname.rb +%{ruby_libdir}/pp.rb +%{ruby_libdir}/prettyprint.rb +%{ruby_libdir}/prime.rb +%{ruby_libdir}/profile.rb +%{ruby_libdir}/profiler.rb +%{ruby_libdir}/pstore.rb +%{ruby_libdir}/psych.rb +%{ruby_libdir}/rational.rb +%{ruby_libdir}/rdoc.rb +%{ruby_libdir}/resolv-replace.rb +%{ruby_libdir}/resolv.rb +%{ruby_libdir}/ripper.rb +%{ruby_libdir}/rss.rb +%{ruby_libdir}/scanf.rb +%{ruby_libdir}/securerandom.rb +%{ruby_libdir}/set.rb +%{ruby_libdir}/shell.rb +%{ruby_libdir}/shellwords.rb +%{ruby_libdir}/singleton.rb +%{ruby_libdir}/socket.rb +%{ruby_libdir}/sync.rb %{ruby_libdir}/tempfile.rb -%{ruby_libdir}/thread.rb %{ruby_libdir}/thwait.rb %{ruby_libdir}/time.rb %{ruby_libdir}/timeout.rb %{ruby_libdir}/tmpdir.rb %{ruby_libdir}/tracer.rb %{ruby_libdir}/tsort.rb -%{ruby_libdir}/[u-z]*.rb +%{ruby_libdir}/un.rb +%{ruby_libdir}/uri.rb +%{ruby_libdir}/weakref.rb +%{ruby_libdir}/webrick.rb +%{ruby_libdir}/xmlrpc.rb +%{ruby_libdir}/yaml.rb + %if %{with batteries} %exclude %{ruby_libdir}/rubygems.rb %exclude %{ruby_libdir}/ubygems.rb @@ -702,8 +898,38 @@ rm -rf $RPM_BUILD_ROOT %endif %exclude %{ruby_libdir}/irb.rb %exclude %{ruby_libdir}/mkmf.rb -%attr(755,root,root) %{ruby_archdir}/[a-s]*.so -%attr(755,root,root) %{ruby_archdir}/[u-z]*.so +%exclude %{ruby_libdir}/rake.rb + +%{ruby_archdir}/rbconfig.rb +%attr(755,root,root) %{ruby_archdir}/bigdecimal.so +%attr(755,root,root) %{ruby_archdir}/continuation.so +%attr(755,root,root) %{ruby_archdir}/coverage.so +#%attr(755,root,root) %{ruby_archdir}/curses.so +%attr(755,root,root) %{ruby_archdir}/date_core.so +%attr(755,root,root) %{ruby_archdir}/dbm.so +%attr(755,root,root) %{ruby_archdir}/digest.so +%attr(755,root,root) %{ruby_archdir}/dl.so +%attr(755,root,root) %{ruby_archdir}/etc.so +%attr(755,root,root) %{ruby_archdir}/fcntl.so +%attr(755,root,root) %{ruby_archdir}/fiber.so +%attr(755,root,root) %{ruby_archdir}/fiddle.so +%attr(755,root,root) %{ruby_archdir}/gdbm.so +%attr(755,root,root) %{ruby_archdir}/nkf.so +%attr(755,root,root) %{ruby_archdir}/objspace.so +%attr(755,root,root) %{ruby_archdir}/openssl.so +%attr(755,root,root) %{ruby_archdir}/pathname.so +%attr(755,root,root) %{ruby_archdir}/psych.so +%attr(755,root,root) %{ruby_archdir}/pty.so +%attr(755,root,root) %{ruby_archdir}/readline.so +%attr(755,root,root) %{ruby_archdir}/ripper.so +%attr(755,root,root) %{ruby_archdir}/thread.so +%attr(755,root,root) %{ruby_archdir}/sdbm.so +%attr(755,root,root) %{ruby_archdir}/socket.so +%attr(755,root,root) %{ruby_archdir}/stringio.so +%attr(755,root,root) %{ruby_archdir}/strscan.so +%attr(755,root,root) %{ruby_archdir}/syslog.so +%attr(755,root,root) %{ruby_archdir}/zlib.so + %dir %{ruby_archdir}/digest %attr(755,root,root) %{ruby_archdir}/digest/*.so %dir %{ruby_archdir}/dl @@ -718,38 +944,57 @@ rm -rf $RPM_BUILD_ROOT %attr(755,root,root) %{ruby_archdir}/mathn/*.so %dir %{ruby_archdir}/racc %attr(755,root,root) %{ruby_archdir}/racc/*.so -%{ruby_archdir}/rbconfig.rb +%dir %{ruby_archdir}/rbconfig +%attr(755,root,root) %{ruby_archdir}/rbconfig/sizeof.so + +# bigdecimal +%{gem_dir}/specifications/bigdecimal-%{bigdecimal_ver}.gemspec +%{gem_dir}/gems/bigdecimal-%{bigdecimal_ver} +%dir %{gem_libdir}/bigdecimal-%{bigdecimal_ver} +%dir %{gem_libdir}/bigdecimal-%{bigdecimal_ver}/lib +%attr(755,root,root) %{gem_libdir}/bigdecimal-%{bigdecimal_ver}/lib/bigdecimal.so +%{ruby_libdir}/bigdecimal -%{gem_dir}/specifications/default/bigdecimal-%{bigdecimal_ver}.gemspec -%{gem_dir}/specifications/default/io-console-%{io_console_ver}.gemspec +%dir %{_libdir}/gems +%dir %{_libdir}/gems/%{oname} + +# io-console +%{gem_dir}/specifications/io-console-%{io_console_ver}.gemspec +%{gem_dir}/gems/io-console-%{io_console_ver} +%dir %{gem_libdir}/io-console-%{io_console_ver} +%dir %{gem_libdir}/io-console-%{io_console_ver}/lib +%dir %{gem_libdir}/io-console-%{io_console_ver}/lib/io +%attr(755,root,root) %{gem_libdir}/io-console-%{io_console_ver}/lib/io/console.so %if %{with batteries} # minitest %{ruby_libdir}/minitest -%{gem_dir}/specifications/default/minitest-%{minitest_ver}.gemspec +%{gem_dir}/gems/minitest-%{minitest_ver} +%{gem_dir}/specifications/minitest-%{minitest_ver}.gemspec %endif -%{gem_dir}/specifications/default/psych-%{psych_ver}.gemspec +%{gem_dir}/specifications/psych-%{psych_ver}.gemspec +%{gem_dir}/gems/psych-%{psych_ver} +%{ruby_libdir}/psych +%dir %{gem_libdir}/psych-%{psych_ver} +%dir %{gem_libdir}/psych-%{psych_ver}/lib +%attr(755,root,root) %{gem_libdir}/psych-%{psych_ver}/lib/psych.so # test-unit -%{gem_dir}/specifications/default/test-unit-%{test_unit_ver}.gemspec +%{gem_dir}/specifications/test-unit-%{test_unit_ver}.gemspec %dir %{gem_dir}/gems/test-unit-%{test_unit_ver} +%{gem_dir}/gems/test-unit-%{test_unit_ver}/lib %dir %{gem_dir}/gems/test-unit-%{test_unit_ver}/bin %attr(755,root,root) %{gem_dir}/gems/test-unit-%{test_unit_ver}/bin/testrb - -# parents of gem_dir -#%dir %{_datadir}/%{oname}/gems -#%dir %{_datadir}/%{oname}/gems/%{ruby_version} -#%dir %{_datadir}/%{oname}/gems/%{ruby_version}/gems - -%dir %{_datadir}/%{oname}/%{ruby_version}/gems/gems +%attr(755,root,root) %{_bindir}/testrb%{ruby_suffix} +%{_mandir}/man1/testrb%{ruby_suffix}.1* %dir %{gem_dir} +%dir %{gem_dir}/gems %dir %{gem_dir}/specifications %dir %{gem_dir}/specifications/default %{_mandir}/man1/erb%{ruby_suffix}.1* %{_mandir}/man1/ri%{ruby_suffix}.1* -%{_mandir}/man1/testrb%{ruby_suffix}.1* %files doc %defattr(644,root,root,755)