]> git.pld-linux.org Git - packages/subversion.git/blobdiff - subversion.spec
- _apachelibdir fixed
[packages/subversion.git] / subversion.spec
index d18557fabf172c0c5343c3e7f48b9ef6302a254d..ac36ed52e9c95fa8a4701a9130d0f7015d6e2764 100644 (file)
@@ -1,35 +1,59 @@
+#
 # TODO:
-# - move modules to some directory (+ link with rpath)
-# - python bindings subpackage
-Summary:       A Concurrent Versioning system similar to but better than CVS.
-Summary(pl):   System Concurrent Versioning System ale lepszy ni¿ CVS
+# - separate subpackage with svnserve + init.d script + sysconfig file
+#
+# Conditional build:
+%bcond_with    internal_neon           # build with internal neon
+%bcond_with    net_client_only         # build only net client
+#      
+%include       /usr/lib/rpm/macros.python
+%{!?with_net_client_only:%include      /usr/lib/rpm/macros.perl}
+Summary:       A Concurrent Versioning system similar to but better than CVS
+Summary(pl):   System kontroli wersji podobny, ale lepszy, ni¿ CVS
+Summary(pt_BR):        Sistema de versionamento concorrente
 Name:          subversion
-Version:       1587
-Release:       2
+Version:       0.35.1
+Release:       1
 License:       Apache/BSD Style
 Group:         Development/Version Control
-Source0:       http://subversion.tigris.org/%{name}-r%{version}.tar.gz
+Source0:       http://svn.collab.net/tarballs/%{name}-%{version}.tar.gz
+# Source0-md5: c4473988acdd82e8b0e176eefc7d0fb7
 Source1:       %{name}-dav_svn.conf
-Patch0:                %{name}-lib.patch
-Patch1:                %{name}-apache2.patch
+Source2:       %{name}-authz_svn.conf
+Source3:       %{name}-svnserve.init
+Source4:       %{name}-svnserve.sysconfig
+Patch0:                %{name}-svnlook.patch
+Patch1:                %{name}-bindings.patch
 URL:           http://subversion.tigris.org/
-BuildRequires: apache-devel >= 2.0.35
-BuildRequires: apr-devel >= 2.0.35
-BuildRequires: autoconf >= 2.53
+%if %{with net_client_only}
+%global apache_modules_api 0
+%else
+BuildRequires: automake
+BuildRequires: apache-devel >= 2.0.47-0.6
+BuildRequires: db-devel >= 4.1.25
+BuildRequires: rpmbuild(macros) >= 1.120
+BuildRequires: swig = 1.3.19
+BuildRequires: swig-python = 1.3.19
+BuildRequires: swig-perl = 1.3.19
+BuildRequires: perl-devel >= 5.8.0
+BuildRequires: rpm-perlprov
+%endif
+BuildRequires: apr-devel >= 1:0.9.5
+BuildRequires: apr-util-devel >= 1:0.9.5
+BuildRequires: autoconf >= 2.59
 BuildRequires: bison
-BuildRequires: db4-devel >= 4.0.14
+BuildRequires: docbook-style-xsl >= 1.56
 BuildRequires: expat-devel
-BuildRequires: libtool >= 1.4
-BuildRequires: neon-devel >= 0.19.2
+BuildRequires: libtool >= 1.4-9
+BuildRequires: libxslt-progs
+%{!?with_internal_neon:BuildRequires:  neon-devel >= 0.24.1}
 BuildRequires: python >= 2.2
+BuildRequires: rpm-pythonprov >= 4.0.2-50
 BuildRequires: texinfo
-Requires(post):        /usr/sbin/fix-info-dir
-Requires(post):        /sbin/ldconfig
-Requires(postun): /sbin/ldconfig 
-Requires(postun): /usr/sbin/fix-info-dir 
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
-%define                _libexecdir     /usr/lib/apache
+%define                _apachelibdir   /usr/%{_lib}/apache
+%define                _libexecdir     %{_libdir}/svn
 
 %description
 The goal of the Subversion project is to build a version control
@@ -68,11 +92,30 @@ Cele projektu to:
 - Internacjonalizacja.
 - Postêpuj±ce wsparcie dla wielu jêzyków.
 
