]> git.pld-linux.org Git - packages/libfuse.git/blobdiff - libfuse.spec
- mass atack: -j1 for make scripts
[packages/libfuse.git] / libfuse.spec
index d759ab93ea5d040f07e7f40114315974caa1d437..88285fd17dfa497e6b2559a7511d3e167262f1fc 100644 (file)
@@ -1,7 +1,4 @@
 #
-# TODO:
-# - review patches
-#
 # Condtional build:
 %bcond_without dist_kernel     # without distribution kernel
 %bcond_without kernel          # don't build kernel modules
@@ -9,38 +6,51 @@
 %bcond_without userspace       # don't build userspace tools
 %bcond_with    verbose         # verbose build (V=1)
 #
-Name:          kernel-misc-fuse
+%ifarch sparc
+%undefine      with_smp
+%endif
+#
+%define                _rel    6
 Summary:       Filesystem in Userspace
 Summary(pl):   System plików w przestrzeni u¿ytkownika
-Version:       2.2
-%define                _rel    0.4
-Release:       %{_rel}@%{_kernel_ver_str}
+Name:          libfuse
+Version:       2.5.3
+Release:       %{_rel}
 Epoch:         0
 License:       GPL v2
-Group:         Base/Kernel
+Group:         Applications/System
 Source0:       http://dl.sourceforge.net/fuse/fuse-%{version}.tar.gz
-# Source0-md5: 6f7fe60795324111fea18143e81512ec
-# Source0-size:        126361
-Patch0:                %{name}-configure.in.patch
-Patch1:                %{name}-perm.patch
+# Source0-md5: 9c7e8b6606b9f158ae20b8521ba2867c
+Source1:       fuse.conf
+Patch0:                kernel-misc-fuse-Makefile.am.patch
+Patch1:                %{name}-ac-LIBTOOL.patch
 URL:           http://fuse.sourceforge.net/
 BuildRequires: autoconf
 BuildRequires: automake
 %if %{with kernel}
-%{?with_dist_kernel:BuildRequires:     kernel-module-build >= 2.6.7}
+%{?with_dist_kernel:BuildRequires:     kernel-module-build >= 3:2.6.7}
+BuildRequires: rpmbuild(macros) >= 1.217
 %endif
 BuildRequires: libtool
-%{?with_dist_kernel:%requires_releq_kernel_up}
-Requires(post,postun): /sbin/depmod
-%{?with_dist_kernel:Requires(postun):  kernel}
+BuildRequires: sed >= 4.0
+Requires(postun):      /sbin/ldconfig
+Requires(postun):      /usr/sbin/groupdel
+Requires(pre): /usr/bin/getgid
+Requires(pre): /usr/sbin/groupadd
 Buildroot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
+%if %{without kernel}
+%undefine with_dist_kernel
+%endif
+
 %description
 FUSE (Filesystem in Userspace) is a simple interface for userspace
 programs to export a virtual filesystem to the Linux kernel. FUSE also
 aims to provide a secure method for non privileged users to create and
 mount their own filesystem implementations.
 
+This package contains a shared library.
+
 %description -l pl
 FUSE stanowi prosty interfejs dla programów dzia³aj±cych w przestrzeni
 u¿ytkownika eksportuj±cy wirtualny system plików do j±dra Linuksa.
@@ -48,88 +58,90 @@ FUSE ma r
 montowania w³asnych implementacji systemów plików przez zwyk³ych
 (nieuprzywilejowanych) u¿ytkowników.
 
-%package -n kernel-smp-misc-fuse
+Ten pakiet zawiera bibliotekê wspó³dzielon±.
+
+%package devel
+Summary:       Filesytem in Userspace - Development header files
+Summary(pl):   System plików w przestrzeni u¿ytkownika - pliki nag³ówkowe
+Group:         Development/Libraries
+Requires:      %{name} = %{epoch}:%{version}-%{_rel}
+
+%description devel
+Libfuse library header files.
+
+%description devel -l pl
+Pliki nag³ówkowe biblioteki libfuse.
+
+%package static
+Summary:       Filesytem in Userspace - static library
+Summary(pl):   System plików w przestrzeni u¿ytkownika - biblioteka statyczna
+Release:       %{_rel}
+Group:         Development/Libraries
+Requires:      libfuse-devel = %{epoch}:%{version}-%{_rel}
+
+%description static
+Static libfuse libraries.
+
+%description static -l pl
+Statyczna biblioteka libfuse.
+
+%package -n kernel-misc-fuse
 Summary:       Filesystem in Userspace
 Summary(pl):   System plików w przestrzeni u¿ytkownika
 Release:       %{_rel}@%{_kernel_ver_str}
 License:       GPL v2
 Group:         Base/Kernel
