-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME
71 lines (60 loc) · 2.63 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
selfcompletion
==============
selfcompletion is a layer on top of argparse to take the fine-grained model
argparse builds of the arguments your program accepts and automatically
generate an extra '--_completion' argument that generates all possible
completions given a partial command line as a string.
The '--_completion' argument in turn is used by a generic bash programmable
completion script that tries '--_completion' on any program that doesn't have
its own completion already available, renders the output of the program's
built-in completion if available, and otherwise silently falls back to the
shell default.
About
-----
* Author: David Barnett <[email protected]>
* Home: http://github.com/dbarnett/cyberpyg
* License: BSD
How to Use
----------
prog.py:
#!/usr/bin/env python
try:
from selfcompletion import SelfCompletingArgumentParser as ArgumentParser
except ImportError, e:
from argparse import ArgumentParser
parser = ArgumentParser(description='Process some integers.')
parser.add_argument('integers', metavar='N', type=int, nargs='+',
help='an integer for the accumulator')
parser.add_argument('--sum', dest='accumulate', action='store_const',
const=sum, default=max,
help='sum the integers (default: find the max)')
args = parser.parse_args()
print(args.accumulate(args.integers))
$ chmod +x prog.py
$ ./prog.py <TAB><TAB>
0 4 8 --help
1 5 9 --sum
2 6 --_completion
3 7 -h
$ ./prog.py -<TAB><TAB>
--_completion -h --help --sum
$ ./prog.py 1<TAB><TAB>
0 1 2 3 4 5 6 7 8 9
Why?
----
Command-line completion is very, very cool, and along with good built-in help,
can make even the most complex program usable. Unfortunately, it's a pain to
implement. It requires an entirely separate shell script *per shell syntax*
to support (e.g., bash, zsh, fish), it's a challenge for maintainers to
distribute, and it must be kept in sync with changes in the program itself or
else it becomes less useful or even gets in the way.
selfcompletion is an attempt to create a standard, and reduce a matrix of
supported shell/application combinations to a list of supported shells and a
list of compliant programs. Now all python software using argparse can add
fine-grained command-line completion essentially for free!
Installing
----------
selfcompletion uses distutils2. To install, run
pysetup install
or
python -m distutils2.run install