6

Can I find the contents of a man page?

man bash is almost 6000 lines long, and I would like to know the section headings within the page.

3
  • You can download as pdf from gnu.org/s/bash/manual/bash.pdf Commented Oct 4, 2014 at 10:12
  • This is basically what I want, thanks. Interestingly, it's not exactly the same, though a lot of text is shared. Commented Oct 4, 2014 at 10:19
  • @wrgrs the details will depend on your distribution. Some of them package their own versions of software and change the man pages. Commented Oct 4, 2014 at 12:58

6 Answers 6

4

If you just want the section headings, grep for them. They are in ALLCAPS and are the only lines that have no leading spaces:

$ man bash | grep '^[A-Z]'
BASH(1)                                General Commands         Manual                                BASH(1)
NAME
SYNOPSIS
COPYRIGHT
DESCRIPTION
OPTIONS
ARGUMENTS
INVOCATION
DEFINITIONS
RESERVED WORDS
SHELL GRAMMAR
COMMENTS
QUOTING
PARAMETERS
EXPANSION
REDIRECTION
ALIASES
FUNCTIONS
ARITHMETIC EVALUATION
CONDITIONAL EXPRESSIONS
SIMPLE COMMAND EXPANSION
COMMAND EXECUTION
COMMAND EXECUTION ENVIRONMENT
ENVIRONMENT
EXIT STATUS
SIGNALS
JOB CONTROL
PROMPTING
READLINE
HISTORY
HISTORY EXPANSION
SHELL BUILTIN COMMANDS
RESTRICTED SHELL
SEE ALSO
FILES
AUTHORS
BUG REPORTS
BUGS
GNU Bash 4.3                               2014 February 2                                    BASH(1)
3
  • run man as usual, which ought to run less to display the content, as evidenced by this kind of status line (at the bottom of the terminal window):

      Manual page man(1) line 1 (press h for help or q to quit)
    
  • type &^( )?[^ ] (with 3 spaces between the parentheses), then hit return, which should get you this:

      MAN(1)                        Manual pager utils                        MAN(1)
      NAME
      SYNOPSIS
      DESCRIPTION
      EXAMPLES
      OVERVIEW
      DEFAULTS
      OPTIONS
         General options
         Main modes of operation
         Finding manual pages
         Controlling formatted output
         Getting help
      EXIT STATUS
      ENVIRONMENT
      FILES
      SEE ALSO
      HISTORY
      2.8.3                             2018-04-05                            MAN(1)
    

    (bonus: with this method you get subsections as well)

  • scroll so the section or subsection of interest sits in the first line. You might have to use shift-J to allow less to scroll the bottom of the screen beyond the end of file:

         Controlling formatted output
         Getting help
      EXIT STATUS
      ENVIRONMENT
      FILES
      SEE ALSO
      HISTORY
      2.8.3                             2018-04-05                            MAN(1)
      ~
      ~
      ~
      ~
      ~
      ~
      ~
      ~
      ~
      ~
      ~
    
  • type &, then hit return, which should get you this:

         Controlling formatted output
             -P pager, --pager=pager
                    Specify which output pager to use.  By default, man uses  pager,
                    falling  back to cat if pager is not found or is not executable.
                    This option overrides the $MANPAGER environment variable,  which
                    in  turn  overrides  the $PAGER environment variable.  It is not
                    used in conjunction with -f or -k.
    
                    The value may be a simple command name or a command  with  argu‐
                    ments, and may use shell quoting (backslashes, single quotes, or
                    double quotes).  It may not use pipes to connect  multiple  com‐
                    mands;  if  you  need that, use a wrapper script, which may take
                    the file to display either as an argument or on standard input.
    
             -r prompt, --prompt=prompt
                    If a recent version of less is  used  as  the  pager,  man  will
                    attempt  to  set  its  prompt  and  some  sensible options.  The
                    default prompt looks like
    

    Note how the first line on screen remains the same.

  • Browse the contents

  • Repeat as necessary

2

Convert it to html. You will have table of contents with links:

bunzip2 -c $(man -w bash) | groff -mandoc -Thtml > /tmp/bash.html && \
firefox -remote "openURL(file:///tmp/bash.html, new-tab)"

You can create a function which will do it automatically for all man pages if you like.

