1
# Copyright 2005 Canonical Ltd.
1
# Copyright (C) 2005-2010 Canonical Ltd
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
"""man.py - create man page from built-in bzr help and static text
21
21
* add command aliases
24
from __future__ import absolute_import
26
PLUGINS_TO_DOCUMENT = ["launchpad"]
33
import bzrlib.help_topics
31
34
import bzrlib.commands
36
from bzrlib.plugin import load_plugins
34
40
def get_filename(options):
35
41
"""Provides name of manpage"""
50
56
outfile.write(man_escape(man_head % params))
51
57
outfile.write(man_escape(getcommand_list(params)))
52
58
outfile.write(man_escape(getcommand_help(params)))
59
outfile.write("".join(environment_variables()))
53
60
outfile.write(man_escape(man_foot % params))
56
63
def man_escape(string):
57
64
"""Escapes strings for man page compatibility"""
58
65
result = string.replace("\\","\\\\")
59
result = result.replace("`","\\`")
60
result = result.replace("'","\\'")
66
result = result.replace("`","\\'")
67
result = result.replace("'","\\*(Aq")
61
68
result = result.replace("-","\\-")
65
72
def command_name_list():
66
73
"""Builds a list of command names from bzrlib"""
67
74
command_names = bzrlib.commands.builtin_command_names()
75
for cmdname in bzrlib.commands.plugin_command_names():
76
cmd_object = bzrlib.commands.get_cmd_object(cmdname)
77
if (PLUGINS_TO_DOCUMENT is None or
78
cmd_object.plugin_name() in PLUGINS_TO_DOCUMENT):
79
command_names.append(cmdname)
68
80
command_names.sort()
69
81
return command_names
80
92
cmd_help = cmd_object.help()
82
94
firstline = cmd_help.split('\n', 1)[0]
83
usage = bzrlib.help.command_usage(cmd_object)
95
usage = cmd_object._usage()
84
96
tmp = '.TP\n.B "%s"\n%s\n' % (usage, firstline)
85
97
output = output + tmp
91
103
def getcommand_help(params):
92
104
"""Shows individual options for a bzr command"""
93
105
output='.SH "COMMAND REFERENCE"\n'
94
107
for cmd_name in command_name_list():
95
108
cmd_object = bzrlib.commands.get_cmd_object(cmd_name)
96
109
if cmd_object.hidden:
98
output = output + format_command(params, cmd_object)
111
formatted[cmd_name] = format_command(params, cmd_object)
112
for alias in cmd_object.aliases:
113
formatted[alias] = format_alias(params, alias, cmd_name)
114
for cmd_name in sorted(formatted):
115
output += formatted[cmd_name]
102
def format_command (params, cmd):
119
def format_command(params, cmd):
103
120
"""Provides long help for each public command"""
104
subsection_header = '.SS "%s"\n' % (bzrlib.help.command_usage(cmd))
121
subsection_header = '.SS "%s"\n' % (cmd._usage())
105
122
doc = "%s\n" % (cmd.__doc__)
123
doc = bzrlib.help_topics.help_as_plain_text(cmd.help())
125
# A dot at the beginning of a line is interpreted as a macro.
126
# Simply join lines that begin with a dot with the previous
127
# line to work around this.
128
doc = doc.replace("\n.", ".")
109
131
options = cmd.options()
111
133
option_str = "\nOptions:\n"
112
134
for option_name, option in sorted(options.items()):
113
135
for name, short_name, argname, help in option.iter_switches():
136
if option.is_hidden(name):
115
139
if argname is not None:
116
140
l += ' ' + argname
118
assert len(short_name) == 1
119
142
l += ', -' + short_name
120
l += (30 - len(l)) * ' ' + help
121
# TODO: Split help over multiple lines with
122
# correct indenting and wrapping.
143
l += (30 - len(l)) * ' ' + (help or '')
123
144
wrapped = textwrap.fill(l, initial_indent='',
124
subsequent_indent=30*' ')
125
option_str = option_str + wrapped + '\n'
145
subsequent_indent=30*' ',
146
break_long_words=False,
148
option_str += wrapped + '\n'
133
156
aliases_str += ', '.join(cmd.aliases)
134
157
aliases_str += '\n'
136
return subsection_header + option_str + aliases_str + "\n" + doc + "\n"
160
see_also = cmd.get_see_also()
162
see_also_str += '\nSee also: '
163
see_also_str += ', '.join(see_also)
166
return subsection_header + option_str + aliases_str + see_also_str + "\n" + doc + "\n"
169
def format_alias(params, alias, cmd_name):
170
help = '.SS "bzr %s"\n' % alias
171
help += 'Alias for "%s", see "bzr %s".\n' % (cmd_name, cmd_name)
175
def environment_variables():
176
yield ".SH \"ENVIRONMENT\"\n"
178
from bzrlib.help_topics import known_env_variables
179
for k, desc in known_env_variables:
181
yield ".I \"%s\"\n" % k
182
yield man_escape(desc) + "\n"
139
185
man_preamble = """\
140
Man page for Bazaar (%(bzrcmd)s)
186
.\\\"Man page for Bazaar (%(bzrcmd)s)
142
188
.\\\" Large parts of this file are autogenerated from the output of
143
189
.\\\" \"%(bzrcmd)s help commands\"
144
190
.\\\" \"%(bzrcmd)s help <cmd>\"
146
.\\\" Generation time: %(timestamp)s
193
.ie \\n(.g .ds Aq \\(aq
152
199
.TH bzr 1 "%(datestamp)s" "%(version)s" "Bazaar"
154
Bazaar (%(bzrcmd)s) - next-generation distributed version control
201
%(bzrcmd)s - Bazaar next-generation distributed version control
168
215
.SH "DESCRIPTION"
169
Bazaar (or %(bzrcmd)s) is a project of Canonical to develop an open source
170
distributed version control system that is powerful, friendly, and scalable.
171
Version control means a system that keeps track of previous revisions
172
of software source code or similar information and helps people work on it in teams.
217
Bazaar (or %(bzrcmd)s) is a distributed version control system that is powerful,
218
friendly, and scalable. Bazaar is a project of Canonical Ltd and part of
219
the GNU Project to develop a free operating system.
221
Bazaar keeps track of changes to software source code (or similar information);
222
lets you explore who changed it, when, and why; merges concurrent changes; and
223
helps people work together in a team.
181
is to look for external command.
184
E-Mail address of the user. Overrides default user config.
187
E-Mail address of the user. Overrides default user config.
190
Editor for editing commit messages
193
Editor for editing commit messages
196
Paths where bzr should look for plugins
199
Home directory for bzr
202
229
.I "~/.bazaar/bazaar.conf"
203
Contains the users default configuration. The section
230
Contains the user's default configuration. The section
205
232
is used to define general configuration that will be applied everywhere.
222
249
log10 = log --short -r -10..-1
224
.UR http://www.bazaar-vcs.org/
225
.BR http://www.bazaar-vcs.org/
251
.UR http://bazaar.canonical.com/
252
.BR http://bazaar.canonical.com/