~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/help.py

  • Committer: Martin Pool
  • Date: 2005-07-16 00:07:40 UTC
  • mfrom: (909.1.5)
  • Revision ID: mbp@sourcefrog.net-20050716000740-f2dcb8894a23fd2d
- merge aaron's bugfix branch
  up to abentley@panoramicfeedback.com-20050715134354-78f2bca607acb415

Show diffs side-by-side

added added

removed removed

Lines of Context:
56
56
"""
57
57
 
58
58
 
59
 
 
60
 
def help(topic=None):
 
59
import sys
 
60
 
 
61
 
 
62
def help(topic=None, outfile = None):
 
63
    if outfile == None:
 
64
        outfile = sys.stdout
61
65
    if topic == None:
62
 
        print global_help
 
66
        outfile.write(global_help)
63
67
    elif topic == 'commands':
64
 
        help_commands()
65
 
    else:
66
 
        help_on_command(topic)
67
 
 
68
 
 
69
 
def help_on_command(cmdname):
70
 
    cmdname = str(cmdname)
71
 
 
72
 
    from inspect import getdoc
73
 
    import commands
74
 
    topic, cmdclass = commands.get_cmd_class(cmdname)
75
 
 
76
 
    doc = getdoc(cmdclass)
77
 
    if doc == None:
78
 
        raise NotImplementedError("sorry, no detailed help yet for %r" % cmdname)
79
 
 
80
 
    if '\n' in doc:
81
 
        short, rest = doc.split('\n', 1)
82
 
    else:
83
 
        short = doc
84
 
        rest = ''
85
 
 
86
 
    print 'usage: bzr ' + topic,
 
68
        help_commands(outfile = outfile)
 
69
    else:
 
70
        help_on_command(topic, outfile = outfile)
 
71
 
 
72
 
 
73
def command_usage(cmdname, cmdclass):
 
74
    """Return single-line grammar for command.
 
75
 
 
76
    Only describes arguments, not options.
 
77
    """
 
78
    s = cmdname + ' '
87
79
    for aname in cmdclass.takes_args:
88
80
        aname = aname.upper()
89
81
        if aname[-1] in ['$', '+']:
92
84
            aname = '[' + aname[:-1] + ']'
93
85
        elif aname[-1] == '*':
94
86
            aname = '[' + aname[:-1] + '...]'
95
 
        print aname,
96
 
    print 
97
 
    print short
 
87
        s += aname + ' '
 
88
            
 
89
    assert s[-1] == ' '
 
90
    s = s[:-1]
 
91
    
 
92
    return s
 
93
 
 
94
 
 
95
def help_on_command(cmdname, outfile = None):
 
96
    cmdname = str(cmdname)
 
97
 
 
98
    if outfile == None:
 
99
        outfile = sys.stdout
 
100
 
 
101
    from inspect import getdoc
 
102
    import commands
 
103
    topic, cmdclass = commands.get_cmd_class(cmdname)
 
104
 
 
105
    doc = getdoc(cmdclass)
 
106
    if doc == None:
 
107
        raise NotImplementedError("sorry, no detailed help yet for %r" % cmdname)
 
108
 
 
109
    outfile.write('usage: ' + command_usage(topic, cmdclass) + '\n')
98
110
 
99
111
    if cmdclass.aliases:
100
 
        print 'aliases: ' + ', '.join(cmdclass.aliases)
101
 
    
102
 
    if rest:
103
 
        print rest
104
 
 
105
 
    help_on_option(cmdclass.takes_options)
106
 
 
107
 
 
108
 
def help_on_option(options):
 
112
        outfile.write('aliases: ' + ', '.join(cmdclass.aliases) + '\n')
 
113
    
 
114
    outfile.write(doc)
 
115
    if doc[-1] != '\n':
 
116
        outfile.write('\n')
 
117
    
 
118
    help_on_option(cmdclass.takes_options, outfile = None)
 
119
 
 
120
 
 
121
def help_on_option(options, outfile = None):
109
122
    import commands
110
123
    
111
124
    if not options:
112
125
        return
113
126
    
114
 
    print
115
 
    print 'options:'
 
127
    if outfile == None:
 
128
        outfile = sys.stdout
 
129
 
 
130
    outfile.write('\noptions:\n')
116
131
    for on in options:
117
132
        l = '    --' + on
118
133
        for shortname, longname in commands.SHORT_OPTIONS.items():
119
134
            if longname == on:
120
135
                l += ', -' + shortname
121
136
                break
122
 
        print l
123
 
 
124
 
 
125
 
def help_commands():
 
137
        outfile.write(l + '\n')
 
138
 
 
139
 
 
140
def help_commands(outfile = None):
126
141
    """List all commands"""
127
142
    import inspect
128
143
    import commands
 
144
 
 
145
    if outfile == None:
 
146
        outfile = sys.stdout
129
147
    
130
148
    accu = []
131
149
    for cmdname, cmdclass in commands.get_all_cmds():
134
152
    for cmdname, cmdclass in accu:
135
153
        if cmdclass.hidden:
136
154
            continue
137
 
        print cmdname
 
155
        outfile.write(command_usage(cmdname, cmdclass) + '\n')
138
156
        help = inspect.getdoc(cmdclass)
139
157
        if help:
140
 
            print "    " + help.split('\n', 1)[0]
 
158
            outfile.write("    " + help.split('\n', 1)[0] + '\n')
 
159
 
141
160
            
142
161