3
  • This is really neat. On Ubuntu I needed to install groff and use gunzip. Commented Oct 4, 2014 at 13:09
  • Yes you are right, if man pages are compressed to *.gz then gunzip -c or zcat (or even gzcat) are the right tools. Commented Oct 4, 2014 at 13:22
  • man2html also performs this kind of conversion and can be used as a CGI script, so you can set up a local web server serving manual pages. It is available in Debian, Ubuntu and Fedora. Commented Oct 4, 2014 at 18:20
2

If you are comfortable with using Neovim as your man pager, it can do this. It has an interactive table of contents that can be activated with gO, as well as some other useful navigation shortcuts. It can be set as your default man pager by adding the following variable to your shell:

export MANPAGER='nvim +Man!'

From :help :Man:

MAN                 *ft-man-plugin* *:Man* *man.vim*

View manpages in Nvim. Supports highlighting, completion, locales, and
navigation. Also see |find-manpage|.

...

Local mappings:
K or CTRL-]               Jump to the manpage for the <cWORD> under the
                          cursor. Takes a count for the section.
CTRL-T                    Jump back to the location that the manpage was
                          opened from.
gO                        Show the manpage outline. |gO|
q                         :quit if invoked as $MANPAGER, otherwise :close.

...

To use Nvim as a manpager:
     export MANPAGER='nvim +Man!'
1

Assuming you haven't changed your pager, you will be viewing man pages in less.

To search in less, type /regex, e.g. /^SHELL BUILTIN COMMANDS, then press enter. Use n/N to navigate between multiple matches.

1
  • 2
    Actually, this is kind of the opposite of what I want! That's how to get somewhere if I know what it's called. I want to know what sections exist. Commented Oct 4, 2014 at 10:59
0

Manpage sections are in all-caps with no leading blanks, but subsections can also be distinguished, because they begin with a predictable number of blanks (3).

I use that fact in generating navigation links for manpages (such as xterm) with my version of man2html.

$ man bash | grep -E '^ {,3}[A-Z]'

gives

BASH(1)                     General Commands Manual                    BASH(1)
NAME
SYNOPSIS
COPYRIGHT
DESCRIPTION
OPTIONS
ARGUMENTS
INVOCATION
DEFINITIONS
RESERVED WORDS
SHELL GRAMMAR
   Simple Commands
   Pipelines
   Lists
   Compound Commands
   Coprocesses
   Shell Function Definitions
COMMENTS
QUOTING
PARAMETERS
   Positional Parameters
   Special Parameters
   Shell Variables
   Arrays
EXPANSION
   Brace Expansion
   Tilde Expansion
   Parameter Expansion
   Command Substitution
   Arithmetic Expansion
   Process Substitution
   Word Splitting
   Pathname Expansion
   Quote Removal
REDIRECTION
   Redirecting Input
   Redirecting Output
   Appending Redirected Output
   Redirecting Standard Output and Standard Error
   Appending Standard Output and Standard Error
   Here Documents
   Here Strings
   Duplicating File Descriptors
   Moving File Descriptors
   Opening File Descriptors for Reading and Writing
ALIASES
FUNCTIONS
ARITHMETIC EVALUATION
CONDITIONAL EXPRESSIONS
SIMPLE COMMAND EXPANSION
COMMAND EXECUTION
COMMAND EXECUTION ENVIRONMENT
ENVIRONMENT
EXIT STATUS
SIGNALS
JOB CONTROL
PROMPTING
READLINE
   Readline Notation
   Readline Initialization
   Readline Key Bindings
   Readline Variables
   Readline Conditional Constructs
   Searching
   Readline Command Names
   Commands for Moving
   Commands for Manipulating the History
   Commands for Changing Text
   Killing and Yanking
   Numeric Arguments
   Completing
   Keyboard Macros
   Miscellaneous
   Programmable Completion
HISTORY
HISTORY EXPANSION
   Event Designators
   Word Designators
   Modifiers
SHELL BUILTIN COMMANDS
RESTRICTED SHELL
SEE ALSO
FILES
AUTHORS
BUG REPORTS
BUGS
GNU Bash 5.0                    2018 December 7                        BASH(1)

Interestingly enough, xterm's manual page uses more lines than bash, but fewer characters. That's because xterm uses more whitespace, for readability:

xterm and bash manpages, in vile

But in either case (roughly 6000-7000 lines) that's 150-175 screen/pages in my xterm window, so some navigation aid is helpful. Some use an editor (as I did in the screenshot), and that allows displaying the section/subsection titles as done using grep. Others use a web browser. The comments about groff do not mention that it does not provide navigation for subsections, which may be important. Half of the outline for the bash manpage is at the subsection level.

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.