+%description -l pt_BR
+O objetivo do projeto Subversion é construir um sistema de controle de
+versões que seja um substituto para o CVS (Concurrent Versioning
+System) na comunidade opensource, fornecendo grandes melhorias.
+
+%package libs
+Summary:       Subversion libraries and modules
+Summary(pl):   Biblioteka subversion oraz ³adowalne modu³y
+Group:         Libraries
+Obsoletes:     libsubversion0
+
+%description libs
+Subversion libraries and modules.
+
+%description libs -l pl
+Biblioteka subversion oraz ³adowalne modu³y.
+
 %package devel
 Summary:       Header files and develpment documentation for subversion
 Summary(pl):   Pliki nag³ówkowe i dokumetacja do subversion
+Summary(pt_BR):        Arquivos de desenvolvimento para o Subversion
 Group:         Development/Libraries
-Requires:      %{name} = %{version}
+Requires:      %{name}-libs = %{version}
+Obsoletes:     libsubversion0-devel
 
 %description devel
 Header files and develpment documentation for subversion.
@@ -80,11 +123,17 @@ Header files and develpment documentation for subversion.
 %description devel -l pl
 Pliki nag³ówkowe i dokumetacja do subversion.
 
+%description devel -l pt_BR
+Este pacote provê os arquivos necessários para desenvolvedores
+interagirem com o Subversion.
+
 %package static
 Summary:       Static subversion library
 Summary(pl):   Biblioteka statyczna subversion
+Summary(pt_BR):        Sistema de versionamento concorrente
 Group:         Development/Libraries
 Requires:      %{name}-devel = %{version}
+Obsoletes:     libsubversion0-static-devel
 
 %description static
 Static subversion library.
@@ -92,110 +141,301 @@ Static subversion library.
 %description static -l pl
 Biblioteka statyczna subversion.
 
+%description static -l pt_BR
+Este pacote provê um cliente estático do subversion.
+
+%package svnserve
+Summary:       Subversion svnserve
+Summary(pl):   Subversion svnserve
+Group:         Networking/Daemons
+PreReq:                rc-scripts
+Requires(post,preun):  /sbin/chkconfig
+
+%description svnserve
+Subversion svnserve server.
+
+%description svnserve -l pl
+Serwer subversion svnserve.
+
+%package tools
+Summary:       Subversion tools and scripts
+Summary(pl):   Narzêdzia oraz skrypty dla subversion
+Summary(pt_BR):        Módulos python para acessar os recursos do Subversion
+Group:         Applications
+%pyrequires_eq python
+Requires:      python-rcsparse >= 0.1-0.20031026.0
+Requires:      python-subversion = %{version}
+
+%description tools
+Subversion tools and scripts.
+
+%description tools -l pl
+Narzêdzia oraz skrypty dla subversion.
+
+%package -n python-subversion
+Summary:       Subversion python bindings
+Summary(pl):   Dowi±zania do subversion dla pythona
+Summary(pt_BR):        Módulos python para acessar os recursos do Subversion
+Group:         Development/Languages/Python
+%pyrequires_eq python
+Obsoletes:     subversion-python
+
+%description -n python-subversion
+Subversion python bindings.
+
+%description -n python-subversion -l pl
+Dowi±zania do subversion dla pythona.
+
+%description -n python-subversion -l pt_BR
+Módulos python para acessar os recursos do Subversion.
+
+%package -n perl-subversion
+Summary:       Subversion perl bindings
+Summary(pl):   Dowi±zania do subversion dla perla
+Summary(pt_BR):        Módulos perl para acessar os recursos do Subversion
+Group:         Development/Languages/Perl
+Obsoletes:     subversion-perl
+
+%description -n perl-subversion
+Subversion perl bindings.
+
+%description -n perl-subversion -l pl
+Dowi±zania do subversion dla perl.
+
+%description -n perl-subversion -l pt_BR
+Módulos perl para acessar os recursos do Subversion.
+
 %package -n apache-mod_dav_svn
 Summary:       Apache module: Subversion Server
 Summary(pl):   Modu³ apache: Serwer Subversion
 Group:         Networking/Daemons
