From: Mark Lodato <lodatom@gmail.com>
To: git list <git@vger.kernel.org>
Cc: Junio C Hamano <gitster@pobox.com>
Subject: Meta-variable naming convention in documentation
Date: Thu, 25 Feb 2010 23:55:08 -0500 [thread overview]
Message-ID: <ca433831002252055l37292cf6v868cc407f0be7250@mail.gmail.com> (raw)
Currently, git's documentation and usage statements are inconsistent in
the meta-variables (e.g., <path>) used to described positional arguments
that denote a path. This post is an attempt to document the existing
issues and to propose a potential solution.
To begin, I ran each of the git sub-commands in git 1.7.0 and documented
its behavior. Each row contains the program, the meta-variables, and
the type. If the man page and the '-h' usage statement differ, I list
both. For example, git-annotate uses "file" in both the man page and
the usage statement, while git-blame uses "<file>" in the man page but
"file" in the usage statement.
The following accept exact filenames. No directory recursion or
globing is applied. The first group die if the file does not exist,
while the second group "filters" (f) -- they silently ignore
non-matching files.
program man[/usage] type
------- ----------- ----
git-annotate file file
git-blame <file>/file file
git-checkout-index <file> file
git-hash-object <file> file
git-mailsplit <mbox>|<Maildir> file
git-merge-file <current-file> ... file
git-merge-index <file>/<filename> file
git-merge-one-file <path> file
git-mergetool <file>/file to merge file
git-mv <args>/<source> file
git-pack-redundant .pack filename/<...> file
git-send-email <file> file
git-update-index <file> file
git-am <dir> dir
git-clone <directory> dir
git-cvsserver <directory> dir
git-daemon <directory> dir
git-fetch-pack <directory> dir
git-filter-branch <directory> dir
git-format-patch <dir> dir
git-fsck <dir> dir
git-mailsplit <directory> dir
git-peek-remote <directory> dir
git-quiltimport <dir> dir
git-receive-pack <directory> dir
git-relink <dir> dir
git-send-pack <directory> dir
git-submodule <path> dir
git-upload-archive <directory> dir
git-upload-pack <directory> dir
git-bundle <file> outfile
git-mailinfo <patch> outfile
git-pack-objects base-name outfile
git-diff-tree <path> file (f)
git-ls-tree paths/path file (f)
The following accept exact filenames or directories. If a directory,
this matches all files within that directory recursively.
git-archive path fdir
git-bisect <paths>/<pathspec> fdir (f)
git-diff <path> fdir (f)
git-diff-files <path> fdir (f)
git-diff-index <path> fdir (f)
git-difftool <path>/(nothing) fdir (f)
git-log <path> fdir (f)
git-reset <paths> fdir (f)
git-rev-list <paths>/paths fdir (f)
git-show (undoc)/<path> fdir (f)
git-whatchanged (undocumented) fdir (f)
gitk <path> fdir (f)
The following accept recursive directory matches or path globs.
git-add <filepattern> glob
git-checkout <paths>/<file> glob
git-commit <file>/<filepattern> glob
git-rm <file> glob
git-clean <path>/<paths> glob (f)
git-grep <path>/path glob (f)
git-ls-files <file> glob (f)
git-status <pathspec>/<filepattern> glob? (f)
* git-rm has --ignore-unmatch, which causes it to "filter"
* git-status only accepts globs for untracked files (currently a bug?)
Here are some examples showing what I mean by "type". (May be useful to
have something like this in the documentation.)
pattern file fdir glob
------- ---- ---- ----
path/to/base.ext yes yes yes
path - yes yes
*xt - - yes
p*t - - yes
base.ext - - -
b* - - -
to - - -
>From the above, it appears that there are four major groups:
* 'file' or 'dir'
* 'fdir' (f)
* 'glob'
* 'glob' (f)
(The only exceptions are git-diff-tree, git-ls-tree, and git-archive.)
Therefore, I suggest that we stick to a consistent naming convention for
these four groups, and document them in git(1). Here's is a proposal,
but I'm not tied to these names.
* <file> for 'file'
* <dir> for 'dir'
* <path> for 'fdir' (f)
* <filepattern> for 'glob'
* <pathspec> for 'glob' (f)
We would have to come up with something for the three exceptions above,
and some commands would benefit from more detailed meta-vars, such as
"<source>... <destination>" for git-mv.
Additionally, it would be nice if all non-filtering commands had
--ignore-unmatch, and all filtering commands had an option to die/warn
if any arguments did not match. But, this is much more work than
a simple documentation change.
Anyway, what do you think of this proposal? I am not sure that I have
my partitioning correct, but I would like to see some sort of
consistency in the documentation. I would be happy to implement
whatever is decided.
next reply other threads:[~2010-02-26 4:55 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-02-26 4:55 Mark Lodato [this message]
2010-02-26 5:42 ` Meta-variable naming convention in documentation Junio C Hamano
2010-02-26 22:51 ` Mark Lodato
2010-02-27 2:41 ` Mark Lodato
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ca433831002252055l37292cf6v868cc407f0be7250@mail.gmail.com \
--to=lodatom@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).