Blob


1 .\"
2 .\" Copyright (c) 2021 Stefan Sperling
3 .\"
4 .\" Permission to use, copy, modify, and distribute this software for any
5 .\" purpose with or without fee is hereby granted, provided that the above
6 .\" copyright notice and this permission notice appear in all copies.
7 .\"
8 .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 .\"
16 .Dd $Mdocdate$
17 .Dt GOTADMIN 1
18 .Os
19 .Sh NAME
20 .Nm gotadmin
21 .Nd Game of Trees repository administration
22 .Sh SYNOPSIS
23 .Nm
24 .Ar command
25 .Op Fl h
26 .Op Ar arg ...
27 .Sh DESCRIPTION
28 .Nm
29 is the repository maintenance tool for the
30 .Xr got 1
31 version control system.
32 .Pp
33 .Xr got 1
34 stores the history of tracked files in a Git repository, as used
35 by the Git version control system.
36 .Nm
37 provides commands for inspecting and manipulating the on-disk state of
38 Git repositories.
39 The repository format is described in
40 .Xr git-repository 5 .
41 .Pp
42 .Nm
43 provides global and command-specific options.
44 Global options must precede the command name, and are as follows:
45 .Bl -tag -width tenletters
46 .It Fl h
47 Display usage information and exit immediately.
48 .It Fl V , -version
49 Display program version and exit immediately.
50 .El
51 .Pp
52 The commands for
53 .Nm
54 are as follows:
55 .Bl -tag -width checkout
56 .It Cm init Ar repository-path
57 Create a new empty repository at the specified
58 .Ar repository-path .
59 .Pp
60 After
61 .Cm gotadmin init ,
62 the
63 .Cm got import
64 command must be used to populate the empty repository before
65 .Cm got checkout
66 can be used.
67 .It Cm info Op Fl r Ar repository-path
68 Display information about a repository.
69 This includes some configuration settings from
70 .Xr got.conf 5 ,
71 and the number of objects stored in the repository, in packed or
72 loose form, as well as the current on-disk size of these objects.
73 .Pp
74 The options for
75 .Cm gotadmin info
76 are as follows:
77 .Bl -tag -width Ds
78 .It Fl r Ar repository-path
79 Use the repository at the specified path.
80 If not specified, assume the repository is located at or above the current
81 working directory.
82 If this directory is a
83 .Xr got 1
84 work tree, use the repository path associated with this work tree.
85 .El
86 .It Xo
87 .Cm pack
88 .Op Fl aq
89 .Op Fl r Ar repository-path
90 .Op Fl x Ar reference
91 .Op Ar reference ...
92 .Xc
93 Generate a new pack file and a corresponding pack file index.
94 By default, add any loose objects which are reachable via any references
95 to the generated pack file.
96 .Pp
97 If one or more
98 .Ar reference
99 arguments is specified, only add objects which are reachable via the specified
100 references.
101 Each
102 .Ar reference
103 argument may either specify a specific reference or a reference namespace,
104 in which case all references within this namespace will be used.
105 .Pp
106 .Cm gotadmin pack
107 always ignores references in the
108 .Pa refs/got/
109 namespace, effectively treating such references as if they did not refer
110 to any objects.
111 .Pp
112 The options for
113 .Cm gotadmin pack
114 are as follows:
115 .Bl -tag -width Ds
116 .It Fl a
117 Add objects to the generated pack file even if they are already packed
118 in a different pack file.
119 Unless this option is specified, only loose objects will be added.
120 .It Fl q
121 Suppress progress reporting output.
122 .It Fl r Ar repository-path
123 Use the repository at the specified path.
124 If not specified, assume the repository is located at or above the current
125 working directory.
126 If this directory is a
127 .Xr got 1
128 work tree, use the repository path associated with this work tree.
129 .It Fl x Ar reference
130 Exclude objects reachable via the specified
131 .Ar reference
132 from the pack file.
133 The
134 .Ar reference
135 argument may either specify a specific reference or a reference namespace,
136 in which case all references within this namespace will be excluded.
137 The
138 .Fl x
139 option may be specified multiple times to build a list of references to exclude.
140 .Pp
141 Exclusion takes precedence over inclusion.
142 If a reference appears in both the included and excluded lists, it will
143 be excluded.
144 .El
145 .Tg ix
146 .It Cm indexpack Ar packfile-path
147 .Dl Pq alias: Cm ix
148 Create a pack index for the pack file at
149 .Ar packfile-path .
150 .Pp
151 A pack index is required for using the corresponding pack file with
152 .Xr got 1 .
153 Usually, a pack index will be created by commands such as
154 .Cm gotadmin pack
155 or
156 .Cm got fetch
157 as part of regular operation.
158 The
159 .Cm gotadmin indexpack
160 command may be used to recover from a corrupt or missing index.
161 A given pack file will always yield the same bit-identical index.
162 .Pp
163 The provided
164 .Ar packfile-path
165 must be located within the
166 .Pa objects/pack/
167 directory of the repository and should end in
168 .Pa .pack .
169 The filename of the corresponding pack index is equivalent, except
170 that it ends in
171 .Pa .idx .
172 .Tg ls
173 .It Xo
174 .Cm listpack
175 .Op Fl hs
176 .Ar packfile-path
177 .Xc
178 .Dl Pq alias: Cm ls
179 List the contents of the pack file at
180 .Ar packfile-path .
181 .Pp
182 Each object contained in the pack file will be displayed on a single line.
183 The information shown includes the object ID, object type, object offset,
184 and object size.
185 .Pp
186 If a packed object is deltified against another object, the delta base
187 will be shown as well.
188 For offset deltas, the delta base is identified via an offset into the
189 pack file.
190 For reference deltas, the delta base is identified via an object ID.
191 .Pp
192 The provided
193 .Ar packfile-path
194 must be located within the
195 .Pa objects/pack/
196 directory of the repository and should end in
197 .Pa .pack .
198 The corresponding pack index must exist and can be created with
199 .Cm gotadmin indexpack
200 if it is missing.
201 .Pp
202 The options for
203 .Cm gotadmin listpack
204 are as follows:
205 .Bl -tag -width Ds
206 .It Fl h
207 Show object sizes in human-readable form.
208 .It Fl s
209 Display statistics about the pack file after listing objects.
210 This includes the total number of objects stored in the pack file
211 and a break-down of the number of objects per object type.
212 .El
213 .Tg cl
214 .It Xo
215 .Cm cleanup
216 .Op Fl anpq
217 .Op Fl r Ar repository-path
218 .Xc
219 .Dl Pq alias: Cm cl
220 Purge unreferenced loose objects from the repository and display
221 the amount of disk space which has been freed as a result.
222 .Pp
223 Unreferenced objects are present in the repository but cannot be
224 reached via any reference in the entire
225 .Pa refs/
226 namespace.
227 .Pp
228 Loose objects are stored as individual files beneath the repository's
229 .Pa objects/
230 directory,
231 spread across 256 sub-directories named after the 256 possible
232 hexadecimal values of the first byte of an object identifier.
233 .Pp
234 Packed objects stored in pack files under
235 .Pa objects/pack/
236 will not be purged.
237 However, if redundant copies of packed objects exist in loose form,
238 such redundant copies will be purged.
239 .Pp
240 Objects will usually become unreferenced as a result of deleting
241 branches or tags with
242 .Cm got branch -d
243 or
244 .Cm got tag -d .
245 Deleting arbitrary references with
246 .Cm got ref -d
247 may also leave unreferenced objects behind.
248 .Pp
249 In order to determine the set of objects which are referenced, search
250 all references for commit objects and tag objects, and traverse the
251 corresponding tree object hierarchies.
252 Any loose object IDs not encountered during this search are unreferenced
253 and thus subject to removal.
254 Display the number of commits which have been searched to indicate progress.
255 .Pp
256 References in the
257 .Pa refs/got
258 namespace may prevent objects from being purged.
259 This includes references in the
260 .Pa refs/got/worktree
261 namespace created by
262 .Cm got checkout
263 and
264 .Cm got update ,
265 as well as references in the
266 .Pa refs/got/backup
267 namespace created by
268 .Cm got rebase
269 and
270 .Cm got histedit .
271 .Cm gotadmin cleanup
272 will only purge corresponding objects once such references have been
273 deleted with
274 .Cm got ref -d .
275 .Pp
276 Some Git repositories contain pack index files which lack a corresponding
277 pack file, which is an inconsistent repository state.
278 In such cases,
279 .Cm gotadmin cleanup -p -n
280 will display a list of affected pack index files.
281 Whenever possible, the missing pack files should be restored.
282 If restoring missing pack files is not possible, then affected pack index
283 files can be removed with
284 .Cm gotadmin cleanup -p .
285 .Pp
286 The
287 .Dq preciousObjects
288 Git extension is intended to prevent the removal of objects from a repository.
289 .Cm gotadmin cleanup
290 will refuse to operate on repositories where this extension is active.
291 .Pp
292 The options for
293 .Cm gotadmin cleanup
294 are as follows:
295 .Bl -tag -width Ds
296 .It Fl a
297 Delete all loose objects.
298 By default, objects which are newer than an implementation-defined
299 modification timestamp are kept on disk to prevent race conditions
300 with other commands that add new objects to the repository while
301 .Cm gotadmin cleanup
302 is running.
303 .It Fl n
304 Display the usual progress output and summary information but do not actually
305 remove any files from disk.
306 .It Fl p
307 Instead of purging unreferenced loose objects, remove any pack index files
308 which do not have a corresponding pack file.
309 .It Fl q
310 Suppress progress reporting and disk space summary output.
311 .It Fl r Ar repository-path
312 Use the repository at the specified path.
313 If not specified, assume the repository is located at or above the current
314 working directory.
315 If this directory is a
316 .Xr got 1
317 work tree, use the repository path associated with this work tree.
318 .El
319 .El
320 .Sh EXIT STATUS
321 .Ex -std gotadmin
322 .Sh SEE ALSO
323 .Xr got 1 ,
324 .Xr tog 1 ,
325 .Xr git-repository 5 ,
326 .Xr got.conf 5
327 .Sh AUTHORS
328 .An Christian Weisgerber Aq Mt naddy@openbsd.org
329 .An Josh Rickmar Aq Mt jrick@zettaport.com
330 .An Klemens Nanni Aq Mt kn@openbsd.org
331 .An Ori Bernstein Aq Mt ori@openbsd.org
332 .An Stefan Sperling Aq Mt stsp@openbsd.org
333 .An Tracey Emery Aq Mt tracey@traceyemery.net
334 .Sh CAVEATS
335 .Nm
336 is a work-in-progress and some features remain to be implemented.
337 .Pp
338 At present, the user has to fall back on
339 .Xr git 1
340 to perform some tasks.
341 In particular:
342 .Bl -bullet
343 .It
344 Removing redundant or unreferenced packed objects requires
345 .Xr git-gc 1
346 and perhaps
347 .Xr git-repack 1 .
348 .It
349 Exporting data from repositories requires
350 .Xr git-fast-export 1 .
351 .It
352 Importing data into repositories requires
353 .Xr git-fast-import 1 .
354 .El
355 .Sh BUGS
356 Disk space savings reported by
357 .Cm gotadmin cleanup
358 will be misleading if the repository contains object files that were
359 hard-linked from another repository.
360 Such hard-links will be created by certain
361 .Xr git 1
362 commands.
363 By itself,
364 .Xr got 1
365 will never create hard-linked object files.