]> git.pld-linux.org Git - packages/db.git/blobdiff - db.spec
- rel 11 (fix fastmutexes on amd64; add official fixes nr 3 and 4)
[packages/db.git] / db.spec
diff --git a/db.spec b/db.spec
index ad7be5fc0efd5c1015e1bdd73d9edbc846cd55d2..1edc1cee1362f495a87f07846445a2951a58aace 100644 (file)
--- a/db.spec
+++ b/db.spec
@@ -1,25 +1,38 @@
 #
 # Conditional build:
-%bcond_with    java    # don't build db-java (required for openoffice)
+%bcond_with    java    # build db-java (required for openoffice)
+%bcond_without tcl     # don't build Tcl bindings
+%bcond_with    pmutex  # use POSIX mutexes (only process-private with linuxthreads)
+%bcond_with    nptl    # use process-shared POSIX mutexes (NPTL provides full interface)
 #
-Summary:       BSD database library for C
+%{?with_nptl:%define   with_pmutex     1}
+Summary:       Berkeley DB database library for C
 Summary(pl):   Biblioteka C do obs³ugi baz Berkeley DB
 Name:          db
-Version:       4.2.50
-Release:       1
-License:       BSD
+Version:       4.2.52
+Release:       11
+License:       Sleepycat public license (GPL-like, see LICENSE)
 Group:         Libraries
 # alternative site (sometimes working): http://www.berkeleydb.com/
+#Source0Download: http://www.sleepycat.com/download/
 Source0:       http://www.sleepycat.com/update/snapshot/%{name}-%{version}.tar.gz
-# Source0-md5: 644522fe89c565ec10c6d2e2d010227b
+# Source0-md5: cbc77517c9278cdb47613ce8cb55779f
+Patch0:                %{name}-so-suffix.patch
+Patch1:                patch.4.2.52.1
+Patch2:                patch.4.2.52.2
+Patch3:                patch.4.2.52.3
+Patch4:                patch.4.2.52.4
+Patch5:                %{name}-amd64-fastmutex.patch
 URL:           http://www.sleepycat.com/
 BuildRequires: autoconf
+BuildRequires: automake
 BuildRequires: ed
-# gcc-java or jdk
-# but requires some Java VM - gij is not sufficient
 %{?with_java:BuildRequires:    jdk}
+BuildRequires: libtool
 BuildRequires: libstdc++-devel
-BuildRequires: tcl-devel >= 8.3.2
+BuildRequires: rpmbuild(macros) >= 1.164
+BuildRequires: sed >= 4.0
+%{?with_tcl:BuildRequires:     tcl-devel >= 8.4.0}
 Obsoletes:     db4
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
@@ -39,7 +52,7 @@ Pythonie i Perlu.
 Summary:       Header files for Berkeley database library
 Summary(pl):   Pliki nag³ówkowe do biblioteki Berkeley Database
 Group:         Development/Libraries
-Requires:      %{name} = %{version}
+Requires:      %{name} = %{epoch}:%{version}-%{release}
 Obsoletes:     db3-devel
 Obsoletes:     db4-devel
 
@@ -57,7 +70,7 @@ for building programs which use Berkeley DB.
 %description devel -l pl
 Berkeley Database (Berkeley DB) to zestaw narzêdzi programistycznych
 zapewniaj±cych obs³ugê baz danych w aplikacjach tradycyjnych jak i
-klient-serwer. Berkeley DB obs³ugje dostêp do bazy przez B-drzewa i
+klient-serwer. Berkeley DB obs³uguje dostêp do bazy przez B-drzewa i
 funkcje mieszaj±ce ze sta³± lub zmienn± wielko¶ci± rekordu,
 transakcje, kroniki, pamiêæ dzielon± i odtwarzanie baz. Ma wsparcie
 dla C, C++, Javy i Perla.
@@ -69,7 +82,7 @@ program
 Summary:       Static libraries for Berkeley database library
 Summary(pl):   Statyczne biblioteki Berkeley Database
 Group:         Development/Libraries
-Requires:      %{name}-devel = %{version}
+Requires:      %{name}-devel = %{epoch}:%{version}-%{release}
 Obsoletes:     db3-static
 Obsoletes:     db4-static
 
