1
# Copyright (C) 2004, 2005 by Canonical Ltd
 
 
3
# This program is free software; you can redistribute it and/or modify
 
 
4
# it under the terms of the GNU General Public License as published by
 
 
5
# the Free Software Foundation; either version 2 of the License, or
 
 
6
# (at your option) any later version.
 
 
8
# This program is distributed in the hope that it will be useful,
 
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
 
11
# GNU General Public License for more details.
 
 
13
# You should have received a copy of the GNU General Public License
 
 
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
 
 
18
"""Bazaar-NG -- a free distributed version-control tool
 
 
21
**WARNING: THIS IS AN UNSTABLE DEVELOPMENT VERSION**
 
 
23
* Metadata format is not stable yet -- you may need to
 
 
24
  discard history in the future.
 
 
26
* Many commands unimplemented or partially implemented.
 
 
28
* Space-inefficient storage.
 
 
30
* No merge operators yet.
 
 
37
      Show software version/licence/non-warranty.
 
 
39
      Start versioning the current directory
 
 
43
      Show revision history.
 
 
46
  bzr move FROM... DESTDIR
 
 
47
      Move one or more files to a different directory.
 
 
49
      Show changes from last revision to working copy.
 
 
50
  bzr commit -m 'MESSAGE'
 
 
51
      Store current state as new revision.
 
 
52
  bzr export [-r REVNO] DESTINATION
 
 
53
      Export the branch state at a previous version.
 
 
55
      Show summary of pending changes.
 
 
57
      Make a file not versioned.
 
 
59
      Show statistics about this branch.
 
 
61
      Verify history is stored safely. 
 
 
62
  (for more type 'bzr help commands')
 
 
69
    elif topic == 'commands':
 
 
72
        help_on_command(topic)
 
 
75
def help_on_command(cmdname):
 
 
76
    cmdname = str(cmdname)
 
 
78
    from inspect import getdoc
 
 
80
    topic, cmdclass = commands.get_cmd_class(cmdname)
 
 
82
    doc = getdoc(cmdclass)
 
 
84
        raise NotImplementedError("sorry, no detailed help yet for %r" % cmdname)
 
 
87
        short, rest = doc.split('\n', 1)
 
 
92
    print 'usage: bzr ' + topic,
 
 
93
    for aname in cmdclass.takes_args:
 
 
95
        if aname[-1] in ['$', '+']:
 
 
96
            aname = aname[:-1] + '...'
 
 
97
        elif aname[-1] == '?':
 
 
98
            aname = '[' + aname[:-1] + ']'
 
 
99
        elif aname[-1] == '*':
 
 
100
            aname = '[' + aname[:-1] + '...]'
 
 
106
        print 'aliases: ' + ', '.join(cmdclass.aliases)
 
 
111
    help_on_option(cmdclass.takes_options)
 
 
114
def help_on_option(options):
 
 
124
        for shortname, longname in commands.SHORT_OPTIONS.items():
 
 
126
                l += ', -' + shortname
 
 
132
    """List all commands"""
 
 
137
    for cmdname, cmdclass in commands.get_all_cmds():
 
 
138
        accu.append((cmdname, cmdclass))
 
 
140
    for cmdname, cmdclass in accu:
 
 
144
        help = inspect.getdoc(cmdclass)
 
 
146
            print "    " + help.split('\n', 1)[0]