[rubygem-cairo] F-17: rebuild against ruby 1.9

Mamoru Tasaka mtasaka at fedoraproject.org
Sat Jan 28 17:57:30 UTC 2012


commit 4937b90815cfd86dce941230ba7b62292c27d652
Author: Mamoru Tasaka <tasaka1 at localhost.localdomain>
Date:   Sun Jan 29 02:57:25 2012 +0900

    F-17: rebuild against ruby 1.9

 rubygem-cairo.spec |  144 ++++++++++++++++++++++++++++++++-------------------
 1 files changed, 90 insertions(+), 54 deletions(-)
---
diff --git a/rubygem-cairo.spec b/rubygem-cairo.spec
index 6644380..7958b3c 100644
--- a/rubygem-cairo.spec
+++ b/rubygem-cairo.spec
@@ -1,25 +1,31 @@
+%if 0%{?fedora} <= 16
 %global	ruby_sitelib		%(ruby -rrbconfig -e "puts Config::CONFIG['sitelibdir']")
 %global	ruby_sitearch		%(ruby -rrbconfig -e "puts Config::CONFIG['sitearchdir']")
-%global	rubyabi		1.8
+%endif
 
-%global	gemdir			%(ruby -rubygems -e 'puts Gem::dir' 2>/dev/null)
-%global	gemname		cairo
-%global	geminstdir		%{gemdir}/gems/%{gemname}-%{version}
+%if 0%{?fedora} >= 17
+%global	rubyabi	1.9.1
+%global	header_dir	%{ruby_vendorarchdir}
+%else
+%global	rubyabi	1.8
+%global	header_dir	%{ruby_sitearch}
+%endif
 
+%global	gem_name		cairo
 
 # Upstream GIT http://github.com/rcairo/
 
 Summary:	Ruby bindings for cairo
-Name:		rubygem-%{gemname}
+Name:		rubygem-%{gem_name}
 Version:	1.10.2
-Release:	2%{?dist}
+Release:	3%{?dist}
 Group:		Development/Languages
 License:	GPLv2 or Ruby
 URL:		http://cairographics.org/rcairo/
-Source0:	http://rubygems.org/downloads/%{gemname}-%{version}.gem
+Source0:	http://rubygems.org/downloads/%{gem_name}-%{version}.gem
 
 BuildRequires:	ruby(abi) = %{rubyabi}
-BuildRequires:	rubygems
+BuildRequires:	rubygems-devel
 BuildRequires:	cairo-devel
 BuildRequires:	ruby-devel
 # For %%check
@@ -30,7 +36,12 @@ BuildRequires:	rubygem(pkg-config)
 BuildRequires:	dejavu-serif-fonts
 Requires:	ruby(abi) = %{rubyabi}
 Requires:	rubygems
-Provides:	rubygem(%{gemname}) = %{version}-%{release}
+Provides:	rubygem(%{gem_name}) = %{version}-%{release}
+
+%if 0%{?fedora} >= 17
+Obsoletes:	ruby-%{gem_name} = %{version}-%{release}
+Provides:	ruby-%{gem_name} = %{version}-%{release}
+%endif
 
 %description
 Ruby bindings for cairo. Cairo is a 2D graphics library with support for 
@@ -45,16 +56,16 @@ Requires:	%{name} = %{version}-%{release}
 %description	doc
 This package contains documentation for %{name}.
 
-%package	-n ruby-%{gemname}
-# TODO: remove ruby-%%{gemname} compat package for F-17
+%package	-n ruby-%{gem_name}
+# TODO: remove ruby-%%{gem_name} compat package for F-17
 # TODO: needs dependency check
-Summary:	Non-Gem support package for %{gemname}
+Summary:	Non-Gem support package for %{gem_name}
 Group:		Development/Languages
 Requires:	%{name} = %{version}-%{release}
-Provides:	ruby(%{gemname}) = %{version}-%{release}
+Provides:	ruby(%{gem_name}) = %{version}-%{release}
 
