3 # Copyright (c) 2010, 2011, 2012, 2013, 2014, 2015 Nicira, Inc.
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at:
9 # http://www.apache.org/licenses/LICENSE-2.0
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
17 from datetime import date
21 import xml.dom.minidom
23 from build.nroff import *
29 %(argv0)s: XML to nroff converter
30 Converts the XML format supplied as input into an nroff-formatted manpage.
31 usage: %(argv0)s [OPTIONS] INPUT.XML [VAR=VALUE]...
32 where INPUT.XML is a manpage in an OVS-specific XML format.
34 Each VAR, when enclosed by "@"s in the input, is replaced by its
35 corresponding VALUE, with characters &<>"' in VALUE escaped.
37 The following options are also available:
38 --version=VERSION use VERSION to display on document footer
39 -h, --help display this help message\
40 """ % {'argv0': argv0}
43 def manpage_to_nroff(xml_file, subst, version=None):
47 for k, v in subst.iteritems():
48 line = line.replace(k, v)
50 doc = xml.dom.minidom.parseString(''.join(input)).documentElement
51 d = date.fromtimestamp(os.stat(xml_file).st_mtime)
55 program = doc.attributes['program'].nodeValue
56 title = doc.attributes['title'].nodeValue
57 section = doc.attributes['section'].nodeValue
59 # Putting '\" p as the first line tells "man" that the manpage
60 # needs to be preprocessed by "pic".
63 .TH "%s" %s "%s" "Open vSwitch %s" "Open vSwitch Manual"
64 .fp 5 L CR \\" Make fixed-width font available as \\fL.
76 ''' % (text_to_nroff(program), text_to_nroff(section),
77 text_to_nroff(title), text_to_nroff(version))
79 s += block_xml_to_nroff(doc.childNodes) + "\n"
84 if __name__ == "__main__":
86 options, args = getopt.gnu_getopt(sys.argv[1:], 'hV',
88 except getopt.GetoptError, geo:
89 sys.stderr.write("%s: %s\n" % (argv0, geo.msg))
95 for key, value in options:
96 if key == '--version':
98 elif key in ['-h', '--help']:
104 sys.stderr.write("%s: exactly 1 non-option arguments required "
105 "(use --help for help)\n" % argv0)
110 var, value = s.split('=', 1)
111 value = value.replace('&', '&')
112 value = value.replace('<', '<')
113 value = value.replace('>', '>')
114 value = value.replace('"', '"')
115 value = value.replace("'", ''')
116 subst['@%s@' % var] = value
119 s = manpage_to_nroff(args[0], subst, version)
120 except error.Error, e:
121 sys.stderr.write("%s: %s\n" % (argv0, e.msg))
123 for line in s.splitlines():