git-gc: run pack-refs by default unless the repo is bare
[git/gitweb.git] / git.spec.in
blobffab6bbfd44fe2a745840869252fbb2f5254b07b
1 # Pass --without docs to rpmbuild if you don't want the documentation
2 Name: git
3 Version: @@VERSION@@
4 Release: 1%{?dist}
5 Summary: Git core and tools
6 License: GPL
7 Group: Development/Tools
8 URL: http://kernel.org/pub/software/scm/git/
9 Source: http://kernel.org/pub/software/scm/git/%{name}-%{version}.tar.gz
10 BuildRequires: zlib-devel >= 1.2, openssl-devel, curl-devel, expat-devel %{!?_without_docs:, xmlto, asciidoc > 6.0.3}
11 BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
12 Requires: git-core, git-svn, git-cvs, git-arch, git-email, gitk, git-gui, perl-Git
14 %description
15 This is a stupid (but extremely fast) directory content manager. It
16 doesn't do a whole lot, but what it _does_ do is track directory
17 contents efficiently. It is intended to be the base of an efficient,
18 distributed source code management system. This package includes
19 rudimentary tools that can be used as a SCM, but you should look
20 elsewhere for tools for ordinary humans layered on top of this.
22 This is a dummy package which brings in all subpackages.
24 %package core
25 Summary: Core git tools
26 Group: Development/Tools
27 Requires: zlib >= 1.2, rsync, curl, less, openssh-clients, expat
28 %description core
29 This is a stupid (but extremely fast) directory content manager. It
30 doesn't do a whole lot, but what it _does_ do is track directory
31 contents efficiently. It is intended to be the base of an efficient,
32 distributed source code management system. This package includes
33 rudimentary tools that can be used as a SCM, but you should look
34 elsewhere for tools for ordinary humans layered on top of this.
36 These are the core tools with minimal dependencies.
38 %package svn
39 Summary: Git tools for importing Subversion repositories
40 Group: Development/Tools
41 Requires: git-core = %{version}-%{release}, subversion
42 %description svn
43 Git tools for importing Subversion repositories.
45 %package cvs
46 Summary: Git tools for importing CVS repositories
47 Group: Development/Tools
48 Requires: git-core = %{version}-%{release}, cvs, cvsps
49 %description cvs
50 Git tools for importing CVS repositories.
52 %package arch
53 Summary: Git tools for importing Arch repositories
54 Group: Development/Tools
55 Requires: git-core = %{version}-%{release}, tla
56 %description arch
57 Git tools for importing Arch repositories.
59 %package email
60 Summary: Git tools for sending email
61 Group: Development/Tools
62 Requires: git-core = %{version}-%{release}
63 %description email
64 Git tools for sending email.
66 %package gui
67 Summary: Git GUI tool
68 Group: Development/Tools
69 Requires: git-core = %{version}-%{release}, tk >= 8.4
70 %description gui
71 Git GUI tool
73 %package -n gitk
74 Summary: Git revision tree visualiser ('gitk')
75 Group: Development/Tools
76 Requires: git-core = %{version}-%{release}, tk >= 8.4
77 %description -n gitk
78 Git revision tree visualiser ('gitk')
80 %package -n perl-Git
81 Summary: Perl interface to Git
82 Group: Development/Libraries
83 Requires: git-core = %{version}-%{release}
84 Requires: perl(:MODULE_COMPAT_%(eval "`%{__perl} -V:version`"; echo $version))
85 BuildRequires: perl(Error)
87 %description -n perl-Git
88 Perl interface to Git
90 %prep
91 %setup -q
93 %build
94 make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" WITH_OWN_SUBPROCESS_PY=YesPlease \
95 prefix=%{_prefix} all %{!?_without_docs: doc}
97 %install
98 rm -rf $RPM_BUILD_ROOT
99 make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" DESTDIR=$RPM_BUILD_ROOT \
100 WITH_OWN_SUBPROCESS_PY=YesPlease \
101 prefix=%{_prefix} mandir=%{_mandir} INSTALLDIRS=vendor \
102 install %{!?_without_docs: install-doc}
103 find $RPM_BUILD_ROOT -type f -name .packlist -exec rm -f {} ';'
104 find $RPM_BUILD_ROOT -type f -name '*.bs' -empty -exec rm -f {} ';'
105 find $RPM_BUILD_ROOT -type f -name perllocal.pod -exec rm -f {} ';'
107 (find $RPM_BUILD_ROOT%{_bindir} -type f | grep -vE "archimport|svn|cvs|email|gitk|git-gui|git-citool" | sed -e s@^$RPM_BUILD_ROOT@@) > bin-man-doc-files
108 (find $RPM_BUILD_ROOT%{perl_vendorlib} -type f | sed -e s@^$RPM_BUILD_ROOT@@) >> perl-files
109 %if %{!?_without_docs:1}0
110 (find $RPM_BUILD_ROOT%{_mandir} $RPM_BUILD_ROOT/Documentation -type f | grep -vE "archimport|svn|git-cvs|email|gitk|git-gui|git-citool" | sed -e s@^$RPM_BUILD_ROOT@@ -e 's/$/*/' ) >> bin-man-doc-files
111 %else
112 rm -rf $RPM_BUILD_ROOT%{_mandir}
113 %endif
115 %clean
116 rm -rf $RPM_BUILD_ROOT
118 %files
119 # These are no files in the root package
121 %files svn
122 %defattr(-,root,root)
123 %{_bindir}/*svn*
124 %doc Documentation/*svn*.txt
125 %{!?_without_docs: %{_mandir}/man1/*svn*.1*}
126 %{!?_without_docs: %doc Documentation/*svn*.html }
128 %files cvs
129 %defattr(-,root,root)
130 %doc Documentation/*git-cvs*.txt
131 %{_bindir}/*cvs*
132 %{!?_without_docs: %{_mandir}/man1/*cvs*.1*}
133 %{!?_without_docs: %doc Documentation/*git-cvs*.html }
135 %files arch
136 %defattr(-,root,root)
137 %doc Documentation/git-archimport.txt
138 %{_bindir}/git-archimport
139 %{!?_without_docs: %{_mandir}/man1/git-archimport.1*}
140 %{!?_without_docs: %doc Documentation/git-archimport.html }
142 %files email
143 %defattr(-,root,root)
144 %doc Documentation/*email*.txt
145 %{_bindir}/*email*
146 %{!?_without_docs: %{_mandir}/man1/*email*.1*}
147 %{!?_without_docs: %doc Documentation/*email*.html }
149 %files gui
150 %defattr(-,root,root)
151 %{_bindir}/git-gui
152 %{_bindir}/git-citool
153 # Not Yet...
154 # %{!?_without_docs: %{_mandir}/man1/git-gui.1}
155 # %{!?_without_docs: %doc Documentation/git-gui.html}
156 # %{!?_without_docs: %{_mandir}/man1/git-citool.1}
157 # %{!?_without_docs: %doc Documentation/git-citool.html}
159 %files -n gitk
160 %defattr(-,root,root)
161 %doc Documentation/*gitk*.txt
162 %{_bindir}/*gitk*
163 %{!?_without_docs: %{_mandir}/man1/*gitk*.1*}
164 %{!?_without_docs: %doc Documentation/*gitk*.html }
166 %files -n perl-Git -f perl-files
167 %defattr(-,root,root)
169 %files core -f bin-man-doc-files
170 %defattr(-,root,root)
171 %{_datadir}/git-core/
172 %doc README COPYING Documentation/*.txt
173 %{!?_without_docs: %doc Documentation/*.html }
175 %changelog
176 * Mon Feb 12 2007 Junio C Hamano <junkio@cox.net>
177 - Add git-gui and git-citool.
179 * Mon Nov 14 2005 H. Peter Anvin <hpa@zytor.com> 0.99.9j-1
180 - Change subpackage names to git-<name> instead of git-core-<name>
181 - Create empty root package which brings in all subpackages
182 - Rename git-tk -> gitk
184 * Thu Nov 10 2005 Chris Wright <chrisw@osdl.org> 0.99.9g-1
185 - zlib dependency fix
186 - Minor cleanups from split
187 - Move arch import to separate package as well
189 * Tue Sep 27 2005 Jim Radford <radford@blackbean.org>
190 - Move programs with non-standard dependencies (svn, cvs, email)
191 into separate packages
193 * Tue Sep 27 2005 H. Peter Anvin <hpa@zytor.com>
194 - parallelize build
195 - COPTS -> CFLAGS
197 * Fri Sep 16 2005 Chris Wright <chrisw@osdl.org> 0.99.6-1
198 - update to 0.99.6
200 * Fri Sep 16 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
201 - Linus noticed that less is required, added to the dependencies
203 * Sun Sep 11 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
204 - Updated dependencies
205 - Don't assume manpages are gzipped
207 * Thu Aug 18 2005 Chris Wright <chrisw@osdl.org> 0.99.4-4
208 - drop sh_utils, sh-utils, diffutils, mktemp, and openssl Requires
209 - use RPM_OPT_FLAGS in spec file, drop patch0
211 * Wed Aug 17 2005 Tom "spot" Callaway <tcallawa@redhat.com> 0.99.4-3
212 - use dist tag to differentiate between branches
213 - use rpm optflags by default (patch0)
214 - own %{_datadir}/git-core/
216 * Mon Aug 15 2005 Chris Wright <chrisw@osdl.org>
217 - update spec file to fix Buildroot, Requires, and drop Vendor
219 * Sun Aug 07 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
220 - Redid the description
221 - Cut overlong make line, loosened changelog a bit
222 - I think Junio (or perhaps OSDL?) should be vendor...
224 * Thu Jul 14 2005 Eric Biederman <ebiederm@xmission.com>
225 - Add the man pages, and the --without docs build option
227 * Wed Jul 7 2005 Chris Wright <chris@osdl.org>
228 - initial git spec file