-%description	-n ruby-%{gemname}
-This package provides non-Gem support for %{gemname}.
+%description	-n ruby-%{gem_name}
+This package provides non-Gem support for %{gem_name}.
 
 %package	devel
 Summary:	Ruby-cairo development environment
@@ -80,11 +91,11 @@ ruby-cairo
 %prep
 %setup -q -T -c
 
-mkdir -p ./%{gemdir}
+mkdir -p ./%{gem_dir}
 export CONFIGURE_ARGS="--with-cflags='%{optflags}'"
 gem install \
 	--local \
-	--install-dir ./%{gemdir} \
+	--install-dir ./%{gem_dir} \
 	-V --force \
 	%{SOURCE0}
 
@@ -97,40 +108,48 @@ find . -name \*.gemspec | \
 
 # Once install to TMPINSTDIR for %%check
 rm -rf ./TMPINSTDIR
-mkdir -p ./TMPINSTDIR/%{gemdir}
-cp -a ./%{gemdir}/* ./TMPINSTDIR/%{gemdir}
+mkdir -p ./TMPINSTDIR/%{gem_dir}
+cp -a ./%{gem_dir}/* ./TMPINSTDIR/%{gem_dir}
 
 TOPDIR=$(pwd)
 
 ## remove all shebang, set permission to 0644
-for f in $(find ./TMPINSTDIR/%{geminstdir} -name \*.rb)
+for f in $(find ./TMPINSTDIR/%{gem_instdir} -name \*.rb)
 do
 	sed -i -e '/^#!/d' $f
 	chmod 0644 $f
 done
 
 # Move C extension library to some private directory
-pushd ./TMPINSTDIR/%{geminstdir}
-grep -rl '%{gemname}.so' . | \
+pushd ./TMPINSTDIR/%{gem_instdir}
+%if 0%{?fedora} < 17
+grep -rl '%{gem_name}.so' . | \
 	xargs sed -i \
-		-e "\@require at s|'%{gemname}.so'|'%{gemname}/%{gemname}.so'|" \
-		-e '\@require at s|"%{gemname}.so"|"%{gemname}/%{gemname}.so"|'
+		-e "\@require at s|'%{gem_name}.so'|'%{gem_name}/%{gem_name}.so'|" \
+		-e '\@require at s|"%{gem_name}.so"|"%{gem_name}/%{gem_name}.so"|'
+popd
+mkdir -p ./TMPINSTDIR/%{ruby_sitearch}/%{gem_name}
+pushd ./TMPINSTDIR
+mv .%{gem_instdir}/lib/%{gem_name}.so \
+	 ./%{ruby_sitearch}/%{gem_name}/
+%else
 popd
-mkdir -p ./TMPINSTDIR/%{ruby_sitearch}/%{gemname}
 pushd ./TMPINSTDIR
-mv .%{geminstdir}/lib/%{gemname}.so \
-	 ./%{ruby_sitearch}/%{gemname}/
+mkdir -p .%{gem_extdir}/lib
+mv .%{gem_instdir}/lib/%{gem_name}.so \
+	./%{gem_extdir}/lib
+%endif
 
 # Move header
-mv ./%{geminstdir}/lib/*.h \
-	./%{ruby_sitearch}/
-
+mkdir -p ./%{header_dir}
+mv ./%{gem_instdir}/lib/*.h \
+	./%{header_dir}/
 popd
 
 
 # cleanups
-rm -rf ./TMPINSTDIR/%{geminstdir}/ext/
-rm -f ./TMPINSTDIR/%{geminstdir}/{Makefile*,extconf.rb}
+rm -rf ./TMPINSTDIR/%{gem_instdir}/ext/
+rm -f ./TMPINSTDIR/%{gem_instdir}/{Makefile*,extconf.rb}
 
 %install
 cp -a ./TMPINSTDIR/* %{buildroot}/
@@ -140,7 +159,7 @@ cp -a ./TMPINSTDIR/* %{buildroot}/
 #
 # Create symlinks
 ##
-## Note that before switching to gem %%{ruby_sitelib}/%%{gemname}
+## Note that before switching to gem %%{ruby_sitelib}/%%{gem_name}
 ## already existed as a directory, so this cannot be replaced
 ## by symlink (cpio fails)
 ## Similarly, all directories under %%{ruby_sitelib} cannot be
@@ -194,12 +213,18 @@ popd
 
 }
 
-create_symlink_rec %{geminstdir}/lib %{ruby_sitelib}
+%if 0%{?fedora} < 17
+create_symlink_rec %{gem_instdir}/lib %{ruby_sitelib}
+%endif
 
 %check
+%if 0%{?fedora} >= 17
+export RUBYLIB=$(pwd)/TMPINSTDIR/%{gem_instdir}:$(pwd)/TMPINSTDIR/%{gem_extdir}/lib
+%else
 export RUBYLIB=$(pwd)/TMPINSTDIR/%{ruby_sitearch}
+%endif
 
-pushd ./TMPINSTDIR/%{geminstdir}
+pushd ./TMPINSTDIR/%{gem_instdir}
 # kill unneeded make process
 rm -rf ./TMPBINDIR
 mkdir ./TMPBINDIR
@@ -215,31 +240,42 @@ ruby ./test/run-test.rb
 popd
 
 %files
-%dir	%{ruby_sitearch}/%{gemname}/
-%{ruby_sitearch}/%{gemname}/%{gemname}.so
-%dir	%{geminstdir}/
-%doc	%{geminstdir}/[A-Z]*
-%exclude %{geminstdir}/Gemfile
-%exclude %{geminstdir}/Rakefile
-%{geminstdir}/lib/
-%{gemdir}/cache/%{gemname}-%{version}.gem
-%{gemdir}/specifications/%{gemname}-%{version}.gemspec
+%if 0%{fedora} < 17
+%dir	%{ruby_sitearch}/%{gem_name}/
+%{ruby_sitearch}/%{gem_name}/%{gem_name}.so
+%else
+%dir %{gem_extdir}
+%dir %{gem_extdir}/lib
+%{gem_extdir}/lib/%{gem_name}.so
+%endif
+%dir	%{gem_instdir}/
+%doc	%{gem_instdir}/[A-Z]*
+%exclude %{gem_instdir}/Gemfile
+%exclude %{gem_instdir}/Rakefile
+%{gem_instdir}/lib/
+%{gem_cache}
+%{gem_spec}
 
 %files	doc
-%{geminstdir}/Gemfile
-%{geminstdir}/Rakefile
-%{geminstdir}/samples/
-%{geminstdir}/test/
-%{gemdir}/doc/%{gemname}-%{version}/
+%{gem_instdir}/Gemfile
+%{gem_instdir}/Rakefile
+%{gem_instdir}/samples/
+%{gem_instdir}/test/
+%{gem_docdir}/
 
-%files	-n ruby-%{gemname}
-%{ruby_sitelib}/%{gemname}.rb
-%{ruby_sitelib}/%{gemname}/
+%if 0%{?fedora} < 17
+%files	-n ruby-%{gem_name}
+%{ruby_sitelib}/%{gem_name}.rb
+%{ruby_sitelib}/%{gem_name}/
+%endif
 
 %files	devel
-%{ruby_sitearch}/rb_cairo.h
+%{header_dir}/rb_cairo.h
 
 %changelog
+* Sun Jan 29 2012 Mamoru Tasaka <mtasaka at fedoraproject.org> - 1.10.2-3
+- F-17: rebuild against ruby 1.9
+
 * Sat Jan 14 2012 Fedora Release Engineering <rel-eng at lists.fedoraproject.org> - 1.10.2-2
 - Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild
 
@@ -257,7 +293,7 @@ popd
 - Ignore test failure for now
 
 * Sun Oct 31 2010 Mamoru Tasaka <mtasaka at ioa.s.u-tokyo.ac.jp> 1.10.0-3
-- Move C extension so that "require %%gemname" works correctly
+- Move C extension so that "require %%gem_name" works correctly
 
 * Tue Oct  5 2010 Mamoru Tasaka <mtasaka at ioa.s.u-tokyo.ac.jp> 1.10.0-2
 - Install one font at BuildRequires for test	


More information about the scm-commits mailing list