%bcond_without ruby # Ruby bindings
%bcond_without static_libs # static libraries
#
+# 5.1 also possible, 5.2 is preferred
+%define lua_ver 5.2
+%define lua_pkg lua%(echo %{lua_ver} | tr -d .)
%include /usr/lib/rpm/macros.perl
Summary: The Prelude library
Summary(pl.UTF-8): Biblioteka Prelude
Name: libprelude
-Version: 1.2.6
+Version: 3.1.0
Release: 1
License: GPL v2 or commercial
Group: Libraries
-# https://www.prelude-ids.org/projects/prelude/files
-Source0: https://www.prelude-ids.org/attachments/download/410/%{name}-%{version}.tar.gz
-# Source0-md5: 6a5aa32864ca6d74e1c7af0cdab7bf40
+#Source0Download: https://www.prelude-ids.org/projects/prelude/files
+Source0: https://www.prelude-ids.org/attachments/download/721/%{name}-%{version}.tar.gz
+# Source0-md5: 2e1a5d7cbf98a2d57fbb367a578dbf8c
Patch0: python-install.patch
-URL: http://www.prelude-ids.com/
+Patch1: %{name}-lua.patch
+URL: https://www.prelude-ids.org/
BuildRequires: autoconf >= 2.59
-BuildRequires: automake
+BuildRequires: automake >= 1:1.9
BuildRequires: bison
BuildRequires: flex
BuildRequires: gnutls-devel >= 1.0.17
BuildRequires: libltdl-devel >= 2:2.0
BuildRequires: libstdc++-devel
BuildRequires: libtool >= 2:2.0
-%{?with_lua:BuildRequires: lua51-devel >= 5.1}
+%{?with_lua:BuildRequires: %{lua_pkg}-devel >= %{lua_ver}}
%{?with_perl:BuildRequires: perl-devel}
%{?with_python2:BuildRequires: python-devel >= 1:2.5}
%{?with_python3:BuildRequires: python3-devel >= 1:3.2}
%description c++-static -l pl.UTF-8
Statyczna biblioteka libpreludecpp.
+%package swig
+Summary: SWIG development files for libprelude
+Summary(pl.UTF-8): Pliki programistyczne SWIG-a dla libprelude
+Group: Development/Libraries
+Requires: %{name}-c++-devel = %{version}-%{release}
+Requires: swig
+
+%description swig
+SWIG development files for libprelude.
+
+%description swig -l pl.UTF-8
+Pliki programistyczne SWIG-a dla libprelude.
+
%package -n lua-prelude
Summary: PreludeEasy - libprelude Lua bindings
Summary(pl.UTF-8): PreludeEasy - dowiązania języka Lua do libprelude
Group: Development/Languages
Requires: %{name}-c++ = %{version}-%{release}
+Requires: %{lua_pkg} >= %{lua_ver}
%description -n lua-prelude
PreludeEasy - libprelude Lua bindings.
PreludeEasy - dowiązania języka Lua do libprelude.
%package -n perl-libprelude
-Summary: Prelude Perl module - low-level Perl binding for libprelude
-Summary(pl.UTF-8): Moduł Perla Prelude - niskopoziomowe wiązanie Perla do libprelude
+Summary: Prelude Perl module - Perl binding for libprelude
+Summary(pl.UTF-8): Moduł Perla Prelude - wiązanie Perla do libprelude
Group: Development/Languages/Perl
-Requires: %{name}-libs = %{version}-%{release}
+Requires: %{name}-c++ = %{version}-%{release}
Obsoletes: perl-PreludeEasy
%description -n perl-libprelude
-Prelude Perl module - low-level Perl binding for libprelude.
+Prelude Perl module - Perl binding for libprelude.
%description -n perl-libprelude -l pl.UTF-8
-Moduł Perla Prelude - niskopoziomowe wiązanie Perla do libprelude.
+Moduł Perla Prelude - wiązanie Perla do libprelude.
%package -n python-libprelude
-Summary: Low-level Python 2.x binding for libprelude
-Summary(pl.UTF-8): Niskopoziomowe wiązanie Pythona 2.x do libprelude
+Summary: Python 2.x binding for libprelude
+Summary(pl.UTF-8): Wiązanie Pythona 2.x do libprelude
Group: Development/Languages/Python
-Requires: %{name}-libs = %{version}-%{release}
+Requires: %{name}-c++ = %{version}-%{release}
Obsoletes: python-PreludeEasy
%description -n python-libprelude
-Low-level Python 2.x binding for libprelude.
+Python 2.x binding for libprelude.
%description -n python-libprelude -l pl.UTF-8
-Niskopoziomowe wiązanie Pythona 2.x do libprelude.
+Wiązanie Pythona 2.x do libprelude.
%package -n python3-libprelude
-Summary: Low-level Python 3.x binding for libprelude
-Summary(pl.UTF-8): Niskopoziomowe wiązanie Pythona 3.x do libprelude
+Summary: Python 3.x binding for libprelude
+Summary(pl.UTF-8): Wiązanie Pythona 3.x do libprelude
Group: Development/Languages/Python
-Requires: %{name}-libs = %{version}-%{release}
+Requires: %{name}-c++ = %{version}-%{release}
%description -n python3-libprelude
-Low-level Python 3.x binding for libprelude.
+Python 3.x binding for libprelude.
%description -n python3-libprelude -l pl.UTF-8
-Niskopoziomowe wiązanie Pythona 3.x do libprelude.
+Wiązanie Pythona 3.x do libprelude.
%package -n ruby-prelude
-Summary: PreludeEasy - libprelude Ruby bindings
-Summary(pl.UTF-8): PreludeEasy - dowiązania języka Ruby do libprelude
+Summary: Ruby bindings for libprelude
+Summary(pl.UTF-8): Wiązania języka Ruby do libprelude
Group: Development/Languages
Requires: %{name}-c++ = %{version}-%{release}
%description -n ruby-prelude
-PreludeEasy - libprelude Ruby bindings.
+Ruby bindings for libprelude.
%description -n ruby-prelude -l pl.UTF-8
-PreludeEasy - dowiązania języka Ruby do libprelude.
+Wiązania języka Ruby do libprelude.
%prep
%setup -q
%patch0 -p1
+%patch1 -p1
%if %{with python3}
# regenerate with fresh swig for python 3.5+
%{__rm} bindings/python/{_prelude.cxx,prelude.py}
%endif
-%{__sed} -i -e 's/lua >= 5.1/lua51 >= 5.1/;s/lua -e/lua5.1 -e/' configure.in
-
%build
%{__libtoolize}
%{__aclocal} -I m4 -I libmissing/m4
--with-lua%{!?with_lua:=no} \
--with-perl%{!?with_perl:=no} \
--with-perl-installdirs=vendor \
- --with-python%{!?with_python2:=no} \
+ --with-python2%{!?with_python2:=no} \
--with-python3%{!?with_python3:=no} \
--with-swig
%{__make}
-#cd bindings/perl
-#%{__make} clean
-#%{__perl} Makefile.PL \
-# INSTALLDIRS=vendor \
-#%{__make}
-
%install
rm -rf $RPM_BUILD_ROOT
python3dir=%{py3_sitescriptdir} \
py3execdir=%{py3_sitedir}
-#%{__make} -C bindings/perl install \
-# DESTDIR=$RPM_BUILD_ROOT
-
%if %{with lua}
-%{__rm} $RPM_BUILD_ROOT%{_libdir}/lua/5.1/prelude.la \
- %{?with_static_libs:$RPM_BUILD_ROOT%{_libdir}/lua/5.1/prelude.a}
+%{__rm} $RPM_BUILD_ROOT%{_libdir}/lua/%{lua_ver}/prelude.la \
+ %{?with_static_libs:$RPM_BUILD_ROOT%{_libdir}/lua/%{lua_ver}/prelude.a}
%endif
%if %{with python2}
%py_postclean
%{?with_static_libs:$RPM_BUILD_ROOT%{ruby_vendorarchdir}/Prelude.a}
%endif
-# not useful in distro? (or -swig?)
-%{__rm} -r $RPM_BUILD_ROOT%{_datadir}/libprelude/swig
-
%clean
rm -rf $RPM_BUILD_ROOT
%{_aclocaldir}/libprelude.m4
%{_gtkdocdir}/libprelude
%{_pkgconfigdir}/libprelude.pc
+%{_mandir}/man1/libprelude-config.1*
%if %{with static_libs}
%files static
%{_libdir}/libpreludecpp.a
%endif
+%files swig
+%defattr(644,root,root,755)
+%dir %{_datadir}/libprelude
+%{_datadir}/libprelude/swig
+
%if %{with lua}
%files -n lua-prelude
%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/lua/5.1/prelude.so
+%attr(755,root,root) %{_libdir}/lua/%{lua_ver}/prelude.so
%endif
%if %{with perl}