-Requires:      apache >= 2.0.35
-Requires:      apache-mod_dav >= 2.0.35
+Requires:      apache >= 2.0.47
+Requires:      apache(modules-api) = %{apache_modules_api}
+Requires:      apache-mod_dav
 
 %description -n apache-mod_dav_svn
 Apache module: Subversion Server.
 
-%description -n apache-mod_dav_svn
+%description -n apache-mod_dav_svn -l pl
 Modu³ apache: Serwer Subversion.
 
+%package -n apache-mod_authz_svn
+Summary:       Apache module: Subversion Server - path-based authorization
+Summary(pl):   Modu³ apache: autoryzacja na podstawie ¶cie¿ki dla serwera Subversion
+Group:         Networking/Daemons
+Requires:      apache-mod_dav_svn = %{version}
+Requires:      apache >= 2.0.47
+Requires:      apache(modules-api) = %{apache_modules_api}
+
+%description -n apache-mod_authz_svn
+Apache module: Subversion Server - path-based authorization.
+
+%description -n apache-mod_authz_svn -l pl
+Modu³ apache: autoryzacja na podstawie ¶cie¿ki dla serwera Subversion.
+
 %prep
-%setup -q -n %{name}-r%{version}
-%patch0 -p1
+%setup -q
+%patch0 -p0
 %patch1 -p1
 
 %build
-./autogen.sh
-# EXPAT is external so get rid of all except (patched) xmlparse.h
-rm -rf expat-lite/[a-w]*.[ch] expat-lite/xmldef.h expat-lite/xmlparse.c
-rm -rf expat-lite/xmlrole* expat-lite/xmltok* neon apr
+cp -f /usr/share/automake/config.sub ac-helpers
+chmod +x ./autogen.sh && ./autogen.sh
+
+# don't enable dso - currently it's broken
 %configure \
-       --enable-dso \
-       --with-neon \
-       --with-apr=%{_bindir}/apr-config \
+%if %{with net_client_only}
+       --without-apache \
+       --without-swig \
+       --without-apxs \
+       --without-berkeley-db \
+%else
+       --disable-dso \
+       --disable-mod-activation \
        --with-apxs=%{_sbindir}/apxs \
-       --with-berkeley-db=%{_includedir}/db4:%{_libdir}
+       --with-berkeley-db=%{_includedir}/db4:%{_libdir} \
+%endif
+       %{!?with_internal_neon:--with-neon=%{_prefix}} \
+       --with-apr=%{_bindir}/apr-config \
+       --with-apr-util=%{_bindir}/apu-config
+
+%{__make}
+
+%if ! %{with net_client_only}
+# python
+%{__make} swig-py \
+       swig_pydir=%{py_sitedir}/libsvn \
+       swig_pydir_extra=%{py_sitedir}/svn
+# perl
+bdir=$(pwd)
+%{__make} install-swig-pl-lib \
+       LC_ALL=C \
+       DESTDIR=${bdir}/swig-pl-lib-buildroot
 %{__make}
