]> git.pld-linux.org Git - packages/db4.2.git/blobdiff - db4.2.spec
- posixmutexes handling fix (now only private cap depends on build env)
[packages/db4.2.git] / db4.2.spec
index ad7be5fc0efd5c1015e1bdd73d9edbc846cd55d2..7e4435610709cfd75053618ee7d6337d7ca864c0 100644 (file)
@@ -1,25 +1,34 @@
 #
 # 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    # synonym for pmutex (NPTL provides full interface)
 #
-Summary:       BSD database library for C
+%{?with_nptl:%define   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:       5
+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
 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: sed >= 4.0
+%{?with_tcl:BuildRequires:     tcl-devel >= 8.4.0}
 Obsoletes:     db4
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
@@ -39,7 +48,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
 
@@ -69,7 +78,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
 
@@ -111,8 +120,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 +134,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 +147,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,6 +155,19 @@ 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
@@ -163,7 +186,7 @@ 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 +199,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
@@ -203,9 +226,15 @@ polece
 
 %prep
 %setup -q
+%patch0 -p1
+%patch1 -p0
+%patch2 -p0
 
 %build
 cd dist
+cp -f %{_datadir}/aclocal/libtool.m4 aclocal/libtool.ac
+cp -f %{_datadir}/automake/config.sub .
+cp -f %{_datadir}/libtool/ltmain.sh .
 sh s_config
 cd ..
 
@@ -217,13 +246,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 +268,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}}
+%if %{with java}
+install -d $RPM_BUILD_ROOT%{_javadir}
+%endif
 
 %{__make} -C build_unix.static library_install \
        docdir=%{_docdir}/%{name}-%{version}-docs \
@@ -262,12 +299,21 @@ install -d $RPM_BUILD_ROOT{%{_includedir},%{_libdir},%{_bindir},/lib}
        LIB_INSTALL_FILE_LIST=""
 
 cd $RPM_BUILD_ROOT%{_libdir}
+ln -sf libdb-4.2.so libdb.so
 ln -sf libdb-4.2.so libdb4.so
+ln -sf libdb-4.2.so libdb-4.so
 ln -sf 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 *.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 +321,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 +343,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
@@ -330,7 +375,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
@@ -363,11 +407,18 @@ rm -rf $RPM_BUILD_ROOT
 %files java
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/libdb_java*.so
-%{_libdir}/db.jar
+%{_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 +429,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.113477 seconds and 4 git commands to generate.