2 # - rm files in platform dir (and make not noarch?)
4 %bcond_without tests # build without tests
7 Summary: FFI Extensions for Ruby
12 Group: Development/Languages
13 Source0: http://rubygems.org/gems/%{pkgname}-%{version}.gem
14 # Source0-md5: 1b5ab133fb1b861eeb7c7a8dbaa0acf4
15 URL: http://wiki.github.com/ffi/ffi
16 BuildRequires: libffi-devel
17 BuildRequires: rpm-rubyprov
18 BuildRequires: rpmbuild(macros) >= 1.665
19 BuildRequires: setup.rb
21 BuildRequires: ruby-rspec
22 BuildRequires: ruby-rspec-mocks
24 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
27 Ruby-FFI is a ruby extension for programmatically loading dynamic
28 libraries, binding functions within them, and calling those functions
29 from Ruby code. Moreover, a Ruby-FFI extension works without changes
30 on Ruby and JRuby. Discover why should you write your next extension
31 using Ruby-FFI here: <http://wiki.github.com/ffi/ffi/why-use-ffi>.
34 %setup -q -n %{pkgname}-%{version}
36 # be sure to use system ffi
37 rm -r ext/ffi_c/libffi
40 cp -p %{_datadir}/setup.rb .
45 %{__ruby} setup.rb config \
46 --rbdir=%{ruby_rubylibdir} \
47 --sodir=%{ruby_archdir} \
50 %{__ruby} setup.rb setup
52 %{__make} -C ext/ffi_c \
56 %{__make} -f libtest/GNUmakefile \
59 ruby -Ilib:ext/ffi_c -S \
64 rm -rf $RPM_BUILD_ROOT
65 install -d $RPM_BUILD_ROOT{%{ruby_vendorlibdir},%{ruby_vendorarchdir},%{ruby_specdir}}
66 cp -a lib/* $RPM_BUILD_ROOT%{ruby_vendorlibdir}
67 install -p ext/ffi_c/ffi_c.so $RPM_BUILD_ROOT%{ruby_vendorarchdir}
68 cp -p %{pkgname}-%{version}.gemspec $RPM_BUILD_ROOT%{ruby_specdir}
71 rm -rf $RPM_BUILD_ROOT
74 %defattr(644,root,root,755)
75 %doc README.md LICENSE
76 %{ruby_vendorlibdir}/ffi.rb
77 %{ruby_vendorlibdir}/ffi
78 %attr(755,root,root) %{ruby_vendorarchdir}/ffi_c.so
79 %{ruby_specdir}/%{pkgname}-%{version}.gemspec