@@ -87,7 +100,7 @@ use Berkeley DB.
 %description static -l pl
 Berkeley Database (Berkeley DB) to zestaw narzêdzi programistycznych
 zapewniaj±cych obs³ugê baz danych w aplikacjach tradycyjnych jak i
-klient-serwer. Berkeley DB obs³ugje dostêp do bazy przez B-drzewa i
+klient-serwer. Berkeley DB obs³uguje dostêp do bazy przez B-drzewa i
 funkcje mieszaj±ce ze sta³± lub zmienn± wielko¶ci± rekordu,
 transakcje, kroniki, pamiêæ dzielon± i odtwarzanie baz. Ma wsparcie
 dla C, C++, Javy i Perla.
@@ -111,8 +124,8 @@ Biblioteka baz danych Berkeley dla C++.
 Summary:       Header files for db-cxx library
 Summary(pl):   Pliki nag³ówkowe biblioteki db-cxx
 Group:         Development/Libraries
-Requires:      %{name}-cxx = %{version}
-Requires:      %{name}-devel = %{version}
+Requires:      %{name}-cxx = %{epoch}:%{version}-%{release}
+Requires:      %{name}-devel = %{epoch}:%{version}-%{release}
 Conflicts:     db-devel < 4.1.25-3
 
 %description cxx-devel
@@ -125,7 +138,7 @@ Pliki nag
 Summary:       Static version of db-cxx library
 Summary(pl):   Statyczna wersja biblioteki db-cxx
 Group:         Development/Libraries
-Requires:      %{name}-cxx-devel = %{version}
+Requires:      %{name}-cxx-devel = %{epoch}:%{version}-%{release}
 Conflicts:     db-static < 4.2.50-1
 
 %description cxx-static
@@ -138,6 +151,7 @@ Statyczna wersja biblioteki db-cxx.
 Summary:       Berkeley database library for Java
 Summary(pl):   Biblioteka baz danych Berkeley dla Javy
 Group:         Libraries
+Requires:      jre
 
 %description java
 Berkeley database library for Java.
@@ -145,25 +159,38 @@ Berkeley database library for Java.
 %description java -l pl
 Biblioteka baz danych Berkeley dla Javy.
 
+%package java-devel
+Summary:       Development files for db-java library
+Summary(pl):   Pliki programistyczne biblioteki db-java
+Group:         Development/Languages/Java
+Requires:      %{name}-java = %{epoch}:%{version}-%{release}
+Conflicts:     db-devel < 4.1.25-3
+
+%description java-devel
+Development files for db-java library.
+
+%description java-devel -l pl
+Pliki programistyczne biblioteki db-java.
+
 %package tcl
-Summary:       Berkeley database library for TCL
-Summary(pl):   Biblioteka baz danych Berkeley dla TCL
+Summary:       Berkeley database library for Tcl
+Summary(pl):   Biblioteka baz danych Berkeley dla Tcl
 Group:         Development/Languages/Tcl
 Requires:      tcl
 Obsoletes:     db4-tcl
 
 %description tcl
-Berkeley database library for TCL.
+Berkeley database library for Tcl.
 
 %description tcl -l pl
-Biblioteka baz danych Berkeley dla TCL.
+Biblioteka baz danych Berkeley dla Tcl.
 
 %package tcl-devel
 Summary:       Development files for db-tcl library
 Summary(pl):   Pliki programistyczne biblioteki db-tcl
 Group:         Development/Languages/Tcl
 Requires:      tcl
-Requires:      %{name}-tcl = %{version}
+Requires:      %{name}-tcl = %{epoch}:%{version}-%{release}
 Conflicts:     db-devel < 4.1.25-3
 
 %description tcl-devel
@@ -176,7 +203,7 @@ Pliki programistyczne biblioteki db-tcl.
 Summary:       Command line tools for managing Berkeley DB databases
 Summary(pl):   Narzêdzia do obs³ugi baz Berkeley DB z linii poleceñ
 Group:         Applications/Databases
-Requires:      %{name} = %{version}
+Requires:      %{name} = %{epoch}:%{version}-%{release}
 Obsoletes:     db4-utils
 
 %description utils
@@ -193,7 +220,7 @@ databases.
 %description utils -l pl
 Berkeley Database (Berkeley DB) to zestaw narzêdzi programistycznych
 zapewniaj±cych obs³ugê baz danych w aplikacjach tradycyjnych jak i
