From: bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r@public.gmane.org
To: linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: [Bug 121211] Please provide conventions for documenting subcommands in man-pages(7)
Date: Thu, 07 Jul 2016 17:53:01 +0000 [thread overview]
Message-ID: <bug-121211-11311-6z9bSry8l2@https.bugzilla.kernel.org/> (raw)
In-Reply-To: <bug-121211-11311-3bo0kxnWaOQUvHkbgXJLS5sdmw4N0Rt+2LY78lusg7I@public.gmane.org/>
https://bugzilla.kernel.org/show_bug.cgi?id=121211
--- Comment #2 from Josh Triplett <josh-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org> ---
(In reply to Michael Kerrisk from comment #1)
> Hi Josh
>
> > Many programs now provide subcommands, such as git, systemctl, git-remote,
> > git-hub, and apt. These programs follow various different inconsistent
> > conventions for documenting these subcommands in their manpages. I'm about
> > to write such a program with subcommands myself. I'd love to see some
> > standard conventions documented in man-pages(7).
>
> I generally would love to see more consistency in man pages across all
> projects of course. The thing is, man-pages(7) was primarily driven from the
> desire to document best practice for the Linux man-pages project, which
> produces only a handful of (relatively short) man pages in Sections 1 and 8.
> As such, I'm cautious about making too many prescriptions there about pages
> in Sections 1 and 8.
The man-pages project, though, seems like the one project with the greatest
claim to provide style guidelines for consistency. Some of these have less to
do with one stylistic choice looking *better*, and more about maintaining
consistency between pages.
> I have made a few changes though in man-pages(7) just
> now (see Git).
Those look helpful, thanks.
One bug report for those changes: the first of the two new subheadings should
say "Formatting conventions for manual pages describing commands", rather than
"... functions" (duplicating the second heading).
> > Note that some programs will want to document all their subcommands in
> > separate manpages, and others will want a single all-encompassing manpage.
> > I don't think man-pages(7) should mandate one or the other approach there,
> > just establish standards that work either way.
> >
> > In particular:
> >
> > - Should the SYNOPSIS section document the usage of every subcommand (see
> > git-remote for an example), or use a placeholders for subcommands and their
> > options (see systemctl, git, or git-hub for examples)?
>
> It seems either approach works. Not sure that anything needs to be said in
> man-pages about this?
Consistency between pages helps.
Personally, I'd suggest using a placeholder for the subcommand, for the same
reason that the majority of manpages just say [OPTION]... rather than listing
every possible option in the synopsis.
> > - If the SYNOPSIS just uses placeholders, what placeholder should it use for
> > subcommands? "<command>" or "<subcommand>" or "<cmd>" or "<subcmd>"? (Or
> > similar with square brackets if optional.)
>
> Are you meaning whether to abbreviate the word "command"? I don't think it's
> necessary to specify things to that level.
No, I was mostly asking about whether the thing in question should be called a
"command" or a "subcommand", as with the question below about headings.
man-pages makes several specific recommendations about terminology for
consistency; this seems like a useful distinction to make there.
> > - What section should subcommands appear in? I've seen both "COMMANDS" and
> > "SUBCOMMANDS".
>
> Not sure. Do you have a recommendation and a justification?
I would recommend "SUBCOMMANDS", because we typically use "commands" to refer
to the top-level programs like "cp", "ls", and "git". Let's avoid the
ambiguity.
> > - Within that section, what formatting should subcommands use for their
> > name, usage, description, and options?
>
> I've added a little more detail on this in the man page.
I saw the details regarding the use of boldface and italics. I was more
wondering about paragraphs and indentation. I'd thought of using the
following, though the need for .RS/.RE bugs me:
.SH SUBCOMMANDS
.TP
\fBcommand subcommand1\fR
Description of subcommand1.
.IP
More description of subcommand1.
.TP
\fBcommand subcommand2\fR [\fB-f\fR|\fB--flag\fR] \fIarg\fR
Description of subcommand2.
.IP
More description of subcommand2.
.RS
.TP
\fIarg\fR
Description of \fIarg\fR.
.TP
.BR -f | --flag
Description of \fB--flag\fR.
.RE
Does that look reasonable, or do you have another idea for how subcommands with
flags and arguments should format their descriptions? Either way, this seems
like something worth providing guidance on, just as man-pages(7) currently
provides guidance suggesting the use of .TP in several places.
I can provide a patch for this.
> > - If programs don't ship separate manual pages for each subcommand, should
> > they ship symlinks for each subcommand to the main manpage?
>
> I'm not sure what to recommend here. Can you give an example or two?
git(1) mentions its subcommands, but has separate manpages for git-diff(1),
git-commit(1), and so on, so "man git diff" works. If git instead documented
all of its subcommands inline, should it ship a symlink git-diff.1.gz ->
git.1.gz? (Or a manpage containing just a .so line?)
--
You are receiving this mail because:
You are watching the assignee of the bug.
--
To unsubscribe from this list: send the line "unsubscribe linux-man" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2016-07-07 17:53 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-30 9:34 [Bug 121211] New: Please provide conventions for documenting subcommands in man-pages(7) bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r
[not found] ` <bug-121211-11311-3bo0kxnWaOQUvHkbgXJLS5sdmw4N0Rt+2LY78lusg7I@public.gmane.org/>
2016-07-07 11:23 ` [Bug 121211] " bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r
2016-07-07 17:53 ` bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r [this message]
2016-07-07 18:25 ` bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r
2016-07-07 18:25 ` bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r
2016-07-07 18:26 ` bugzilla-daemon-590EEB7GvNiWaY/ihj7yzEB+6BGkLq7r
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=bug-121211-11311-6z9bSry8l2@https.bugzilla.kernel.org/ \
--to=bugzilla-daemon-590eeb7gvniway/ihj7yzeb+6bgklq7r@public.gmane.org \
--cc=linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
/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).