-Provides:      kernel-misc-fuse
-%{?with_dist_kernel:%requires_releq_kernel_smp}
 Requires(post,postun): /sbin/depmod
-%{?with_dist_kernel:Requires(postun):  kernel-smp}
+%if %{with dist_kernel}
+%requires_releq_kernel_up
+Requires(postun):      %releq_kernel_up
+%endif
 
-%description -n kernel-smp-misc-fuse
+%description -n kernel-misc-fuse
 FUSE (Filesystem in Userspace) is a simple interface for userspace
 programs to export a virtual filesystem to the Linux kernel. FUSE also
 aims to provide a secure method for non privileged users to create and
 mount their own filesystem implementations.
 
-%description -n kernel-smp-misc-fuse -l pl
+%description -n kernel-misc-fuse -l pl
 FUSE stanowi prosty interfejs dla programów dzia³aj±cych w przestrzeni
 u¿ytkownika eksportuj±cy wirtualny system plików do j±dra Linuksa.
 FUSE ma równie¿ na celu udostêpnienie bezpiecznej metody tworzenia i
 montowania w³asnych implementacji systemów plików przez zwyk³ych
 (nieuprzywilejowanych) u¿ytkowników.
 
-%package -n libfuse
-Summary:       Shared library for Filesytem in Userspace
-Summary(pl):   Biblioteki dzielone Systemu plików w przestrzeni u¿ytkownika
-Group:         Applications/System
-Release:       %{_rel}
-
-%description -n libfuse
-Shared library for Filesytem in Userspace
-
-%description -n libfuse -l pl
-Biblioteki dzielone Systemu plików w przestrzeni u¿ytkownika
-
-%package -n libfuse-devel
-Summary:       Filesytem in Userspace - Development header fiels and libraries
-Summary(pl):   Systemu plików w przestrzeni u¿ytkownika - Biblioteki dzielone
-Group:         Development/Libraries
-Release:       %{_rel}
-Requires:      libfuse = %{epoch}:%{version}-%{_rel}
-
-%description -n libfuse-devel
-Libfuse library header files.
-
-%description -n libfuse-devel -l pl
-Libfuse biblioteki nag³ówkowe dla programistów.
-
-%package -n libfuse-static
-Summary:       Filesytem in Userspace - static libraries
-Summary(pl):   Systemu plików w przestrzeni u¿ytkownika - Biblioteki statyczne
-Group:         Development/Libraries
-Release:       %{_rel}
-Requires:      libfuse-devel = %{epoch}:%{version}-%{_rel}
-
-%description -n libfuse-static
-Static libfuse libraries.
-
-%description -n libfuse-static -l pl
-Statyczne biblioteki libfuse
-
-%package -n fusermount
-Summary:       Filesytem in Userspace utilities
-Summary(pl):   Narzêdzia obs³uguj±ce systemu plików w przestrzeni u¿ytkownika
-Group:         Applications/System
-Release:       %{_rel}
+%package -n kernel-smp-misc-fuse
+Summary:       Filesystem in Userspace
+Summary(pl):   System plików w przestrzeni u¿ytkownika
+Release:       %{_rel}@%{_kernel_ver_str}
+License:       GPL v2
+Group:         Base/Kernel
+Requires(post,postun): /sbin/depmod
+Provides:      kernel-misc-fuse
+%if %{with dist_kernel}
+%requires_releq_kernel_smp
+Requires(postun):      %releq_kernel_smp
+%endif
 
-%description -n fusermount
-Filesytem in Userspace utilities. It provide a secure method for non
-privileged users to create and mount their own filesystem
-implementations.
+%description -n kernel-smp-misc-fuse
+FUSE (Filesystem in Userspace) is a simple interface for userspace
+programs to export a virtual filesystem to the Linux kernel. FUSE also
+aims to provide a secure method for non privileged users to create and
+mount their own filesystem implementations.
 