-klient-serwer. Berkeley DB obs³ugje dostêp do bazy przez B-drzewa i
+klient-serwer. Berkeley DB obs³uguje dostêp do bazy przez B-drzewa i
 funkcje mieszaj±ce ze sta³± lub zmienn± wielko¶ci± rekordu,
 transakcje, kroniki, pamiêæ dzielon± i odtwarzanie baz. Ma wsparcie
 dla C, C++, Javy i Perla.
@@ -203,9 +230,22 @@ polece
 
 %prep
 %setup -q
+%patch0 -p1
+%patch1 -p0
+%patch2 -p0
+%patch3 -p0
+%patch4 -p0
+%patch5 -p1
+
+%if %{without nptl}
+sed -i -e 's,AM_PTHREADS_SHARED("POSIX/.*,:,' dist/aclocal/mutex.ac
+%endif
 
 %build
 cd dist
+cp -f /usr/share/aclocal/libtool.m4 aclocal/libtool.ac
+cp -f /usr/share/automake/config.sub .
+cp -f /usr/share/libtool/ltmain.sh .
 sh s_config
 cd ..
 
@@ -217,13 +257,15 @@ CC="%{__cc}"
 CXX="%{__cxx}"
 CFLAGS="%{rpmcflags}"
 CXXFLAGS="%{rpmcflags} -fno-implicit-templates"
-export CC CXX CFLAGS CXXFLAGS
+LDFLAGS="%{rpmldflags}"
+export CC CXX CFLAGS CXXFLAGS LDFLAGS
 
 ../dist/%configure \
        --enable-compat185 \
        --disable-shared \
        --enable-static \
        --enable-rpc \
+       --%{?with_pmutex:en}%{!?with_pmutex:dis}able-posixmutexes \
        --enable-cxx
 
 # (temporarily?) disabled because of compilation errors:
@@ -237,20 +279,26 @@ cd ../build_unix
        --prefix=%{_prefix} \
        --libdir=%{_libdir} \
        --enable-compat185 \
-       --enable-shared \
-       --disable-static \
        --enable-rpc \
+       --%{?with_pmutex:en}%{!?with_pmutex:dis}able-posixmutexes \
        --enable-cxx \
-       --enable-tcl \
-       --with-tcl=/usr/lib \
-       %{?with_java:--enable-java}
+       %{?with_tcl:--enable-tcl} \
+       %{?with_tcl:--with-tcl=/usr/lib} \
+       %{?with_java:--enable-java} \
+       --disable-static \
+       --enable-shared 
 
 %{__make} library_build \
-       TCFLAGS='-I$(builddir) -I%{_includedir}'
+       TCFLAGS='-I$(builddir) -I%{_includedir}' \
+       LIBSO_LIBS="\$(LIBS)" \
+       LIBTSO_LIBS="\$(LIBS) -ltcl"
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir},/lib}
+install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir},/%{_lib}}
+%if %{with java}
+install -d $RPM_BUILD_ROOT%{_javadir}
+%endif
 
 %{__make} -C build_unix.static library_install \
        docdir=%{_docdir}/%{name}-%{version}-docs \
@@ -261,13 +309,24 @@ install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir},/lib}
        DESTDIR=$RPM_BUILD_ROOT \
        LIB_INSTALL_FILE_LIST=""
 
+mv $RPM_BUILD_ROOT%{_libdir}/libdb-4.2.so $RPM_BUILD_ROOT/%{_lib}
+
 cd $RPM_BUILD_ROOT%{_libdir}
-ln -sf libdb-4.2.so libdb4.so
-ln -sf libdb-4.2.so libndbm.so
+ln -sf /%{_lib}/libdb-4.2.so libdb.so
+ln -sf /%{_lib}/libdb-4.2.so libdb4.so
+ln -sf /%{_lib}/libdb-4.2.so libdb-4.so
+ln -sf /%{_lib}/libdb-4.2.so libndbm.so
 ln -sf libdb-4.2.la libdb.la
 ln -sf libdb-4.2.la libdb4.la
 ln -sf libdb-4.2.la libndbm.la
