1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
// Warning!! Code generated automatically: this file must not be edited by hand
use crateoption_arg;
use crateFnOptionArg;
pub const PARSEOPT: &str = "--parseopt";
pub const SQ_QUOTE: &str = "--sq-quote";
pub const KEEP_DASHDASH: &str = "--keep-dashdash";
pub const STOP_AT_NON_OPTION: &str = "--stop-at-non-option";
pub const STUCK_LONG: &str = "--stuck-long";
pub const REVS_ONLY: &str = "--revs-only";
pub const NO_REVS: &str = "--no-revs";
pub const FLAGS: &str = "--flags";
pub const NO_FLAGS: &str = "--no-flags";
pub const DEFAULT: &str = "--default";
pub const PREFIX: &str = "--prefix";
pub const VERIFY: &str = "--verify";
pub const QUIET: &str = "--quiet";
pub const SQ: &str = "--sq";
pub const SHORT: &str = "--short";
pub const NOT: &str = "--not";
pub const ABBREV_REF: &str = "--abbrev-ref";
pub const SYMBOLIC: &str = "--symbolic";
pub const SYMBOLIC_FULL_NAME: &str = "--symbolic-full-name";
pub const ALL: &str = "--all";
pub const BRANCHES: &str = "--branches";
pub const TAGS: &str = "--tags";
pub const REMOTES: &str = "--remotes";
pub const GLOB: &str = "--glob";
pub const EXCLUDE: &str = "--exclude";
pub const DISAMBIGUATE: &str = "--disambiguate";
pub const LOCAL_ENV_VARS: &str = "--local-env-vars";
pub const GIT_DIR: &str = "--git-dir";
pub const ABSOLUTE_GIT_DIR: &str = "--absolute-git-dir";
pub const GIT_COMMON_DIR: &str = "--git-common-dir";
pub const IS_INSIDE_GIT_DIR: &str = "--is-inside-git-dir";
pub const IS_INSIDE_WORK_TREE: &str = "--is-inside-work-tree";
pub const IS_BARE_REPOSITORY: &str = "--is-bare-repository";
pub const RESOLVE_GIT_DIR: &str = "--resolve-git-dir";
pub const GIT_PATH: &str = "--git-path";
pub const SHOW_CDUP: &str = "--show-cdup";
pub const SHOW_PREFIX: &str = "--show-prefix";
pub const SHOW_TOPLEVEL: &str = "--show-toplevel";
pub const SHOW_SUPERPROJECT_WORKING_TREE: &str = "--show-superproject-working-tree";
pub const SHARED_INDEX_PATH: &str = "--shared-index-path";
pub const SINCE: &str = "--since";
pub const AFTER: &str = "-after";
pub const UNTIL: &str = "--until";
pub const BEFORE: &str = "--before";
/// Use git rev-parse in option parsing mode (see PARSEOPT section below).
/// --parseopt
/// Use git rev-parse in shell quoting mode (see SQ-QUOTE section below).
/// In contrast to the --sq option below, this mode does only quoting.
/// Nothing else is done to command input.
/// --sq-quote
/// Only meaningful in --parseopt mode.
/// Tells the option parser to echo out the first -- met instead of skipping it.
/// --keep-dashdash
/// Only meaningful in --parseopt mode.
/// Lets the option parser stop at the first non-option argument.
/// This can be used to parse sub-commands that take options themselves.
/// --stop-at-non-option
/// Only meaningful in --parseopt mode.
/// Output the options in their long form if available, and with their arguments stuck.
/// --stuck-long
/// Do not output flags and parameters not meant for git rev-list command.
/// --revs-only
/// Do not output flags and parameters meant for git rev-list command.
/// --no-revs
/// Do not output non-flag parameters.
/// --flags
/// Do not output flag parameters.
/// --no-flags
/// If there is no parameter given by the user, use <arg> instead.
/// --default <arg>
/// Behave as if git rev-parse was invoked from the <arg> subdirectory of the working tree.
/// Any relative filenames are resolved as if they are prefixed by <arg> and will be printed in that form.
/// This can be used to convert arguments to a command run in a subdirectory so that they can still be used after moving to the top-level of the repository.
/// --prefix <arg>
/// Verify that exactly one parameter is provided, and that it can be turned into a raw 20-byte SHA-1 that can be used to access the object database.
/// If so, emit it to the standard output; otherwise, error out.
/// --verify
/// Only meaningful in --verify mode.
/// Do not output an error message if the first argument is not a valid object name; instead exit with non-zero status silently.
/// SHA-1s for valid object names are printed to stdout on success.
/// -q, --quiet
/// Usually the output is made one line per flag and parameter.
/// This option makes output a single line, properly quoted for consumption by shell.
/// Useful when you expect your parameter to contain whitespaces and newlines (e.g.
/// when using pickaxe -S with git diff-*).
/// In contrast to the --sq-quote option, the command input is still interpreted as usual.
/// --sq
/// Same as --verify but shortens the object name to a unique prefix with at least length characters.
/// The minimum length is 4, the default is the effective value of the core.abbrev configuration variable (see git-config(1)).
/// --short[=length]
/// When showing object names, prefix them with ^ and strip ^ prefix from the object names that already have one.
/// --not
/// A non-ambiguous short name of the objects name.
/// The option core.warnAmbiguousRefs is used to select the strict abbreviation mode.
/// --abbrev-ref[=(strict|loose)]
/// Usually the object names are output in SHA-1 form (with possible ^ prefix); this option makes them output in a form as close to the original input as possible.
/// --symbolic
/// This is similar to --symbolic, but it omits input that are not refs
/// (i.e.
/// branch or tag names; or more explicitly disambiguating 'heads/master' form, when you want to name the 'master' branch when there is an unfortunately named tag 'master'),
/// and show them as full refnames (e.g.
/// 'refs/heads/master').
/// --symbolic-full-name
/// Show all refs found in refs/.
/// --all
/// Show all branches, tags, or remote-tracking branches, respectively (i.e., refs found in refs/heads, refs/tags, or refs/remotes, respectively).
/// If a pattern is given, only refs matching the given shell glob are shown.
/// If the pattern does not contain a globbing character (?, *, or [), it is turned into a prefix match by appending /*.
/// --branches[=pattern], --tags[=pattern], --remotes[=pattern]
/// Show all branches, tags, or remote-tracking branches, respectively (i.e., refs found in refs/heads, refs/tags, or refs/remotes, respectively).
/// If a pattern is given, only refs matching the given shell glob are shown.
/// If the pattern does not contain a globbing character (?, *, or [), it is turned into a prefix match by appending /*.
/// --branches[=pattern], --tags[=pattern], --remotes[=pattern]
/// Show all branches, tags, or remote-tracking branches, respectively (i.e., refs found in refs/heads, refs/tags, or refs/remotes, respectively).
/// If a pattern is given, only refs matching the given shell glob are shown.
/// If the pattern does not contain a globbing character (?, *, or [), it is turned into a prefix match by appending /*.
/// --branches[=pattern], --tags[=pattern], --remotes[=pattern]
/// Show all refs matching the shell glob pattern pattern.
/// If the pattern does not start with refs/, this is automatically prepended.
/// If the pattern does not contain a globbing character (?, *, or [), it is turned into a prefix match by appending /*.
/// --glob=pattern
/// Do not include refs matching <glob-pattern> that the next --all, --branches, --tags, --remotes, or --glob would otherwise consider.
/// Repetitions of this option accumulate exclusion patterns up to the next --all, --branches, --tags, --remotes, or --glob option (other options or arguments do not clear accumulated patterns).
/// The patterns given should not begin with refs/heads, refs/tags, or refs/remotes when applied to --branches, --tags, or --remotes, respectively, and they must begin with refs/ when applied to --glob or --all.
/// If a trailing /* is intended, it must be given explicitly.
/// --exclude=<glob-pattern>
/// Show every object whose name begins with the given prefix.
/// The <prefix> must be at least 4 hexadecimal digits long to avoid listing each and every object in the repository by mistake.
/// --disambiguate=<prefix>
/// List the GIT_* environment variables that are local to the repository (e.g.
/// GIT_DIR or GIT_WORK_TREE, but not GIT_EDITOR).
/// Only the names of the variables are listed, not their value, even if they are set.
/// --local-env-vars
/// Show $GIT_DIR if defined.
/// Otherwise show the path to the .git directory.
/// The path shown, when relative, is relative to the current working directory.
/// If $GIT_DIR is not defined and the current directory is not detected to lie in a Git repository or work tree print a message to stderr and exit with nonzero status.
/// --git-dir
/// Like --git-dir, but its output is always the canonicalized absolute path.
/// --absolute-git-dir
/// Show $GIT_COMMON_DIR if defined, else $GIT_DIR.
/// --git-common-dir
/// When the current working directory is below the repository directory print 'true', otherwise 'false'.
/// --is-inside-git-dir
/// When the current working directory is inside the work tree of the repository print 'true', otherwise 'false'.
/// --is-inside-work-tree
/// When the repository is bare print 'true', otherwise 'false'.
/// --is-bare-repository
/// Check if <path> is a valid repository or a gitfile that points at a valid repository, and print the location of the repository.
/// If <path> is a gitfile then the resolved path to the real repository is printed.
/// --resolve-git-dir <path>
/// Resolve '$GIT_DIR/<path>' and takes other path relocation variables such as $GIT_OBJECT_DIRECTORY, $GIT_INDEX_FILE...
/// into account.
/// For example, if $GIT_OBJECT_DIRECTORY is set to /foo/bar then 'git rev-parse --git-path objects/abc' returns /foo/bar/abc.
/// --git-path <path>
/// When the command is invoked from a subdirectory,
/// show the path of the top-level directory relative to the current directory (typically a sequence of '../', or an empty string).
/// --show-cdup
/// When the command is invoked from a subdirectory,
/// show the path of the current directory relative to the top-level directory.
/// --show-prefix
/// Show the absolute path of the top-level directory.
/// --show-toplevel
/// Show the absolute path of the root of the superproject’s working tree (if exists) that uses the current repository as its submodule.
/// Outputs nothing if the current repository is not used as a submodule by any project.
/// --show-superproject-working-tree
/// Show the path to the shared index file in split index mode, or empty if not in split-index mode.
/// --shared-index-path
/// Parse the date string, and output the corresponding --max-age= parameter for git rev-list.
/// --since=datestring, --after=datestring
/// Parse the date string, and output the corresponding --max-age= parameter for git rev-list.
/// --since=datestring, --after=datestring
/// Parse the date string, and output the corresponding --min-age= parameter for git rev-list.
/// --until=datestring, --before=datestring
/// Parse the date string, and output the corresponding --min-age= parameter for git rev-list.
/// --until=datestring, --before=datestring