Merge branch 'jc/web-blame'
[git/jnareb-git/bp-gitweb.git] / git.spec.in
blob83268fc9d9e3ab63920b5ec4a5ffd71e8dd11b0d
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, 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, rcs, curl, less, openssh-clients, python >= 2.3, 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 -n gitk
67 Summary: Git revision tree visualiser ('gitk')
68 Group: Development/Tools
69 Requires: git-core = %{version}-%{release}, tk >= 8.4
70 %description -n gitk
71 Git revision tree visualiser ('gitk')
73 %package -n perl-Git
74 Summary: Perl interface to Git
75 Group: Development/Libraries
76 Requires: git-core = %{version}-%{release}
77 Requires: perl(:MODULE_COMPAT_%(eval "`%{__perl} -V:version`"; echo $version))
78 BuildRequires: perl(Error)
80 %description -n perl-Git
81 Perl interface to Git
83 %prep
84 %setup -q
86 %build
87 make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" WITH_OWN_SUBPROCESS_PY=YesPlease \
88 prefix=%{_prefix} all %{!?_without_docs: doc}
90 %install
91 rm -rf $RPM_BUILD_ROOT
92 make %{_smp_mflags} DESTDIR=$RPM_BUILD_ROOT WITH_OWN_SUBPROCESS_PY=YesPlease \
93 prefix=%{_prefix} mandir=%{_mandir} INSTALLDIRS=vendor \
94 install %{!?_without_docs: install-doc}
95 find $RPM_BUILD_ROOT -type f -name .packlist -exec rm -f {} ';'
96 find $RPM_BUILD_ROOT -type f -name '*.bs' -empty -exec rm -f {} ';'
97 find $RPM_BUILD_ROOT -type f -name perllocal.pod -exec rm -f {} ';'
99 (find $RPM_BUILD_ROOT%{_bindir} -type f | grep -vE "archimport|svn|cvs|email|gitk" | sed -e s@^$RPM_BUILD_ROOT@@) > bin-man-doc-files
100 (find $RPM_BUILD_ROOT%{perl_vendorlib} -type f | sed -e s@^$RPM_BUILD_ROOT@@) >> perl-files
101 %if %{!?_without_docs:1}0
102 (find $RPM_BUILD_ROOT%{_mandir} $RPM_BUILD_ROOT/Documentation -type f | grep -vE "archimport|svn|git-cvs|email|gitk" | sed -e s@^$RPM_BUILD_ROOT@@ -e 's/$/*/' ) >> bin-man-doc-files
103 %else
104 rm -rf $RPM_BUILD_ROOT%{_mandir}
105 %endif
107 %clean
108 rm -rf $RPM_BUILD_ROOT
110 %files
111 # These are no files in the root package
113 %files svn
114 %defattr(-,root,root)
115 %{_bindir}/*svn*
116 %doc Documentation/*svn*.txt
117 %{!?_without_docs: %{_mandir}/man1/*svn*.1*}
118 %{!?_without_docs: %doc Documentation/*svn*.html }
120 %files cvs
121 %defattr(-,root,root)
122 %doc Documentation/*git-cvs*.txt
123 %{_bindir}/*cvs*
124 %{!?_without_docs: %{_mandir}/man1/*cvs*.1*}
125 %{!?_without_docs: %doc Documentation/*git-cvs*.html }
127 %files arch
128 %defattr(-,root,root)
129 %doc Documentation/git-archimport.txt
130 %{_bindir}/git-archimport
131 %{!?_without_docs: %{_mandir}/man1/git-archimport.1*}
132 %{!?_without_docs: %doc Documentation/git-archimport.html }
134 %files email
135 %defattr(-,root,root)
136 %doc Documentation/*email*.txt
137 %{_bindir}/*email*
138 %{!?_without_docs: %{_mandir}/man1/*email*.1*}
139 %{!?_without_docs: %doc Documentation/*email*.html }
141 %files -n gitk
142 %defattr(-,root,root)
143 %doc Documentation/*gitk*.txt
144 %{_bindir}/*gitk*
145 %{!?_without_docs: %{_mandir}/man1/*gitk*.1*}
146 %{!?_without_docs: %doc Documentation/*gitk*.html }
148 %files -n perl-Git -f perl-files
149 %defattr(-,root,root)
151 %files core -f bin-man-doc-files
152 %defattr(-,root,root)
153 %{_datadir}/git-core/
154 %doc README COPYING Documentation/*.txt
155 %{!?_without_docs: %doc Documentation/*.html }
157 %changelog
158 * Mon Nov 14 2005 H. Peter Anvin <hpa@zytor.com> 0.99.9j-1
159 - Change subpackage names to git-<name> instead of git-core-<name>
160 - Create empty root package which brings in all subpackages
161 - Rename git-tk -> gitk
163 * Thu Nov 10 2005 Chris Wright <chrisw@osdl.org> 0.99.9g-1
164 - zlib dependency fix
165 - Minor cleanups from split
166 - Move arch import to separate package as well
168 * Tue Sep 27 2005 Jim Radford <radford@blackbean.org>
169 - Move programs with non-standard dependencies (svn, cvs, email)
170 into separate packages
172 * Tue Sep 27 2005 H. Peter Anvin <hpa@zytor.com>
173 - parallelize build
174 - COPTS -> CFLAGS
176 * Fri Sep 16 2005 Chris Wright <chrisw@osdl.org> 0.99.6-1
177 - update to 0.99.6
179 * Fri Sep 16 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
180 - Linus noticed that less is required, added to the dependencies
182 * Sun Sep 11 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
183 - Updated dependencies
184 - Don't assume manpages are gzipped
186 * Thu Aug 18 2005 Chris Wright <chrisw@osdl.org> 0.99.4-4
187 - drop sh_utils, sh-utils, diffutils, mktemp, and openssl Requires
188 - use RPM_OPT_FLAGS in spec file, drop patch0
190 * Wed Aug 17 2005 Tom "spot" Callaway <tcallawa@redhat.com> 0.99.4-3
191 - use dist tag to differentiate between branches
192 - use rpm optflags by default (patch0)
193 - own %{_datadir}/git-core/
195 * Mon Aug 15 2005 Chris Wright <chrisw@osdl.org>
196 - update spec file to fix Buildroot, Requires, and drop Vendor
198 * Sun Aug 07 2005 Horst H. von Brand <vonbrand@inf.utfsm.cl>
199 - Redid the description
200 - Cut overlong make line, loosened changelog a bit
201 - I think Junio (or perhaps OSDL?) should be vendor...
203 * Thu Jul 14 2005 Eric Biederman <ebiederm@xmission.com>
204 - Add the man pages, and the --without docs build option
206 * Wed Jul 7 2005 Chris Wright <chris@osdl.org>
207 - initial git spec file