#
# Conditional build:
-%bcond_without gtk2 # build gtk1 client, not gtk2
+%bcond_without gtk # do not build gtk client
+%bcond_without ggz_client # build without ggz client
+%bcond_without ggz_server # build without ggz server
#
-
-%define beta beta3
-
Summary: FREE CIVilization clone
-Summary(es): Clon del juego Civilization
-Summary(pl): Niekomercyjny klon CIVilization
-Summary(pt_BR): Clone do jogo Civilization
+Summary(es.UTF-8): Clon del juego Civilization
+Summary(pl.UTF-8): Niekomercyjny klon CIVilization
+Summary(pt_BR.UTF-8): Clone do jogo Civilization
Name: freeciv
-Version: 1.14.1
-Release: 1.%{beta}
-License: GPL
+Version: 2.1.8
+Release: 1
+License: GPL v2+
Group: X11/Applications/Games/Strategy
-Source0: ftp://ftp.freeciv.org/freeciv/beta/%{name}-%{version}-%{beta}.tar.bz2
-# Source0-md5: 3184042067d5fdd511dddcf5ff9b1ab7
-Source1: %{name}-client.desktop
-Source2: %{name}-server.desktop
-Source3: %{name}.png
-Source4: ftp://ftp.freeciv.org/freeciv/contrib/sounds/sets/stdsounds1.tar.gz
-# Source4-md5: 28a54fbe3ddb67a9b8fe85b8332415e1
-Source5: ftp://ftp.freeciv.org/freeciv/contrib/sounds/sets/stdsounds.spec
-# Source5-md5: 6e3e2bc551eb49ca87c4f0085991db15
+Source0: http://dl.sourceforge.net/freeciv/%{name}-%{version}.tar.bz2
+# Source0-md5: a5b50e596b146616ebebde5c483f59d5
+Source1: ftp://ftp.freeciv.org/pub/freeciv/contrib/audio/soundsets/stdsounds3.tar.gz
+# Source1-md5: 77215914712f2f351092918f5e41e39e
+Source2: ftp://ftp.freeciv.org/pub/freeciv/contrib/tilesets/freeland/freeland-normal-2.0.0.tar.gz
+# Source2-md5: c9f061fca82aa50a19fbbc89c06ff81d
+Patch0: %{name}-link.patch
+Patch1: %{name}-desktop.patch
+Patch2: %{name}-ggz.patch
URL: http://www.freeciv.org/
BuildRequires: SDL_mixer-devel
+BuildRequires: autoconf >= 2.52
+BuildRequires: automake
BuildRequires: esound-devel
-%{!?with_gtk2:BuildRequires: gtk+-devel > 1.2.1}
-%{?with_gtk2:BuildRequires: gtk+2-devel}
-%{!?with_gtk2:BuildRequires: imlib-devel >= 1.9.2}
+%{?with_ggz_client:BuildRequires: ggz-gtk-client-devel}
+%{?with_ggz_server:BuildRequires: ggz-server-devel}
+%{?with_gtk:BuildRequires: gtk+2-devel}
+BuildRequires: libggz-devel
+BuildRequires: pkgconfig
BuildRequires: readline-devel
BuildRequires: zlib-devel
-Requires: SDL_mixer
-Requires: esound
-%{!?with_gtk2:Requires: gtk+ > 1.2.1}
-%{!?with_gtk2:Requires: imlib >= 1.9.2}
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%description
-Free clone of Sid Meiers Civilization. Free Civilization clone for
-unix and X. This is multiplayer strategic game and you can also play
+Free clone of Sid Meier's Civilization. Free Civilization clone for
+Unix and X. This is multiplayer strategic game and you can also play
against computer-AI players.
-%description -l es
+%description -l es.UTF-8
Clon del juego Civilization.
-%description -l pl
-Freeciv jest to niekomercyjny (GPL) klon gry Civilization Sida
-Meiersa. Jest to gra strategiczna dla systemu X Window. Mo¿na graæ w
-ni± z innymi osobami poprzez sieæ, a tak¿e przeciwko "graczom"
-zarz±dzanym przez komputer.
+%description -l pl.UTF-8
+Freeciv jest to niekomercyjny (GPL) klon gry Civilization Sida Meiera.
+Jest to gra strategiczna dla systemu X Window. Można grać w nią z
+innymi osobami poprzez sieć, a także przeciwko "graczom" zarządzanym
+przez komputer.
-%description -l pt_BR
-O FreeCiv é uma implementação do Civilization II para o Sistema X
+%description -l pt_BR.UTF-8
+O FreeCiv é uma implementação do Civilization II para o Sistema X
Window.
+%package client
+Summary: Freeciv game client
+Summary(pl.UTF-8): Klient gry Freeciv
+Group: X11/Applications/Games/Strategy
+Requires: %{name} = %{version}-%{release}
+Requires: SDL_mixer
+Suggests: %{name}-server = %{version}-%{release}
+
+%description client
+This package contains Freeciv game client.
+
+%description client -l pl.UTF-8
+Ten pakiet zawiera klienta gry Freeciv.
+
+%package server
+Summary: Freeciv game server
+Summary(pl.UTF-8): Serwer gry Freeciv
+Group: X11/Applications/Games/Strategy
+Requires: %{name} = %{version}-%{release}
+
+%description server
+This package contans Freeciv game server.
+
+%description server -l pl.UTF-8
+Ten pakiet zawiera server gry Freeciv.
+
%prep
-%setup -q -a 4 -n %{name}-%{version}-%{beta}
+%setup -q -a1 -a2
+%patch0 -p1
+%patch1 -p1
+%patch2 -p1
%build
-%configure2_13 \
-%{!?with_gtk2: --enable-client=gtk} \
-%{?with_gtk2: --enable-client=gtk2}
+%{__aclocal} -I m4
+%{__autoconf}
+%{__autoheader}
+%{__automake}
+%configure \
+ --with-ggzd-confdir=%{_sysconfdir}/ggzd \
+ %{?with_gtk: --enable-client=gtk} \
+ %{!?with_ggz_client: --without-ggz-client} \
+ %{!?with_ggz_server: --without-ggz-server}
%{__make}
%install
rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT%{_libdir}/X11/app-defaults \
- $RPM_BUILD_ROOT{%{_applnkdir}/Games/Strategy,%{_pixmapsdir}}
+install -d $RPM_BUILD_ROOT{%{_desktopdir},%{_pixmapsdir}}
%{__make} install \
DESTDIR=$RPM_BUILD_ROOT
-rm $RPM_BUILD_ROOT%{_datadir}/freeciv/Freeciv
+cp -f client/%{name}.desktop $RPM_BUILD_ROOT%{_desktopdir}/%{name}-client.desktop
+cp -f server/%{name}-server.desktop $RPM_BUILD_ROOT%{_desktopdir}
+rm $RPM_BUILD_ROOT%{_desktopdir}/%{name}.desktop
+
+cp -f data/icons/32x32/*.png $RPM_BUILD_ROOT%{_pixmapsdir}
+cp -rf data/stdsounds{,.soundspec} $RPM_BUILD_ROOT%{_datadir}/%{name}
+cp -f freeland.tilespec $RPM_BUILD_ROOT%{_datadir}/%{name}
+cp -rf freeland $RPM_BUILD_ROOT%{_datadir}/%{name}
-install %{SOURCE1} %{SOURCE2} $RPM_BUILD_ROOT%{_applnkdir}/Games/Strategy
-install %{SOURCE3} $RPM_BUILD_ROOT%{_pixmapsdir}
-install %{SOURCE5} $RPM_BUILD_ROOT%{_datadir}/freeciv/stdsounds.soundspec
-cp -ar stdsounds $RPM_BUILD_ROOT%{_datadir}/freeciv
+rm -rf $RPM_BUILD_ROOT%{_datadir}/locale/no
+rm -f $RPM_BUILD_ROOT%{_sysconfdir}/ggz.modules
+
+%if %{with ggz_server}
+install -d $RPM_BUILD_ROOT%{_sysconfdir}/ggzd/{games,rooms}
+install data/civserver.dsc $RPM_BUILD_ROOT%{_sysconfdir}/ggzd/games/civserver.dsc
+install data/civserver.room $RPM_BUILD_ROOT%{_sysconfdir}/ggzd/rooms/civserver.room
+%endif
%find_lang %{name}
%files -f %{name}.lang
%defattr(644,root,root,755)
%doc AUTHORS README ChangeLog NEWS
-%attr(755,root,root) %{_bindir}/*
-%{_datadir}/freeciv
-%{_applnkdir}/Games/Strategy/*
%{_pixmapsdir}/*
+%dir %{_datadir}/%{name}
+%{_datadir}/%{name}/helpdata.txt
+
+%files server
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/civserver
+%{_desktopdir}/%{name}-server.desktop
+%{_datadir}/%{name}/civ1
+%{_datadir}/%{name}/civ2
+%{_datadir}/%{name}/default
+%{_datadir}/%{name}/nation
+%{_datadir}/%{name}/scenario
+%{_datadir}/%{name}/*.serv
+%{_mandir}/man6/civserver.6*
+%{?with_ggz_server:%{_sysconfdir}/ggzd/games/civserver.dsc}
+%{?with_ggz_server:%{_sysconfdir}/ggzd/rooms/civserver.room}
+
+%files client
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/civclient
+%attr(755,root,root) %{_bindir}/civmanual
+%{_desktopdir}/%{name}-client.desktop
+%{_datadir}/%{name}/*.*spec
+%{_datadir}/%{name}/amplio
+%{_datadir}/%{name}/buildings
+%{_datadir}/%{name}/flags
+%{_datadir}/%{name}/freeciv.rc*
+%{_datadir}/%{name}/freeland
+%{_datadir}/%{name}/hex2t
+%{_datadir}/%{name}/isophex
+%{_datadir}/%{name}/isotrident
+%{_datadir}/%{name}/misc
+%{_datadir}/%{name}/stdsounds
+%{_datadir}/%{name}/themes
+%{_datadir}/%{name}/trident
+%{_datadir}/%{name}/wonders
+%{_mandir}/man6/civclient.6*
+%{_iconsdir}/hicolor/*/apps/*