#
# Conditional build:
%bcond_without tests # don't perform make test
+%bcond_without doc # skip building/packaging docs/manuals (takes some time)
#
%include /usr/lib/rpm/macros.perl
Summary: The stupid content tracker
Summary(pl.UTF-8): Prymitywne narzędzie do śledzenia treści
Name: git-core
-Version: 1.5.3.1
-Release: 1
+Version: 1.5.6
+Release: 3
License: GPL v2
Group: Development/Tools
Source0: http://www.kernel.org/pub/software/scm/git/git-%{version}.tar.bz2
-# Source0-md5: 3213bc24c86e3741bae3607192f3ee7d
+# Source0-md5: 76c4efaaa5470a5385e22d99349a97b3
Source1: %{name}-gitweb.conf
Source2: %{name}-gitweb-httpd.conf
+Source3: %{name}.sysconfig
+Source4: %{name}.inet
+Source5: %{name}.init
+Patch0: %{name}-bashizm.patch
URL: http://git.or.cz/
-BuildRequires: asciidoc
BuildRequires: autoconf
BuildRequires: automake
BuildRequires: curl-devel
BuildRequires: expat-devel
+BuildRequires: gettext-devel
BuildRequires: openssl-devel
BuildRequires: perl-Error
BuildRequires: perl-base
BuildRequires: python
BuildRequires: rpm-perlprov >= 4.1-13
BuildRequires: rpmbuild(macros) >= 1.264
-BuildRequires: xmlto
BuildRequires: zlib-devel
+%if %{with doc}
+BuildRequires: asciidoc >= 7.1.2-3
+BuildRequires: xmlto
+%endif
+%if %{with tests}
+# tests failed sometimes when using nserver client 1.11(?)
+BuildRequires: cvs-client >= 1.12
+BuildRequires: pdksh >= 5.2.14-46
+%endif
Requires: coreutils
-Requires: curl
+Requires: cvsps >= 2.1-2
Requires: diffutils
Requires: findutils
Requires: grep
Requires: sed
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
+# html docs have links to txt files
+%define _noautocompressdoc *.txt
+
%define webapp gitweb
%define webappdir %{_sysconfdir}/webapps/%{webapp}
%define appdir %{_datadir}/%{webapp}
%description -l pl.UTF-8
"git" może oznaczać cokolwiek, w zależności od nastroju.
-- losową kombinację trzech liter, która jest wymawialna i
- właściwie nie używana przez żadne popularne polecenie uniksowe.
- Fakt, że jest to błędna pisownia słowa "get" może mieć lub nie
- mieć znaczenia.
-- głupi, pogardliwy, prosty. Można wybrać ze słownika slangu.
-- "global information tracker" (narzędzie do globalnego śledzenia
- informacji) - jeśli jesteśmy w dobrym nastroju i git akurat działa.
- Anioły śpiewają, a światło niespodziewanie wypełnia pokój.
-- "goddamn idiotic truckload of sh*t" (przeklęty idiotyczny ładunek
- g*) - kiedy się zepsuje.
+ - losową kombinację trzech liter, która jest wymawialna i właściwie
+ nie używana przez żadne popularne polecenie uniksowe. Fakt, że jest to
+ błędna pisownia słowa "get" może mieć lub nie mieć znaczenia.
+ - głupi, pogardliwy, prosty. Można wybrać ze słownika slangu.
+ - "global information tracker" (narzędzie do globalnego śledzenia
+ informacji) - jeśli jesteśmy w dobrym nastroju i git akurat działa.
+ Anioły śpiewają, a światło niespodziewanie wypełnia pokój.
+ - "goddamn idiotic truckload of sh*t" (przeklęty idiotyczny ładunek
+ g*) - kiedy się zepsuje.
Jest to prymitywny (ale bardzo szybki) zarządca treści słownikowej.
Nie robi wiele, ale to, co "robi", to wydajne śledzenie zawartości
katalogu.
+%package daemon-inetd
+Summary: Files necessary to run git-daemon as an inetd service
+Summary(pl.UTF-8): Pliki niezbędne do uruchomienia git-daemona w trybie usługi inetd
+Group: Networking/Daemons
+Requires: %{name} = %{version}-%{release}
+Requires: setup >= 2.4.11-1
+Provides: git-core-daemon
+Obsoletes: git-core-daemon
+Obsoletes: git-core-daemon-standalone
+
+%description daemon-inetd
+Git-daemon is a really simple TCP git daemon that can serve git
+repositories. This package provides all necessarry files to run
+git-daemon as an inetd service.
+
+%description daemon-inetd -l pl.UTF-8
+Git-daemon to prosty demon git korzystający z protokołu TCP do
+udostępniania repozytoriów git. Ten pakiet dostarcza pliki potrzebne
+do uruchomienia git-demona w trybie usługi inetd.
+
+%package daemon-standalone
+Summary: Files necessary to run git-daemon as a standalone service
+Summary(pl.UTF-8): Pliki niezbędne do uruchomienia git-daemona w trybie usługi samodzielnej
+Group: Networking/Daemons
+Requires: %{name} = %{version}-%{release}
+Provides: git-core-daemon
+Obsoletes: git-core-daemon
+Obsoletes: git-core-daemon-inetd
+
+%description daemon-standalone
+Git-daemon is a really simple TCP git daemon that can serve git
+repositories. This package provides all necessarry files to run
+git-daemon as an standalone service.
+
+%description daemon-standalone -l pl.UTF-8
+Git-daemon to prosty demon git korzystający z protokołu TCP do
+udostępniania repozytoriów git. Ten pakiet dostarcza pliki potrzebne
+do uruchomienia git-daemona w trybie usługi samodzielnej.
+
%package devel
Summary: Header files for git-core
Summary(pl.UTF-8): Pliki nagłówkowe dla git-core
into the main git repository.
%description gitk -l pl.UTF-8
-Wyświetla zmiany w repozytorium lub wybranym zbiorze commitów.
-Oznacza to wizualizację grafu commitów, wyświetlanie informacji
-związanych z każdym z commitów oraz listę plików dla każdej
-rewizji.
+Wyświetla zmiany w repozytorium lub wybranym zbiorze commitów. Oznacza
+to wizualizację grafu commitów, wyświetlanie informacji związanych z
+każdym z commitów oraz listę plików dla każdej rewizji.
Z punktu widzenia historii, gitk był pierwszą przeglądarką
-repozytorium git. Napisany jest w Tcl/Tk i początkowo był rozwijany
-w osobnym repozytorium, ale z czasem został włączony do głównego
+repozytorium git. Napisany jest w Tcl/Tk i początkowo był rozwijany w
+osobnym repozytorium, ale z czasem został włączony do głównego
repozytorium gita.
%package gitweb
%description gitweb -l pl.UTF-8
Pakiet ten dostarcza interfejs WWW do przeglądania repozytoriów gita.
+%package gitview
+Summary: A GTK+ based repository browser for git
+Summary(pl.UTF-8): Oparta na GTK+ przeglądarka repozytorium gita
+Group: Development/Tools
+Requires: %{name} = %{version}-%{release}
+Requires: python >= 1:2.4
+Requires: python-pycairo >= 1.0
+Requires: python-pygobject
+Requires: python-pygtk-gtk >= 2:2.8
+Suggests: python-gnome-desktop-gtksourceview
+
+%description gitview
+A GTK+ based repository browser for git.
+
+%description gitview -l pl.UTF-8
+Oparta na GTK+ przeglądarka repozytorium gita.
+
+%package gui
+Summary: Tcl/Tk interface to the Git version control system
+Summary(pl.UTF-8): Napisany w Tcl/Tk interfejs do systemu kontroli wersji Git
+Group: Development/Tools
+Requires: %{name} = %{version}-%{release}
+Requires: tk
+
+%description gui
+Displays changes in a repository or a selected set of commits. This
+includes visualizing the commit graph, showing information related to
+each commit, and the files in the trees of each revision.
+
+Historically, gitk was the first repository browser. It's written in
+Tcl/Tk and started off in a separate repository but was later merged
+into the main git repository.
+
+%description gui -l pl.UTF-8
+Wyświetla zmiany w repozytorium lub wybranym zbiorze commitów. Oznacza
+to wizualizację grafu commitów, wyświetlanie informacji związanych z
+każdym z commitów oraz listę plików dla każdej rewizji.
+
+Z punktu widzenia historii, gitk był pierwszą przeglądarką
+repozytorium git. Napisany jest w Tcl/Tk i początkowo był rozwijany w
+osobnym repozytorium, ale z czasem został włączony do głównego
+repozytorium gita.
+
%package -n bash-completion-git
Summary: bash-completion for git
Summary(pl.UTF-8): bashowe uzupełnianie nazw dla gita
-Group: Applications/Shell
+Group: Applications/Shells
Requires: bash-completion
%description -n bash-completion-git
%description -n perl-Git -l pl.UTF-8
Ten moduł umożliwia skryptom Perla współpracę z systemem kontroli
-wersji Git. W łatwy i dobrze przetestowany sposób pozwala
-wywoływać dowolne polecenia Gita; w przyszłości interfejs
-udostępni także specjalne metody do łatwego wykonywania operacji
-nietrywialnych do wykonania przy użyciu ogólnego interfejsu
-poleceń.
+wersji Git. W łatwy i dobrze przetestowany sposób pozwala wywoływać
+dowolne polecenia Gita; w przyszłości interfejs udostępni także
+specjalne metody do łatwego wykonywania operacji nietrywialnych do
+wykonania przy użyciu ogólnego interfejsu poleceń.
%package -n vim-syntax-gitcommit
Summary: Vim syntax: gitcommit
Summary(pl.UTF-8): Składnia dla Vima: gitcommit
Group: Applications/Editors/Vim
# for _vimdatadir existence
-Requires: vim >= 4:6.3.058-3
+Requires: vim-rt >= 4:6.3.058-3
%description -n vim-syntax-gitcommit
This plugin provides syntax highlighting for git's commit messages.
%prep
%setup -q -n git-%{version}
+%patch0 -p1
%build
%{__aclocal}
GITWEB_LOGO="/gitweb/git-logo.png" \
GITWEB_FAVICON="/gitweb/git-favicon.png"
-%{__make} -C Documentation
+%{?with_doc:%{__make} -C Documentation}
%{?with_tests:%{__make} test}
%install
rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{_includedir}/%{name}/xdiff,%{_sharedstatedir}/git}
+install -d $RPM_BUILD_ROOT{%{_includedir}/%{name}/xdiff,%{_localstatedir}/lib/git}
install -d $RPM_BUILD_ROOT{%{appdir},%{cgibindir},%{webappdir}}
install -d $RPM_BUILD_ROOT%{_datadir}/vim/vimfiles/syntax
install -d $RPM_BUILD_ROOT%{_sysconfdir}/bash_completion.d
+install -d $RPM_BUILD_ROOT/etc/{sysconfig/rc-inetd,rc.d/init.d}
%{__make} install \
INSTALLDIRS=vendor \
DESTDIR=$RPM_BUILD_ROOT
+%if %{with doc}
%{__make} -C Documentation install \
DESTDIR=$RPM_BUILD_ROOT
+%endif
# header files and lib
install *.h $RPM_BUILD_ROOT%{_includedir}/%{name}
install %{SOURCE2} $RPM_BUILD_ROOT%{webappdir}/apache.conf
install %{SOURCE2} $RPM_BUILD_ROOT%{webappdir}/httpd.conf
+# gitview
+install contrib/gitview/gitview $RPM_BUILD_ROOT%{_bindir}
+
+# git-daemon related files
+install %{SOURCE3} $RPM_BUILD_ROOT/etc/sysconfig/git-daemon
+install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/git-daemon
+install %{SOURCE5} $RPM_BUILD_ROOT/etc/rc.d/init.d/git-daemon
+
# remove unneeded files
rm -f $RPM_BUILD_ROOT%{perl_archlib}/perllocal.pod
rm -f $RPM_BUILD_ROOT%{perl_vendorarch}/auto/Git/.packlist
+rm -f $RPM_BUILD_ROOT%{perl_vendorlib}/Error.pm
+rm -f $RPM_BUILD_ROOT%{_mandir}/man3/private-Error.3*
%clean
rm -rf $RPM_BUILD_ROOT
+%post daemon-inetd
+%service -q rc-inetd reload
+
+%postun daemon-inetd
+if [ "$1" = "0" ]; then
+ %service -q rc-inetd reload
+fi
+
+%post daemon-standalone
+/sbin/chkconfig --add git-daemon
+%service git-daemon restart "git-daemon"
+
+%preun daemon-standalone
+if [ "$1" = "0" ]; then
+ %service git-daemon stop
+ /sbin/chkconfig --del git-daemon
+fi
+
%triggerin gitweb -- apache1 < 1.3.37-3, apache1-base
%webapp_register apache %{webapp}
%files
%defattr(644,root,root,755)
-%doc README Documentation/{[!g]*,g[!i]*,git,git[!k]*}.html Documentation/howto Documentation/technical contrib
-%attr(755,root,root) %{_bindir}/git
-%attr(755,root,root) %{_bindir}/git-*
+%doc README contrib
+%if %{with doc}
+%doc Documentation/RelNotes*
+%doc Documentation/*.html Documentation/howto Documentation/technical
%{_mandir}/man1/git-*.1*
+%exclude %{_mandir}/man1/git-gui.1*
+%{_mandir}/man1/git.1*
%{_mandir}/man5/gitattributes.5*
+%{_mandir}/man5/githooks.5*
%{_mandir}/man5/gitignore.5*
%{_mandir}/man5/gitmodules.5*
-%{_mandir}/man7/git.7*
+%{_mandir}/man5/gitrepository-layout.5*
+%{_mandir}/man7/gitcli.7*
+%{_mandir}/man7/gitcore-tutorial.7*
+%{_mandir}/man7/gitcvs-migration.7*
+%{_mandir}/man7/gitdiffcore.7*
+%{_mandir}/man7/gitglossary.7*
+%{_mandir}/man7/gittutorial-2.7*
+%{_mandir}/man7/gittutorial.7*
+%endif
+%attr(755,root,root) %{_bindir}/git
+%attr(755,root,root) %{_bindir}/git-*
+%exclude %{_bindir}/git-gui
%{_datadir}/%{name}
-%{_datadir}/git-gui
-%{_sharedstatedir}/git
+%{_localstatedir}/lib/git
+
+%files daemon-inetd
+%defattr(644,root,root,755)
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/git-daemon
+
+%files daemon-standalone
+%defattr(644,root,root,755)
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/git-daemon
+%attr(754,root, root) /etc/rc.d/init.d/git-daemon
%files devel
%defattr(644,root,root,755)
-%{_includedir}/*
-%{_libdir}/*.a
+%{_includedir}/git-core
+%{_libdir}/libgit.a
%files gitk
%defattr(644,root,root,755)
-%doc Documentation/gitk.html
-%attr(755,root,root) %{_bindir}/gitk
+%if %{with doc}
%{_mandir}/man1/gitk.1*
+%endif
+%attr(755,root,root) %{_bindir}/gitk
+%dir %{_datadir}/gitk
+%dir %{_datadir}/gitk/lib
+%dir %{_datadir}/gitk/lib/msgs
+%lang(de) %{_datadir}/gitk/lib/msgs/de.msg
+%lang(es) %{_datadir}/gitk/lib/msgs/es.msg
+%lang(it) %{_datadir}/gitk/lib/msgs/it.msg
+%lang(sv) %{_datadir}/gitk/lib/msgs/sv.msg
%files gitweb
%defattr(644,root,root,755)
%attr(755,root,root) %{cgibindir}/gitweb.cgi
%{appdir}
+%files gitview
+%defattr(644,root,root,755)
+%doc contrib/gitview/gitview.txt
+%attr(755,root,root) %{_bindir}/gitview
+
+%files gui
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/git-gui
+%{_mandir}/man1/git-gui.1*
+%dir %{_datadir}/git-gui
+%dir %{_datadir}/git-gui/lib
+%dir %{_datadir}/git-gui/lib/msgs
+%{_datadir}/git-gui/lib/git-gui.ico
+%{_datadir}/git-gui/lib/tclIndex
+%{_datadir}/git-gui/lib/*.js
+%{_datadir}/git-gui/lib/*.tcl
+%lang(de) %{_datadir}/git-gui/lib/msgs/de.msg
+%lang(fr) %{_datadir}/git-gui/lib/msgs/fr.msg
+%lang(hu) %{_datadir}/git-gui/lib/msgs/hu.msg
+%lang(it) %{_datadir}/git-gui/lib/msgs/it.msg
+%lang(ja) %{_datadir}/git-gui/lib/msgs/ja.msg
+%lang(ru) %{_datadir}/git-gui/lib/msgs/ru.msg
+%lang(sv) %{_datadir}/git-gui/lib/msgs/sv.msg
+%lang(zh_cn) %{_datadir}/git-gui/lib/msgs/zh_cn.msg
+
%files -n bash-completion-git
%defattr(644,root,root,755)
%{_sysconfdir}/bash_completion.d/*