X-Git-Url: http://git.pld-linux.org/?p=packages%2Fdb4.7.git;a=blobdiff_plain;f=db4.7.spec;h=a65663129c9586602a86dd85ae7ceb3e53b822b6;hp=276a6ac2f43e365fc99c7e457f1a8bd5b26ab7ec;hb=ceca53abd9b529012c9d1275a8e4daff7afc1a27;hpb=ee5514d74f642f01d070dfb09ff2b7fcbe5a8363 diff --git a/db4.7.spec b/db4.7.spec index 276a6ac..a656631 100644 --- a/db4.7.spec +++ b/db4.7.spec @@ -4,24 +4,24 @@ %bcond_without java # don't build Java bindings %bcond_without tcl # don't build Tcl bindings %bcond_without static_libs # don't build static libraries - -%{?with_java:%include /usr/lib/rpm/macros.java} +%bcond_with default_db # use this db as default system db [Th uses DB 5.3] %define libver 4.7 %define ver %{libver}.25 %define patchlevel 4 +%{?with_java:%include /usr/lib/rpm/macros.java} Summary: Berkeley DB database library for C Summary(pl.UTF-8): Biblioteka C do obsługi baz Berkeley DB Name: db4.7 Version: %{ver}.%{patchlevel} -Release: 7 -Epoch: 0 +Release: 9 License: GPL-like (see LICENSE) Group: Libraries #Source0Download: http://www.oracle.com/technetwork/database/berkeleydb/downloads/index-082944.html Source0: http://download.oracle.com/berkeley-db/db-%{ver}.tar.gz # Source0-md5: ec2b87e833779681a0c3a814aa71359e %patchset_source -f http://download.oracle.com/berkeley-db/patches/db/%{ver}/patch.%{ver}.%g 1 %{patchlevel} +Patch0: %{name}-format-security.patch URL: http://www.oracle.com/technetwork/database/berkeleydb/downloads/index.html BuildRequires: automake BuildRequires: ed @@ -34,11 +34,17 @@ BuildRequires: rpmbuild(macros) >= 1.426 BuildRequires: sed >= 4.0 %{?with_tcl:BuildRequires: tcl-devel >= 8.4.0} Requires: uname(release) >= 2.6.0 -Provides: db = %{version}-%{release} +%if %{with default_db} Provides: db = %{libver} +Provides: db = %{version}-%{release} Obsoletes: db4 +%endif BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) +%if %{without default_db} +%define _includedir %{_prefix}/include/db%{libver} +%endif + %description The Berkeley Database (Berkeley DB) is a programmatic toolkit that provides embedded database support for both traditional and @@ -55,12 +61,13 @@ Pythonie i Perlu. Summary: Header files for Berkeley database library Summary(pl.UTF-8): Pliki nagłówkowe do biblioteki Berkeley Database Group: Development/Libraries -Requires: %{name} = %{epoch}:%{version}-%{release} +Requires: %{name} = %{version}-%{release} +%if %{with default_db} Provides: db-devel = %{version}-%{release} +Obsoletes: db-devel Obsoletes: db3-devel Obsoletes: db4-devel -Obsoletes: db4.5-devel -Obsoletes: db4.6-devel +%endif %description devel The Berkeley Database (Berkeley DB) is a programmatic toolkit that @@ -88,12 +95,13 @@ programów używających Berkeley DB. Summary: Static libraries for Berkeley database library Summary(pl.UTF-8): Statyczne biblioteki Berkeley Database Group: Development/Libraries -Requires: %{name}-devel = %{epoch}:%{version}-%{release} +Requires: %{name}-devel = %{version}-%{release} +%if %{with default_db} Provides: db-static = %{version}-%{release} +Obsoletes: db-static Obsoletes: db3-static Obsoletes: db4-static -Obsoletes: db4.5-static -Obsoletes: db4.6-static +%endif %description static The Berkeley Database (Berkeley DB) is a programmatic toolkit that @@ -121,6 +129,9 @@ używających Berkeley DB. Summary: Berkeley database library API documentation Summary(pl.UTF-8): Dokumentacja API biblioteki baz danych Berkeley Group: Documentation +%if "%{_rpmversion}" >= "5" +BuildArch: noarch +%endif %description apidocs API and internal documentation for Berkeley database library. @@ -132,8 +143,10 @@ Dokumentacja API i wewnętrzna do biblioteki baz danych Berkeley. Summary: Berkeley database library for C++ Summary(pl.UTF-8): Biblioteka baz danych Berkeley dla C++ Group: Libraries +%if %{with default_db} Provides: db-cxx = %{version}-%{release} Obsoletes: db4-cxx +%endif %description cxx Berkeley database library for C++. @@ -145,9 +158,12 @@ Biblioteka baz danych Berkeley dla C++. Summary: Header files for db-cxx library Summary(pl.UTF-8): Pliki nagłówkowe biblioteki db-cxx Group: Development/Libraries -Requires: %{name}-cxx = %{epoch}:%{version}-%{release} -Requires: %{name}-devel = %{epoch}:%{version}-%{release} +Requires: %{name}-cxx = %{version}-%{release} +Requires: %{name}-devel = %{version}-%{release} +%if %{with default_db} Provides: db-cxx-devel = %{version}-%{release} +Obsoletes: db-cxx-devel +%endif Conflicts: db-devel < 4.1.25-3 %description cxx-devel @@ -160,8 +176,11 @@ Pliki nagłówkowe biblioteki db-cxx. Summary: Static version of db-cxx library Summary(pl.UTF-8): Statyczna wersja biblioteki db-cxx Group: Development/Libraries -Requires: %{name}-cxx-devel = %{epoch}:%{version}-%{release} +Requires: %{name}-cxx-devel = %{version}-%{release} +%if %{with default_db} Provides: db-cxx-static = %{version}-%{release} +Obsoletes: db-cxx-static +%endif Conflicts: db-static < 4.2.50-1 %description cxx-static @@ -175,7 +194,10 @@ Summary: Berkeley database library for Java Summary(pl.UTF-8): Biblioteka baz danych Berkeley dla Javy Group: Libraries Requires: jpackage-utils +%if %{with default_db} Provides: db-java = %{version}-%{release} +Obsoletes: db-java +%endif %description java Berkeley database library for Java. @@ -187,8 +209,11 @@ Biblioteka baz danych Berkeley dla Javy. Summary: Development files for db-java library Summary(pl.UTF-8): Pliki programistyczne biblioteki db-java Group: Development/Languages/Java -Requires: %{name}-java = %{epoch}:%{version}-%{release} +Requires: %{name}-java = %{version}-%{release} +%if %{with default_db} Provides: db-java-devel = %{version}-%{release} +Obsoletes: db-java-devel +%endif Conflicts: db-devel < 4.1.25-3 %description java-devel @@ -202,8 +227,10 @@ Summary: Berkeley database library for Tcl Summary(pl.UTF-8): Biblioteka baz danych Berkeley dla Tcl Group: Development/Languages/Tcl Requires: tcl +%if %{with default_db} Provides: db-tcl = %{version}-%{release} Obsoletes: db4-tcl +%endif %description tcl Berkeley database library for Tcl. @@ -215,8 +242,11 @@ Biblioteka baz danych Berkeley dla Tcl. Summary: Development files for db-tcl library Summary(pl.UTF-8): Pliki programistyczne biblioteki db-tcl Group: Development/Languages/Tcl -Requires: %{name}-tcl = %{epoch}:%{version}-%{release} +Requires: %{name}-tcl = %{version}-%{release} +%if %{with default_db} Provides: db-tcl-devel = %{version}-%{release} +Obsoletes: db-tcl-devel +%endif Conflicts: db-devel < 4.1.25-3 %description tcl-devel @@ -229,10 +259,13 @@ Pliki programistyczne biblioteki db-tcl. Summary: Command line tools for managing Berkeley DB databases Summary(pl.UTF-8): Narzędzia do obsługi baz Berkeley DB z linii poleceń Group: Applications/Databases -Requires: %{name} = %{epoch}:%{version}-%{release} +Requires: %{name} = %{version}-%{release} +%if %{with default_db} Provides: db-utils = %{version}-%{release} +Obsoletes: db-utils Obsoletes: db3-utils Obsoletes: db4-utils +%endif %description utils The Berkeley Database (Berkeley DB) is a programmatic toolkit that @@ -261,6 +294,8 @@ poleceń. # official patches %patchset_patch 1 %{patchlevel} +%patch0 -p1 + %build cp -f /usr/share/automake/config.sub dist @@ -280,12 +315,12 @@ LDFLAGS="%{rpmcflags} %{rpmldflags}" export CC CXX CFLAGS CXXFLAGS LDFLAGS ../dist/%configure \ - --enable-compat185 \ --disable-shared \ --enable-static \ - --enable-rpc \ + --enable-compat185 \ + --enable-cxx \ --enable-posixmutexes \ - --enable-cxx + --enable-rpc # (temporarily?) disabled because of compilation errors: # --enable-dump185 \ @@ -299,15 +334,14 @@ cd build_unix ../dist/%configure \ --prefix=%{_prefix} \ --libdir=%{_libdir} \ + --enable-shared \ + --disable-static \ --enable-compat185 \ - --enable-rpc \ - --enable-posixmutexes \ --enable-cxx \ - %{?with_tcl:--enable-tcl} \ - %{?with_tcl:--with-tcl=/usr/lib} \ + --enable-posixmutexes \ + --enable-rpc \ %{?with_java:--enable-java} \ - --disable-static \ - --enable-shared + %{?with_tcl:--enable-tcl --with-tcl=/usr/lib} %{__make} library_build \ TCFLAGS='-I$(builddir) -I%{_includedir}' \ @@ -316,7 +350,7 @@ cd build_unix %install rm -rf $RPM_BUILD_ROOT -install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir},/%{_lib}} +install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir}} %if %{with java} install -d $RPM_BUILD_ROOT%{_javadir} %endif @@ -324,17 +358,30 @@ install -d $RPM_BUILD_ROOT%{_javadir} %if %{with static_libs} %{__make} -C build_unix.static library_install \ DESTDIR=$RPM_BUILD_ROOT \ - docdir=%{_docdir}/db-%{version}-docs + docdir=%{_docdir}/db-%{version}-docs \ + includedir=%{_includedir} %endif %{__make} -C build_unix library_install \ DESTDIR=$RPM_BUILD_ROOT \ LIB_INSTALL_FILE_LIST="" \ - docdir=%{_docdir}/db-%{version}-docs + docdir=%{_docdir}/db-%{version}-docs \ + includedir=%{_includedir} +%if %{with default_db} +install -d $RPM_BUILD_ROOT/%{_lib} mv $RPM_BUILD_ROOT%{_libdir}/libdb-%{libver}.so $RPM_BUILD_ROOT/%{_lib} +%endif cd $RPM_BUILD_ROOT%{_libdir} +%if %{with static_libs} +mv -f libdb.a libdb-%{libver}.a +mv -f libdb_cxx.a libdb_cxx-%{libver}.a +%endif +%if %{with java} +mv -f $RPM_BUILD_ROOT%{_libdir}/db.jar $RPM_BUILD_ROOT%{_javadir}/db-%{libver}.jar +%endif +%if %{with default_db} ln -sf /%{_lib}/libdb-%{libver}.so libdb.so ln -sf /%{_lib}/libdb-%{libver}.so libdb4.so ln -sf /%{_lib}/libdb-%{libver}.so libdb-%{libver}.so @@ -342,28 +389,37 @@ ln -sf /%{_lib}/libdb-%{libver}.so libndbm.so ln -sf libdb-%{libver}.la libdb.la ln -sf libdb-%{libver}.la libdb4.la ln -sf libdb-%{libver}.la libndbm.la +ln -sf libdb_cxx-%{libver}.so libdb_cxx.so +ln -sf libdb_cxx-%{libver}.la libdb_cxx.la %if %{with java} ln -sf libdb_java-%{libver}.la libdb_java.la -mv -f $RPM_BUILD_ROOT%{_libdir}/*.jar $RPM_BUILD_ROOT%{_javadir} +ln -sf db-%{libver}.jar $RPM_BUILD_ROOT%{_javadir}/db.jar %endif %if %{with tcl} ln -sf libdb_tcl-%{libver}.so libdb_tcl.so ln -sf libdb_tcl-%{libver}.la libdb_tcl.la %endif -ln -sf libdb_cxx-%{libver}.la libdb_cxx.la %if %{with static_libs} -mv -f libdb.a libdb-%{libver}.a ln -sf libdb-%{libver}.a libdb.a ln -sf libdb-%{libver}.a libdb4.a ln -sf libdb-%{libver}.a libndbm.a -mv -f libdb_cxx.a libdb_cxx-%{libver}.a ln -sf libdb_cxx-%{libver}.a libdb_cxx.a %endif -ln -sf libdb_cxx-%{libver}.so libdb_cxx.so +%endif sed -i "s/old_library=''/old_library='libdb-%{libver}.a'/" libdb-%{libver}.la sed -i "s/old_library=''/old_library='libdb_cxx-%{libver}.a'/" libdb_cxx-%{libver}.la +cd - + +cd $RPM_BUILD_ROOT%{_bindir} +mv -f berkeley_db_svc berkeley_db_svc-%{libver} +%{?with_default_db:ln -sf berkeley_db_svc-%{libver} berkeley_db_svc} +for F in db_*; do + Fver=$(echo $F|sed 's/db_/db%{libver}_/') + mv $F $Fver + %{?with_default_db:ln -sf $Fver $F} +done cd - rm -f examples_c*/tags install -d $RPM_BUILD_ROOT%{_examplesdir}/db-%{version} @@ -395,18 +451,26 @@ rm -rf $RPM_BUILD_ROOT %files %defattr(644,root,root,755) %doc LICENSE README docs/index.html docs/license +%if %{with default_db} %attr(755,root,root) /%{_lib}/libdb-%{libver}.so +%else +%attr(755,root,root) %{_libdir}/libdb-%{libver}.so +%endif %files devel %defattr(644,root,root,755) +%{_libdir}/libdb-%{libver}.la +%if %{with default_db} %attr(755,root,root) %{_libdir}/libdb-%{libver}.so %attr(755,root,root) %{_libdir}/libdb4.so %attr(755,root,root) %{_libdir}/libdb.so %attr(755,root,root) %{_libdir}/libndbm.so -%{_libdir}/libdb-%{libver}.la %{_libdir}/libdb4.la %{_libdir}/libdb.la %{_libdir}/libndbm.la +%else +%dir %{_includedir} +%endif %{_includedir}/db.h %{_includedir}/db_185.h %{_examplesdir}/db-%{version} @@ -415,10 +479,12 @@ rm -rf $RPM_BUILD_ROOT %files static %defattr(644,root,root,755) %{_libdir}/libdb-%{libver}.a +%if %{with default_db} %{_libdir}/libdb4.a %{_libdir}/libdb.a %{_libdir}/libndbm.a %endif +%endif %if %{with apidocs} %files apidocs @@ -443,9 +509,11 @@ rm -rf $RPM_BUILD_ROOT %files cxx-devel %defattr(644,root,root,755) -%attr(755,root,root) %{_libdir}/libdb_cxx.so %{_libdir}/libdb_cxx-%{libver}.la +%if %{with default_db} +%attr(755,root,root) %{_libdir}/libdb_cxx.so %{_libdir}/libdb_cxx.la +%endif %{_includedir}/db_cxx.h %{_docdir}/db-%{version}-docs/api_cxx %{_docdir}/db-%{version}-docs/gsg/CXX @@ -457,20 +525,27 @@ rm -rf $RPM_BUILD_ROOT %files cxx-static %defattr(644,root,root,755) %{_libdir}/libdb_cxx-%{libver}.a +%if %{with default_db} %{_libdir}/libdb_cxx.a %endif +%endif %if %{with java} %files java %defattr(644,root,root,755) %attr(755,root,root) %{_libdir}/libdb_java-%{libver}.so +%{_javadir}/db-%{libver}.jar +%if %{with default_db} %{_javadir}/db.jar +%endif %files java-devel %defattr(644,root,root,755) -%attr(755,root,root) %{_libdir}/libdb_java.so %{_libdir}/libdb_java-%{libver}.la +%if %{with default_db} +%attr(755,root,root) %{_libdir}/libdb_java.so %{_libdir}/libdb_java.la +%endif %{_docdir}/db-%{version}-docs/collections %{_docdir}/db-%{version}-docs/gsg/JAVA %{_docdir}/db-%{version}-docs/gsg_txn/JAVA @@ -486,27 +561,45 @@ rm -rf $RPM_BUILD_ROOT %files tcl-devel %defattr(644,root,root,755) -%attr(755,root,root) %{_libdir}/libdb_tcl.so %{_libdir}/libdb_tcl-%{libver}.la +%if %{with default_db} +%attr(755,root,root) %{_libdir}/libdb_tcl.so %{_libdir}/libdb_tcl.la +%endif %{_docdir}/db-%{version}-docs/api_tcl %endif %files utils %defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/berkeley_db_svc-%{libver} +%attr(755,root,root) %{_bindir}/db%{libver}_archive +%attr(755,root,root) %{_bindir}/db%{libver}_checkpoint +%attr(755,root,root) %{_bindir}/db%{libver}_codegen +%attr(755,root,root) %{_bindir}/db%{libver}_deadlock +%attr(755,root,root) %{_bindir}/db%{libver}_dump +#%attr(755,root,root) %{_bindir}/db%{libver}_dump185 +%attr(755,root,root) %{_bindir}/db%{libver}_hotbackup +%attr(755,root,root) %{_bindir}/db%{libver}_load +%attr(755,root,root) %{_bindir}/db%{libver}_printlog +%attr(755,root,root) %{_bindir}/db%{libver}_recover +%attr(755,root,root) %{_bindir}/db%{libver}_stat +%attr(755,root,root) %{_bindir}/db%{libver}_upgrade +%attr(755,root,root) %{_bindir}/db%{libver}_verify +%if %{with default_db} %attr(755,root,root) %{_bindir}/berkeley_db_svc -%attr(755,root,root) %{_bindir}/db*_archive -%attr(755,root,root) %{_bindir}/db*_checkpoint -%attr(755,root,root) %{_bindir}/db*_codegen -%attr(755,root,root) %{_bindir}/db*_deadlock -%attr(755,root,root) %{_bindir}/db*_dump -#%attr(755,root,root) %{_bindir}/db*_dump185 -%attr(755,root,root) %{_bindir}/db*_hotbackup -%attr(755,root,root) %{_bindir}/db*_load -%attr(755,root,root) %{_bindir}/db*_printlog -%attr(755,root,root) %{_bindir}/db*_recover -%attr(755,root,root) %{_bindir}/db*_stat -%attr(755,root,root) %{_bindir}/db*_upgrade -%attr(755,root,root) %{_bindir}/db*_verify +%attr(755,root,root) %{_bindir}/db_archive +%attr(755,root,root) %{_bindir}/db_checkpoint +%attr(755,root,root) %{_bindir}/db_codegen +%attr(755,root,root) %{_bindir}/db_deadlock +%attr(755,root,root) %{_bindir}/db_dump +#%attr(755,root,root) %{_bindir}/db_dump185 +%attr(755,root,root) %{_bindir}/db_hotbackup +%attr(755,root,root) %{_bindir}/db_load +%attr(755,root,root) %{_bindir}/db_printlog +%attr(755,root,root) %{_bindir}/db_recover +%attr(755,root,root) %{_bindir}/db_stat +%attr(755,root,root) %{_bindir}/db_upgrade +%attr(755,root,root) %{_bindir}/db_verify +%endif %dir %{_docdir}/db-%{version}-docs %{_docdir}/db-%{version}-docs/utility