X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=git-core.spec;h=ca453a9a3b84ba305a061a2e21203ed62e24e494;hb=570f1092d13a6a878c2d6b0893ad5c340c746d13;hp=46e0cdb6f2f15a14e48b6641f8d2f7a4b5bf0536;hpb=785b167ddf284224a8828e38aad391f6a156b45c;p=packages%2Fgit-core.git diff --git a/git-core.spec b/git-core.spec index 46e0cdb..ca453a9 100644 --- a/git-core.spec +++ b/git-core.spec @@ -1,44 +1,61 @@ # # 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 +Version: 1.6.4.3 Release: 1 License: GPL v2 Group: Development/Tools Source0: http://www.kernel.org/pub/software/scm/git/git-%{version}.tar.bz2 -# Source0-md5: 798e5784670e0a3e0daaea048e60851d +# Source0-md5: 4af70ff9b8f209704059f7ef96127236 Source1: %{name}-gitweb.conf Source2: %{name}-gitweb-httpd.conf -URL: http://git.or.cz/ -BuildRequires: asciidoc +Source3: %{name}.sysconfig +Source4: %{name}.inet +Source5: %{name}.init +URL: http://git-scm.com/ BuildRequires: autoconf BuildRequires: automake BuildRequires: curl-devel +BuildRequires: docbook-dtd45-xml 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/cvsnt client so enforce pure cvs here +BuildRequires: cvs-gnu-client < 1.13 +BuildRequires: cvs-gnu-client >= 1.12 +BuildRequires: pdksh >= 5.2.14-46 +%endif Requires: coreutils -Requires: curl Requires: diffutils Requires: findutils Requires: grep Requires: openssh-clients Requires: perl-Error -Requires: rcs Requires: sed +Suggests: git-core-cvs +Suggests: git-core-svn 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} @@ -63,21 +80,59 @@ contents efficiently. %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 @@ -97,23 +152,22 @@ Requires: %{name} = %{version}-%{release} Requires: tk %description gitk -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. +gitk 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 gitk -l pl.UTF-8 -Wyświetla zmiany w repozytorium lub wybranym zbiorze commitów. +gitk 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. +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 +Z historycznego punktu widzenia 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 gitweb @@ -129,10 +183,79 @@ This package provides a web interface for browsing git repositories. %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 svn +Summary: Subversion support for Git +Summary(pl.UTF-8): Obsługa Subversion dla Git +Group: Development/Tools +Requires: %{name} = %{version}-%{release} + +%description svn +Subversion support for Git. + +%description svn -l pl.UTF-8 +Obsługa Subversion dla Git. + +%package cvs +Summary: CVS support for Git +Summary(pl.UTF-8): Obsługa CVS dla Git +Group: Development/Tools +Requires: %{name} = %{version}-%{release} +Requires: cvsps >= 2.1-2 +Requires: rcs + +%description cvs +CVS support for Git. + +%description cvs -l pl.UTF-8 +Obsługa CVS dla Git. + %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 @@ -157,18 +280,17 @@ totally trivial to do over the generic command interface. %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. @@ -193,34 +315,50 @@ Ta wtyczka dostarcza podświetlanie składni dla treści commitów gita. 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 xdiff/*.h $RPM_BUILD_ROOT%{_includedir}/%{name}/xdiff install libgit.a $RPM_BUILD_ROOT%{_libdir} +install xdiff/lib.a $RPM_BUILD_ROOT%{_libdir}/libgit_xdiff.a # bash completion install contrib/completion/git-completion.bash $RPM_BUILD_ROOT%{_sysconfdir}/bash_completion.d # vim syntax -install contrib/vim/syntax/gitcommit.vim $RPM_BUILD_ROOT%{_datadir}/vim/vimfiles/syntax +cat > $RPM_BUILD_ROOT/%{_datadir}/vim/vimfiles/syntax/gitcommit.vim << 'EOF' +autocmd BufNewFile,BufRead *.git/COMMIT_EDITMSG setf gitcommit +autocmd BufNewFile,BufRead *.git/config,.gitconfig setf gitconfig +autocmd BufNewFile,BufRead git-rebase-todo setf gitrebase +autocmd BufNewFile,BufRead .msg.[0-9]* + \ if getline(1) =~ '^From.*# This line is ignored.$' | + \ setf gitsendemail | + \ endif +autocmd BufNewFile,BufRead *.git/** + \ if getline(1) =~ '^\x\{40\}\>\|^ref: ' | + \ setf git | + \ endif +EOF # gitweb install gitweb/*.css gitweb/*.png $RPM_BUILD_ROOT%{appdir} @@ -229,13 +367,45 @@ install %{SOURCE1} $RPM_BUILD_ROOT%{webappdir}/gitweb.conf 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 + +# paths cleanup +sed -e 's,@libdir@,%{_libdir},g' -i $RPM_BUILD_ROOT/etc/rc.d/init.d/git-daemon +sed -e 's,@libdir@,%{_libdir},g' -i $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/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} @@ -250,28 +420,67 @@ rm -rf $RPM_BUILD_ROOT %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-svn.1* +%exclude %{_mandir}/man1/git-cvs*.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/gitdiffcore.7* +%{_mandir}/man7/gitglossary.7* +%{_mandir}/man7/gittutorial-2.7* +%{_mandir}/man7/gittutorial.7* +%{_mandir}/man7/gitworkflows.7* +%endif +%attr(755,root,root) %{_bindir}/git +%attr(755,root,root) %{_bindir}/git-* +%dir %{_libdir}/%{name} +%attr(755,root,root) %{_libdir}/%{name}/*-* +%attr(755,root,root) %{_libdir}/%{name}/git +%exclude %{_libdir}/%{name}/git-gui +%exclude %{_libdir}/%{name}/git-svn +%exclude %{_libdir}/%{name}/git-cvs* %{_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 +%{_libdir}/libgit_xdiff.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(ru) %{_datadir}/gitk/lib/msgs/ru.msg +%lang(sv) %{_datadir}/gitk/lib/msgs/sv.msg %files gitweb %defattr(644,root,root,755) @@ -283,6 +492,46 @@ rm -rf $RPM_BUILD_ROOT %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) %{_libdir}/%{name}/git-gui +%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(nb) %{_datadir}/git-gui/lib/msgs/nb.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 svn +%defattr(644,root,root,755) +%attr(755,root,root) %{_libdir}/%{name}/git-svn +%if %{with doc} +%{_mandir}/man1/git-svn.1* +%endif + +%files cvs +%defattr(644,root,root,755) +%attr(755,root,root) %{_libdir}/%{name}/git-cvs* +%if %{with doc} +%{_mandir}/man1/git-cvs*.1* +%{_mandir}/man7/gitcvs-migration.7* +%endif + %files -n bash-completion-git %defattr(644,root,root,755) %{_sysconfdir}/bash_completion.d/*