+cd subversion/bindings/swig/perl
+env APR_CONFIG=%{_bindir}/apr-config \
+    APU_CONFIG=%{_bindir}/apu-config \
+       %{__perl} Makefile.PL \
+       INSTALLDIRS=vendor
+env LIBRARY_PATH=${bdir}/swig-pl-lib-buildroot%{_libdir} %{__make}
+cd ../../../../
+%endif
+
+# build documentation; build process for documentation is severely
+# braindamaged -- authors suggests to untar docbook distribution in
+# build directory, hence the hack here
+ln -s /usr/share/sgml/docbook/xsl-stylesheets doc/book/tools/xsl
+%{__make} -C doc/book all-html
+
+# prepare for %%doc below
+mv -f doc/book/book/html-chunk svn-handbook
+mkdir svn-handbook/images/
+cp -f doc/book/book/images/*.png svn-handbook/images/
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{_sysconfdir}/httpd/httpd.conf,%{_libexecdir}}
+install -d $RPM_BUILD_ROOT/etc/{rc.d/init.d,sysconfig}
+install -d $RPM_BUILD_ROOT{%{_sysconfdir}/httpd/httpd.conf,%{_apachelibdir},%{_infodir}}
 
-# relinking sux
-for i in 1 2; do
-[ "$i" = "2" ] && find . -name "*.la" -exec rm -f "{}" ";"
 %{__make} install \
-       INSTALL_MOD_SHARED=echo \
+       LC_ALL=C \
+       %{!?with_net_client_only:install-swig-py} \
        DESTDIR=$RPM_BUILD_ROOT \
-       libdir=$RPM_BUILD_ROOT%{_libdir} \
-       fs_libdir=$RPM_BUILD_ROOT%{_libdir} \
-       base_libdir=$RPM_BUILD_ROOT%{_libdir} \
-       swig_py_libdir=$RPM_BUILD_ROOT%{_libdir} \
-       bindir=$RPM_BUILD_ROOT%{_bindir} \
-       fs_bindir=$RPM_BUILD_ROOT%{_bindir} \
-       includedir=$RPM_BUILD_ROOT%{_includedir}/%{name}
-done
-
-install subversion/mod_dav_svn/.libs/*.so $RPM_BUILD_ROOT%{_libexecdir}
+       swig_pydir=%{py_sitedir}/libsvn \
+       swig_pydir_extra=%{py_sitedir}/svn
+
+%if ! %{with net_client_only}
+%{__make} install-swig-pl-lib \
+       LC_ALL=C \
+       DESTDIR=$RPM_BUILD_ROOT
+%{__make} -C subversion/bindings/swig/perl install \
+       DESTDIR=$RPM_BUILD_ROOT
+%endif
+
 install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/httpd/httpd.conf/65_mod_dav_svn.conf
+install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}/httpd/httpd.conf/66_mod_authz_svn.conf
+install %{SOURCE3} $RPM_BUILD_ROOT/etc/rc.d/init.d/svnserve
+install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/svnserve
+install doc/programmer/design/*.info* $RPM_BUILD_ROOT%{_infodir}/
 
-gzip -9nf BUGS CHANGES IDEAS INSTALL README
+%if ! %{with net_client_only}
+install tools/cvs2svn/cvs2svn.py       $RPM_BUILD_ROOT%{_bindir}/cvs2svn
+install tools/cvs2svn/cvs2svn.1                $RPM_BUILD_ROOT%{_mandir}/man1
+cp tools/cvs2svn/README tools/cvs2svn/README.cvs2svn
+
+%py_ocomp $RPM_BUILD_ROOT%{py_sitedir}
+%py_comp $RPM_BUILD_ROOT%{py_sitedir}
+%endif
+
+%clean
+rm -rf $RPM_BUILD_ROOT
 
-%post
-/sbin/ldconfig
+%post devel
 [ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
 
-%postun
-/sbin/ldconfig
+%postun devel
 [ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
 
+%post  libs -p /sbin/ldconfig
+%postun        libs -p /sbin/ldconfig
+
+%post svnserve
+if [ -f /var/lock/subsys/svnserve ]; then
+       /etc/rc.d/init.d/svnserve restart 1>&2
+else
+       echo "Run \"/etc/rc.d/init.d/svnserve start\" to start subversion svnserve daemon."
+fi
+
+%preun svnserve
+if [ "$1" = "0" ]; then
+       if [ -f /var/lock/subsys/svnserve ]; then
+               /etc/rc.d/init.d/svnserve restart 1>&2
+       fi
+fi
+
 %post -n apache-mod_dav_svn
 if [ -f /var/lock/subsys/httpd ]; then
-        /etc/rc.d/init.d/httpd restart 1>&2
+       /etc/rc.d/init.d/httpd restart 1>&2
 else
-        echo "Run \"/etc/rc.d/init.d/httpd start\" to start apache http daemon."
+       echo "Run \"/etc/rc.d/init.d/httpd start\" to start apache http daemon."
 fi
 
 %preun -n apache-mod_dav_svn
 if [ "$1" = "0" ]; then
-        if [ -f /var/lock/subsys/httpd ]; then
-                /etc/rc.d/init.d/httpd restart 1>&2
-        fi
+       if [ -f /var/lock/subsys/httpd ]; then
+               /etc/rc.d/init.d/httpd restart 1>&2
+       fi
 fi
 
-%clean
-rm -rf $RPM_BUILD_ROOT
-
 %files
 %defattr(644,root,root,755)
-%doc *.gz
-%attr(755,root,root) %{_bindir}/*
-%attr(755,root,root) %{_libdir}/libsvn_[cdsw]*.so.*
-%attr(755,root,root) %{_libdir}/libsvn_ra.so.*
-%attr(755,root,root) %{_libdir}/libsvn_fs*.so*
-%attr(755,root,root) %{_libdir}/libsvn_ra_*.so*
-%attr(755,root,root) %{_libdir}/libsvn_repos.so*
+%doc BUGS CHANGES COPYING INSTALL README
+%doc svn-handbook doc/book/misc-docs/misc-docs.html
+%doc tools/hook-scripts/*.{pl,py,example}
+%doc tools/hook-scripts/mailer/*.{py,example}
+%attr(755,root,root) %{_bindir}/svn*
+%exclude %{_bindir}/svnserve
 %{_mandir}/man1/*
-%{_infodir}/svn*
+%{_mandir}/man5/*
+%{_mandir}/man8/*
+%exclude %{_mandir}/man?/svnserve*
+%{?with_internal_neon:%exclude %{_mandir}/man1/neon*}
+
+%files libs
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_libdir}/lib*.so.*
 
 %files devel
 %defattr(644,root,root,755)
-%{_includedir}/%{name}
-%attr(755,root,root) %{_libdir}/libsvn_[cdsw]*.so
-%attr(755,root,root) %{_libdir}/libsvn_ra.so
-%attr(755,root,root) %{_libdir}/lib*.la
+%{_includedir}/%{name}*
+%attr(755,root,root) %{_libdir}/lib*.so
+%{_libdir}/lib*.la
+%{_infodir}/svn*
 
 %files static
 %defattr(644,root,root,755)
 %{_libdir}/lib*.a
 
+%if ! %{with net_client_only}
+%files svnserve
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/svnserve
+%{_mandir}/man?/svnserve*
+%attr(754,root,root) /etc/rc.d/init.d/svnserve
+%attr(640,root,root) %config(noreplace) %verify(not mtime md5 size) /etc/sysconfig/svnserve
+
+%files tools
+%defattr(644,root,root,755)
+%doc tools/cvs2svn/README*
+%attr(755,root,root) %{_bindir}/cvs*
+%{_mandir}/man1/cvs*
+
+%files -n python-subversion
+%defattr(644,root,root,755)
+%doc tools/backup/*.py tools/examples/*.py
+%dir %{py_sitedir}/svn
+%dir %{py_sitedir}/libsvn
+%{py_sitedir}/svn/*.py[co]
+%{py_sitedir}/libsvn/*.py[co]
+%attr(755,root,root) %{py_sitedir}/libsvn/*.so
+
+%files -n perl-subversion
+%defattr(644,root,root,755)
+%{perl_vendorarch}/SVN
+%dir %{perl_vendorarch}/auto/SVN
+%dir %{perl_vendorarch}/auto/SVN/*
+%attr(755,root,root) %{perl_vendorarch}/auto/SVN/*/*.so
+%{perl_vendorarch}/auto/SVN/*/*.bs
+%{_mandir}/man3/*.3pm*
+
 %files -n apache-mod_dav_svn
 %defattr(644,root,root,755)
-%attr(640,root,root) %config(noreplace) %verify(not size mtime md5) /etc/httpd/httpd.conf/*_mod_dav_svn.conf
-%attr(755,root,root) %{_libexecdir}/*.so
+%attr(640,root,root) %config(noreplace) %verify(not size mtime md5) %{_sysconfdir}/httpd/httpd.conf/*_mod_dav_svn.conf
+%attr(755,root,root) %{_apachelibdir}/mod_dav_svn.so
+
+%files -n apache-mod_authz_svn
+%defattr(644,root,root,755)
+%doc subversion/mod_authz_svn/INSTALL
+%attr(640,root,root) %config(noreplace) %verify(not size mtime md5) %{_sysconfdir}/httpd/httpd.conf/*_mod_authz_svn.conf
+%attr(755,root,root) %{_apachelibdir}/mod_authz_svn.so
+%endif
This page took 0.056805 seconds and 4 git commands to generate.