~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/shellcomplete.py

  • Committer: Martin Pool
  • Date: 2005-08-30 03:29:32 UTC
  • Revision ID: mbp@sourcefrog.net-20050830032932-1ad1c40cfacde866
- add a docstring for the placeholder plugin

- remove the checkperms shell plugin, which was in the wrong
  place anyhow

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006 Canonical Ltd
2
 
#
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.
7
 
#
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.
12
 
#
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
16
 
 
17
1
import sys
18
2
 
19
3
 
20
4
def shellcomplete(context=None, outfile = None):
21
 
    if outfile is None:
 
5
    if outfile == None:
22
6
        outfile = sys.stdout
23
 
    if context is None:
 
7
    if context == None:
24
8
        shellcomplete_commands(outfile = outfile)
25
9
    else:
26
10
        shellcomplete_on_command(context, outfile = outfile)
28
12
def shellcomplete_on_command(cmdname, outfile = None):
29
13
    cmdname = str(cmdname)
30
14
 
31
 
    if outfile is None:
 
15
    if outfile == None:
32
16
        outfile = sys.stdout
33
17
 
34
18
    from inspect import getdoc
35
19
    import commands
36
 
    cmdobj = commands.get_cmd_object(cmdname)
 
20
    context, cmdclass = commands.get_cmd_class(cmdname)
37
21
 
38
 
    doc = getdoc(cmdobj)
39
 
    if doc is None:
 
22
    doc = getdoc(cmdclass)
 
23
    if doc == None:
40
24
        raise NotImplementedError("sorry, no detailed shellcomplete yet for %r" % cmdname)
41
25
 
42
 
    shellcomplete_on_option(cmdobj.takes_options, outfile = None)
43
 
    for aname in cmdobj.takes_args:
44
 
        outfile.write(aname + '\n')
45
 
 
46
 
 
47
 
def shellcomplete_on_option(options, outfile=None):
48
 
    from bzrlib.option import Option
 
26
    shellcomplete_on_option(cmdclass.takes_options, outfile = None)
 
27
    for aname in cmdclass.takes_args:
 
28
            outfile.write(aname + '\n')
 
29
 
 
30
 
 
31
def shellcomplete_on_option(options, outfile = None):
 
32
    import commands
 
33
    
49
34
    if not options:
50
35
        return
51
 
    if outfile is None:
 
36
    
 
37
    if outfile == None:
52
38
        outfile = sys.stdout
 
39
 
53
40
    for on in options:
54
 
        for shortname, longname in Option.SHORT_OPTIONS.items():
 
41
        for shortname, longname in commands.SHORT_OPTIONS.items():
55
42
            if longname == on:
56
43
                l = '"(--' + on + ' -' + shortname + ')"{--' + on + ',-' + shortname + '}'
57
44
                break
66
53
    import commands
67
54
    from inspect import getdoc
68
55
    
69
 
    if outfile is None:
 
56
    if outfile == None:
70
57
        outfile = sys.stdout
71
58
    
72
59
    cmds = []
79
66
        if cmdclass.hidden:
80
67
            continue
81
68
        doc = getdoc(cmdclass)
82
 
        if doc is None:
 
69
        if doc == None:
83
70
            outfile.write(cmdname + '\n')
84
71
        else:
85
72
            doclines = doc.splitlines()