+# TODO: consider lua51
+
+# Conditional build:
+%bcond_with gnutls # Enable GNUTLS SSL support (disables openssl)
+%bcond_with lzma # Enable lzma support
+%bcond_with python # Enable Python scripting support
+%bcond_with ruby # Enable (experimental) Ruby scripting support
+%bcond_with verbose # verbose build (V=1)
+%bcond_with x # Use the X Windows System
+%bcond_without 256 # Disable 256 colors support
+%bcond_without bittorrent # Disable BitTorrent support
+%bcond_without cgi # Disable Local CGI support
+%bcond_without fsp # Disable FSP support
+%bcond_without guile # Disable Guile scripting
+%bcond_without idn # Disable Internation Domain Names support
+%bcond_without ipv6 # Disable IPv6 support
+%bcond_without js # Disable experimental (yet quite usable) JavaScript support (using SpiderMonkey)
+%bcond_without led # Disable LEDs
+%bcond_without lua # Disable Lua scripting
+%bcond_without openssl # Disable OpenSSL support
+%bcond_without perl # Disable Perl scripting
+%bcond_without smb # Disable smb protocol support (smb requires libsmbclient)
+#
+%if %{with gnutls}
+%undefine with_openssl
+%endif
+#
+%define pre pre2
Summary: Experimantal Links (text WWW browser)
-Summary(es): El links es un browser para modo texto, similar a lynx
-Summary(pl): Eksperymentalny Links (tekstowa przegl±darka WWW)
-Summary(pt_BR): O links é um browser para modo texto, similar ao lynx
+Summary(es.UTF-8): El links es un browser para modo texto, similar a lynx
+Summary(pl.UTF-8): Eksperymentalny Links (tekstowa przeglądarka WWW)
+Summary(pt_BR.UTF-8): O links é um browser para modo texto, similar ao lynx
Name: elinks
-Version: 0.9.0
-Release: 0.1
+Version: 0.12
+Release: 0.%{pre}.2
Epoch: 1
License: GPL
Group: Applications/Networking
-#Source0Download: http://elinks.or.cz/download.html
-Source0: http://elinks.or.cz/download/%{name}-%{version}.tar.bz2
-# Source0-md5: 65c94efab769c1819d30a17dc9201c73
+Source0: http://www.elinks.cz/download/%{name}-%{version}%{pre}.tar.bz2
+# Source0-md5: bfc2a531f633c9e25e108e5ce2d864ea
Source1: %{name}.desktop
Source2: links.png
-Patch0: %{name}-pl.po.patch
-Patch1: %{name}-home_etc.patch
-URL: http://elinks.or.cz/
+Patch0: %{name}-home_etc.patch
+Patch1: %{name}-lua40.patch
+Patch2: %{name}-date-format.patch
+Patch3: %{name}-old_incremental.patch
+URL: http://www.elinks.cz/
BuildRequires: autoconf
BuildRequires: automake
BuildRequires: bzip2-devel
BuildRequires: expat-devel
+%{?with_fsp:BuildRequires: fsplib-devel}
BuildRequires: gettext-devel
BuildRequires: gpm-devel
-BuildRequires: lua40-devel
-BuildRequires: ncurses-devel => 5.1
-BuildRequires: openssl-devel >= 0.9.7c
+%{?with_guile:BuildRequires: guile-devel}
+%{?with_gnutls:BuildRequires: gnutls-devel >= 1.2.5}
+%{?with_js:BuildRequires: js-devel >= 1.5-0.rc6a.1}
+%{?with_idn:BuildRequires: libidn-devel}
+%{?with_smb:BuildRequires: libsmbclient-devel}
+%{?with_lua:BuildRequires: lua50-devel}
+%{?with_lzma:BuildRequires: lzma-devel}
+BuildRequires: ncurses-devel >= 5.1
+%{?with_openssl:BuildRequires: openssl-devel >= 0.9.7d}
+%{?with_perl:BuildRequires: perl-devel}
+%{?with_python:BuildRequires: python-devel}
+%{?with_ruby:BuildRequires: ruby-devel}
BuildRequires: zlib-devel
-BuildRequires: /usr/bin/texi2html
+Suggests: mailcap
Provides: webclient
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%define _sysconfdir /etc/elinks
-%define specflags_ia32 "-fomit-frame-pointer"
+%define specflags_ia32 -fomit-frame-pointer
%description
This is the elinks tree - intended to provide feature-rich version of
time to maintain it, and to test and tune various patches for Mikulas
to be able to include them in the official links releases.
-%description -l es
+%description -l es.UTF-8
Links es un browser WWW modo texto, similar al Lynx. El links muestra
tablas, hace baja archivos en segundo plano, y usa conexiones HTTP/1.1
keepalive.
-%description -l pl
-Bogata w opcje i mo¿liwo¶ci wersja tekstowej przegl±darki www - links.
-elinks jednak jest dedykowana g³ównie do testowania.
+%description -l pl.UTF-8
+Bogata w opcje i możliwości wersja tekstowej przeglądarki WWW - links.
+elinks jednak jest dedykowana głównie do testowania.
-%description -l pt_BR
-Links é um browser WWW modo texto, similar ao Lynx. O Links exibe
-tabelas, baixa arquivos em segundo plano, e usa as conexões HTTP/1.1
+%description -l pt_BR.UTF-8
+Links é um browser WWW modo texto, similar ao Lynx. O Links exibe
+tabelas, baixa arquivos em segundo plano, e usa as conexões HTTP/1.1
keepalive.
%prep
-%setup -q
+%setup -q -n %{name}-%{version}%{pre}
%patch0 -p1
%patch1 -p1
+%patch2 -p1
+# restores old behaviour of type-ahead search
+#%patch3 -p1
%build
%{__aclocal}
%{__autoconf}
%{__autoheader}
-%{__automake}
%configure \
-%{!?debug: --enable-fastmem} \
-%{?debug: --enable-debug} \
- --enable-leds \
- --enable-256-colors \
- --without-x
-%{__make}
+ %{?with_smb:--enable-smb} \
+ --disable-no-root \
+ %{!?debug:--enable-fastmem} \
+ %{?debug:--enable-debug} \
+ %{!?with_ipv6:--disable-ipv6} \
+ %{?with_bittorrent:--enable-bittorrent} \
+ %{?with_cgi:--enable-cgi} \
+ --enable-finger \
+ --enable-gopher \
+ --enable-nntp \
+ %{?with_256:--enable-256-colors} \
+ --enable-exmode \
+ %{?with_fsp:--enable-fsp} \
+ %{?with_leds:--enable-leds} \
+ --enable-marks \
+ --enable-html-highlight \
+ %{!?with_idn:--without-idn} \
+ %{?with_guile:--with-guile} \
+ %{?with_perl:--with-perl} \
+ %{!?with_lua:--without-lua} \
+ %{?with_python:--with-python} \
+ %{?with_ruby:--with-ruby} \
+ %{!?with_js:--without-spidermonkey} \
+ %{?with_gnutls:--with-gnutls} \
+ %{!?with_openssl:--without-openssl} \
+ --with%{!?with_x:out}-x \
+ %{!?with_lzma:--without-lzma}
+# xterm -e is default, one might want to change it to
+# something else
+# --with-xterm="xterm -e"
-cd doc
-texi2html elinks-lua.texi
-cd ..
+%{__make} %{?with_verbose:V=1}
%install
rm -rf $RPM_BUILD_ROOT
$RPM_BUILD_ROOT%{_datadir}/%{name} \
$RPM_BUILD_ROOT{%{_sysconfdir},%{_pixmapsdir}}
-%{__make} install \
+%{__make} install %{?with_verbose:V=1} \
DESTDIR=$RPM_BUILD_ROOT
install %{SOURCE1} $RPM_BUILD_ROOT%{_desktopdir}
install %{SOURCE2} $RPM_BUILD_ROOT%{_pixmapsdir}/%{name}.png
-install contrib/lua/[bcmr]*.lua $RPM_BUILD_ROOT%{_sysconfdir}
-install contrib/lua/hooks.lua.in $RPM_BUILD_ROOT%{_sysconfdir}/hooks.lua
+%{?with_lua:install contrib/lua/*.lua $RPM_BUILD_ROOT%{_sysconfdir}}
%find_lang %{name}
%doc AUTHORS BUGS ChangeLog NEWS README SITES TODO
%doc contrib/{keybind*,wipe-out-ssl*,lua/elinks-remote}
%doc contrib/conv/{*awk,*.pl,*.sh}
-%doc doc/{*.txt,*.html}
+%doc doc/html/*.html
%attr(755,root,root) %{_bindir}/*
%{_mandir}/man*/*
-%{_desktopdir}/*
+%{_desktopdir}/*.desktop
%{_pixmapsdir}/*
-%config(noreplace) %verify(not size mtime md5) %{_sysconfdir}
+%{?with_lua:%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}}