-%description -n fusermount -l pl
-Narzêdzia obs³uguj±ce systemu plików w przestrzeni u¿ytkownika.
-Dostarcza bezpieczn± metodê tworzenia i montowania w³asnych systemów
-plików dla nie uprzywilejowanych userów.
+%description -n kernel-smp-misc-fuse -l pl
+FUSE stanowi prosty interfejs dla programów dzia³aj±cych w przestrzeni
+u¿ytkownika eksportuj±cy wirtualny system plików do j±dra Linuksa.
+FUSE ma równie¿ na celu udostêpnienie bezpiecznej metody tworzenia i
+montowania w³asnych implementacji systemów plików przez zwyk³ych
+(nieuprzywilejowanych) u¿ytkowników.
 
 %prep
 %setup -q -n fuse-%{version}
-%patch0 -p0
-#patch1 -p1
+%patch0 -p1
+%patch1 -p1
+
+sed -i '/FUSERMOUNT_PROG/s,fusermount,%{_bindir}/fusermount,' lib/mount.c
 
 %build
 %{__libtoolize}
@@ -138,38 +150,10 @@ plik
 %{__autoconf}
 %{__automake}
 %configure \
-    --enable-lib \
-    --enable-util \
-    --with-kernel=%{_kernelsrcdir}
-
-%if %{with kernel}
-cd kernel
-
-for cfg in %{?with_dist_kernel:%{?with_smp:smp} up}%{!?with_dist_kernel:nondist}; do
-    if [ ! -r "%{_kernelsrcdir}/config-$cfg" ]; then
-       exit 1
-    fi
-    rm -rf include
-    install -d include/{linux,config}
-    ln -sf %{_kernelsrcdir}/config-$cfg .config
-    ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h include/linux/autoconf.h
-    ln -sf %{_kernelsrcdir}/include/asm-%{_target_base_arch} include/asm
-    touch include/config/MARKER
-    %{__make} -C %{_kernelsrcdir} clean \
-       RCS_FIND_IGNORE="-name '*.ko' -o" \
-       M=$PWD O=$PWD \
-       %{?with_verbose:V=1}
-    %{__make} -C %{_kernelsrcdir} modules \
-       EXTRA_CFLAGS='-I../include -DFUSE_VERSION=\"2.2\"' \
-       RCS_FIND_IGNORE="-name '*.ko' -o" \
-       CC="%{__cc}" CPP="%{__cpp}" \
-       M=$PWD O=$PWD \
-       %{?with_verbose:V=1}
-
-    mv fuse.ko fuse-$cfg.ko
-done
-cd -
-%endif
+       --%{?with_kernel:en}%{!?with_kernel:dis}able-kernel-module \
+       --enable-lib \
+       --enable-util \
+       %{?with_kernel:--with-kernel=%{_kernelsrcdir}}
 
 %if %{with userspace}
 cp kernel/fuse_kernel.h include/
@@ -178,10 +162,44 @@ for DIR in include lib util; do
 done
 %endif
 
+%if %{with kernel}
+cd kernel
+for cfg in %{?with_dist_kernel:%{?with_smp:smp} up}%{!?with_dist_kernel:nondist}; do
+       if [ ! -r "%{_kernelsrcdir}/config-$cfg" ]; then
+               exit 1
+       fi
+       install -d o/include/linux
+       ln -sf %{_kernelsrcdir}/config-$cfg o/.config
+       ln -sf %{_kernelsrcdir}/Module.symvers-$cfg o/Module.symvers
+       ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h o/include/linux/autoconf.h
+%if %{with dist_kernel}
+       %{__make} -j1 -C %{_kernelsrcdir} O=$PWD/o prepare scripts
+%else
+       install -d o/include/config
+       touch o/include/config/MARKER
+       ln -sf %{_kernelsrcdir}/scripts o/scripts
+%endif
+       %{__make} -C %{_kernelsrcdir} clean \
+               RCS_FIND_IGNORE="-name '*.ko' -o" \
+               SYSSRC=%{_kernelsrcdir} \
+               SYSOUT=$PWD/o \
+               M=$PWD O=$PWD/o \
+               %{?with_verbose:V=1}
+       %{__make} -C %{_kernelsrcdir} modules \
+               CC="%{__cc}" CPP="%{__cpp}" \
+               SYSSRC=%{_kernelsrcdir} \
+               SYSOUT=$PWD/o \
+               M=$PWD O=$PWD/o \
+               %{?with_verbose:V=1}
+
+       mv fuse.ko fuse-$cfg.ko
+done
+cd -
+%endif
+
 %install
 rm -rf $RPM_BUILD_ROOT