+%if %{with java}
+ln -sf libdb_java-4.2.la libdb_java.la
+mv -f $RPM_BUILD_ROOT%{_libdir}/*.jar $RPM_BUILD_ROOT%{_javadir}
+%endif
+%if %{with tcl}
+ln -sf libdb_tcl-4.2.so libdb_tcl.so
 ln -sf libdb_tcl-4.2.la libdb_tcl.la
+%endif
 ln -sf libdb_cxx-4.2.la libdb_cxx.la
 mv -f libdb.a libdb-4.2.a
 ln -sf libdb-4.2.a libdb.a
@@ -275,12 +334,11 @@ ln -sf libdb-4.2.a libdb4.a
 ln -sf libdb-4.2.a libndbm.a
 mv -f libdb_cxx.a libdb_cxx-4.2.a
 ln -sf libdb_cxx-4.2.a libdb_cxx.a
+ln -sf libdb_cxx-4.2.so libdb_cxx.so
+ln -sf libdb_cxx-4.2.so libdb_cxx-4.so
 
-mv -f libdb-4.2.la libdb-4.2.la.tmp
-mv -f libdb_cxx-4.2.la libdb_cxx-4.2.la.tmp
-sed -e "s/old_library=''/old_library='libdb-4.2.a'/" libdb-4.2.la.tmp > libdb-4.2.la
-sed -e "s/old_library=''/old_library='libdb_cxx-4.2.a'/" libdb_cxx-4.2.la.tmp > libdb_cxx-4.2.la
-rm -f libdb*.la.tmp
+sed -i "s/old_library=''/old_library='libdb-4.2.a'/" libdb-4.2.la
+sed -i "s/old_library=''/old_library='libdb_cxx-4.2.a'/" libdb_cxx-4.2.la
 
 cd -
 rm -f examples_c*/tags
@@ -298,8 +356,8 @@ cp -rf examples_java/* $RPM_BUILD_ROOT%{_examplesdir}/%{name}-java-%{version}
 %clean
 rm -rf $RPM_BUILD_ROOT
 
-%post   -p /sbin/ldconfig
-%postun -p /sbin/ldconfig
+%post  -p /sbin/ldconfig
+%postun        -p /sbin/ldconfig
 
 %post  tcl -p /sbin/ldconfig
 %postun        tcl -p /sbin/ldconfig
@@ -310,7 +368,7 @@ rm -rf $RPM_BUILD_ROOT
 %files
 %defattr(644,root,root,755)
 %doc LICENSE README
-%attr(755,root,root) %{_libdir}/libdb-4.2.so
+%attr(755,root,root) /%{_lib}/libdb-4.2.so
 %dir %{_docdir}/%{name}-%{version}-docs
 %{_docdir}/%{name}-%{version}-docs/sleepycat
 %{_docdir}/%{name}-%{version}-docs/index.html
@@ -330,7 +388,6 @@ rm -rf $RPM_BUILD_ROOT
 %{_docdir}/%{name}-%{version}-docs/api_c
 %{_docdir}/%{name}-%{version}-docs/images
 %{_docdir}/%{name}-%{version}-docs/ref
-%{_docdir}/%{name}-%{version}-docs/reftoc.html
 %{_examplesdir}/%{name}-%{version}
 
 %files static
@@ -362,12 +419,19 @@ rm -rf $RPM_BUILD_ROOT
 %if %{with java}
 %files java
 %defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libdb_java*.so
-%{_libdir}/db.jar
+%attr(755,root,root) %{_libdir}/libdb_java-4.2.so
+%{_javadir}/db.jar
+
+%files java-devel
+%defattr(644,root,root,755)
+%{_libdir}/libdb_java-4.2.la
+%{_libdir}/libdb_java.la
+%{_libdir}/libdb_java.so
 %{_docdir}/%{name}-%{version}-docs/java
 %{_examplesdir}/%{name}-java-%{version}
 %endif
 
+%if %{with tcl}
 %files tcl
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/libdb_tcl-4.2.so
@@ -378,6 +442,7 @@ rm -rf $RPM_BUILD_ROOT
 %{_libdir}/libdb_tcl.la
 %{_libdir}/libdb_tcl.so
 %{_docdir}/%{name}-%{version}-docs/api_tcl
+%endif
 
 %files utils
 %defattr(644,root,root,755)
This page took 0.068848 seconds and 4 git commands to generate.