/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to generate_docs.py

  • Committer: John Arbash Meinel
  • Date: 2006-07-18 18:57:54 UTC
  • mto: This revision was merged to the branch mainline in revision 1868.
  • Revision ID: john@arbash-meinel.com-20060718185754-4007745748e28db9
Commit timestamp restricted to 1ms precision.

The old code would restrict to 1s resolution if the timestamp was
supplied, while it preserved full resolution if the timestamp was
auto generated. Now both paths preserve only 1ms resolution.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/python
 
2
 
 
3
# Copyright 2005 Canonical Ltd.
 
4
 
 
5
# This program is free software; you can redistribute it and/or modify
 
6
# it under the terms of the GNU General Public License as published by
 
7
# the Free Software Foundation; either version 2 of the License, or
 
8
# (at your option) any later version.
 
9
 
 
10
# This program is distributed in the hope that it will be useful,
 
11
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
# GNU General Public License for more details.
 
14
 
 
15
# You should have received a copy of the GNU General Public License
 
16
# along with this program; if not, write to the Free Software
 
17
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
18
"""%(prog)s - generate information from built-in bzr help
 
19
 
 
20
%(prog)s creates a file with information on bzr in one of
 
21
several different output formats:
 
22
 
 
23
    man              man page
 
24
    bash_completion  bash completion script
 
25
    ...
 
26
 
 
27
Examples: 
 
28
 
 
29
    python2.4 generated-docs.py man
 
30
    python2.4 generated-docs.py bash_completion
 
31
 
 
32
Run "%(prog)s --help" for the option reference.
 
33
"""
 
34
 
 
35
import sys
 
36
from optparse import OptionParser
 
37
 
 
38
import tools.doc_generate
 
39
 
 
40
def main(argv):
 
41
    parser = OptionParser(usage="%prog [options] OUTPUT_FORMAT")
 
42
 
 
43
    parser.add_option("-s", "--show-filename",
 
44
                      action="store_true", dest="show_filename", default=False,
 
45
                      help="print default filename on stdout")
 
46
 
 
47
    parser.add_option("-o", "--output", dest="filename", metavar="FILE",
 
48
                      help="write output to FILE")
 
49
 
 
50
    parser.add_option("-b", "--bzr-name",
 
51
                      dest="bzr_name", default="bzr", metavar="EXEC_NAME",
 
52
                      help="name of bzr executable")
 
53
 
 
54
    parser.add_option("-e", "--examples",
 
55
                      action="callback", callback=print_extended_help,
 
56
                      help="Examples of ways to call generate_doc")
 
57
 
 
58
 
 
59
    (options, args) = parser.parse_args(argv)
 
60
 
 
61
    if len(args) != 2:
 
62
        parser.print_help()
 
63
        sys.exit(1)
 
64
 
 
65
    infogen_type = args[1]
 
66
    infogen_mod = tools.doc_generate.get_module(infogen_type)
 
67
 
 
68
    if options.filename:
 
69
        outfilename = options.filename
 
70
    else:
 
71
        outfilename = infogen_mod.get_filename(options)
 
72
 
 
73
    if outfilename == "-":
 
74
        outfile = sys.stdout
 
75
    else:
 
76
        outfile = open(outfilename,"w")
 
77
 
 
78
    if options.show_filename and (outfilename != "-"):
 
79
        print >>sys.stdout, outfilename
 
80
    
 
81
    infogen_mod.infogen(options, outfile)
 
82
 
 
83
def print_extended_help(option, opt, value, parser):
 
84
    """ Program help examples
 
85
 
 
86
    Prints out the examples stored in the docstring. 
 
87
 
 
88
    """
 
89
    print >>sys.stdout, __doc__ % {"prog":sys.argv[0]}
 
90
    sys.exit(0)
 
91
 
 
92
if __name__ == '__main__':
 
93
    main(sys.argv)