-
-install -d $RPM_BUILD_ROOT%{_pkgconfigdir}
+install -d $RPM_BUILD_ROOT{%{_pkgconfigdir},%{_sysconfdir}}
 
 %if %{with userspace}
 for DIR in include lib util; do
@@ -190,6 +208,7 @@ for DIR in include lib util; do
 done
 
 install fuse.pc $RPM_BUILD_ROOT%{_pkgconfigdir}
+install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}
 %endif
 
 %if %{with kernel}
@@ -206,10 +225,20 @@ install fuse-smp.ko \
 %clean
 rm -rf $RPM_BUILD_ROOT
 
-%post
-%depmod %{_kernel_ver}
+%pre
+%groupadd -g 84 fuse
 
+%post  -p /sbin/ldconfig
 %postun
+/sbin/ldconfig
+if [ "$1" = "0" ] ; then
+       %groupremove fuse
+fi
+
+%post -n kernel-misc-fuse
+%depmod %{_kernel_ver}
+
+%postun -n kernel-misc-fuse
 %depmod %{_kernel_ver}
 
 %post -n kernel-smp-misc-fuse
@@ -218,43 +247,35 @@ rm -rf $RPM_BUILD_ROOT
 %postun -n kernel-smp-misc-fuse
 %depmod %{_kernel_ver}smp
 
-%post -n libfuse -p /sbin/ldconfig
-%postun -n libfuse -p /sbin/ldconfig
-
-%if %{with kernel}
+%if %{with userspace}
 %files
 %defattr(644,root,root,755)
 %doc README NEWS ChangeLog AUTHORS doc/*
-/lib/modules/%{_kernel_ver}/kernel/fs/fuse.ko*
-
-%if %{with smp} && %{with dist_kernel}
-%files -n kernel-smp-misc-fuse
-%defattr(644,root,root,755)
-%doc README NEWS ChangeLog AUTHORS doc/*
-/lib/modules/%{_kernel_ver}smp/kernel/fs/fuse.ko*
-%endif
-%endif
-
-%if %{with userspace}
-%files -n fusermount
-%defattr(644,root,root,755)
-# suid needed? NO!
-%attr(755,root,root) %{_bindir}/fusermount
-# do it ! failed
-# %%attr(755,root,root) %{_sbindir}/mount.fuse
-
-%files -n libfuse
-%defattr(644,root,root,755)
+%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/fuse.conf
+%attr(4754,root,fuse) %{_bindir}/fusermount
+%attr(755,root,root) /sbin/mount.fuse
 %attr(755,root,root) %{_libdir}/libfuse.so.*.*.*
 
-%files -n libfuse-devel
+%files devel
 %defattr(644,root,root,755)
-%{_includedir}/fuse*
-%{_libdir}/libfuse.la
 %attr(755,root,root) %{_libdir}/libfuse.so
+%{_libdir}/libfuse.la
+%{_includedir}/fuse*
 %{_pkgconfigdir}/fuse.pc
 
-%files -n libfuse-static
+%files static
 %defattr(644,root,root,755)
 %{_libdir}/libfuse.a
 %endif
+
+%if %{with kernel}
+%files -n kernel-misc-fuse
+%defattr(644,root,root,755)
+/lib/modules/%{_kernel_ver}/kernel/fs/fuse.ko*
+
+%if %{with smp} && %{with dist_kernel}
+%files -n kernel-smp-misc-fuse
+%defattr(644,root,root,755)
+/lib/modules/%{_kernel_ver}smp/kernel/fs/fuse.ko*
+%endif
+%endif
This page took 0.03591 seconds and 4 git commands to generate.