diff options
Diffstat (limited to 'sources/pyside2/doc/pyhtml2devhelp.py')
-rw-r--r-- | sources/pyside2/doc/pyhtml2devhelp.py | 256 |
1 files changed, 0 insertions, 256 deletions
diff --git a/sources/pyside2/doc/pyhtml2devhelp.py b/sources/pyside2/doc/pyhtml2devhelp.py deleted file mode 100644 index aa39036d3..000000000 --- a/sources/pyside2/doc/pyhtml2devhelp.py +++ /dev/null @@ -1,256 +0,0 @@ -#! /usr/bin/python - -############################################################################# -## -## Copyright (C) 2016 The Qt Company Ltd. -## Copyright (C) 2009 Matthias Klose <doko@debian.org> -## Contact: https://www.qt.io/licensing/ -## -## This file is part of Qt for Python tools. -## -## $QT_BEGIN_LICENSE:GPL-EXCEPT$ -## Commercial License Usage -## Licensees holding valid commercial Qt licenses may use this file in -## accordance with the commercial license agreement provided with the -## Software or, alternatively, in accordance with the terms contained in -## a written agreement between you and The Qt Company. For licensing terms -## and conditions see https://www.qt.io/terms-conditions. For further -## information use the contact form at https://www.qt.io/contact-us. -## -## GNU General Public License Usage -## Alternatively, this file may be used under the terms of the GNU -## General Public License version 3 as published by the Free Software -## Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT -## included in the packaging of this file. Please review the following -## information to ensure the GNU General Public License requirements will -## be met: https://www.gnu.org/licenses/gpl-3.0.html. -## -## $QT_END_LICENSE$ -## -############################################################################# - -""" - This script is based on Python2.6 Ubuntu package script -""" - -import formatter, htmllib -import os, sys, re - -class PyHTMLParser(htmllib.HTMLParser): - pages_to_include = set(('index.html', 'PySide/QtHelp/index.html', 'PySide/QtSvg/index.html', - 'PySide/QtGui/index.html', 'PySide/QtNetwork/index.html', 'PySide/QtWebKit/index.html', - 'PySide/QtUiTools/index.html', 'PySide/QtXml/index.html', 'PySide/QtCore/index.html', - 'PySide/QtScriptTools/index.html', 'PySide/QtOpenGL/index.html', 'PySide/QtScript/index.html', - 'PySide/QtSql/index.html', 'howto-build/index.html')) - - def __init__(self, formatter, basedir, fn, indent, parents=set()): - htmllib.HTMLParser.__init__(self, formatter) - self.basedir = basedir - self.dir, self.fn = os.path.split(fn) - self.data = '' - self.parents = parents - self.link = {} - self.indent = indent - self.last_indent = indent - 1 - self.sub_indent = 0 - self.sub_count = 0 - self.next_link = False - - def process_link(self): - new_href = os.path.join(self.dir, self.link['href']) - text = self.link['text'] - indent = self.indent + self.sub_indent - if self.last_indent == indent: - print '%s</sub>' % (' ' * self.last_indent) - self.sub_count -= 1 - print '%s<sub link="%s" name="%s">' % (' ' * indent, new_href, text) - self.sub_count += 1 - self.last_indent = self.indent + self.sub_indent - - def start_li(self, attrs): - self.sub_indent += 1 - self.next_link = True - - def end_li(self): - indent = self.indent + self.sub_indent - if self.sub_count > 0: - print '%s</sub>' % (' ' * self.last_indent) - self.sub_count -= 1 - self.last_indent -= 1 - self.sub_indent -= 1 - - def start_a(self, attrs): - self.link = {} - for attr in attrs: - self.link[attr[0]] = attr[1] - self.data = '' - - def end_a(self): - process = False - text = self.data.replace('\t', '').replace('\n', ' ').replace('&', '&').replace('<', '<').replace('>', '>') - self.link['text'] = text - # handle a tag without href attribute - try: - href = self.link['href'] - except KeyError: - return - - abs_href = os.path.join(self.basedir, href) - if abs_href in self.parents: - return - if href.startswith('..') or href.startswith('http:') \ - or href.startswith('mailto:') or href.startswith('news:'): - return - if href in ('', 'about.html', 'modindex.html', 'genindex.html', 'glossary.html', - 'search.html', 'contents.html', 'download.html', 'bugs.html', - 'license.html', 'copyright.html'): - return - - if self.link.has_key('class'): - if self.link['class'] in ('biglink'): - process = True - if self.link['class'] in ('reference external'): - if self.next_link: - process = True - next_link = False - - if process == True: - self.process_link() - if href in self.pages_to_include: - self.parse_file(os.path.join(self.dir, href)) - - def finish(self): - if self.sub_count > 0: - print '%s</sub>' % (' ' * self.last_indent) - - def handle_data(self, data): - self.data += data - - def parse_file(self, href): - # TODO basedir bestimmen - parent = os.path.join(self.basedir, self.fn) - self.parents.add(parent) - parser = PyHTMLParser(formatter.NullFormatter(), - self.basedir, href, self.indent + 1, - self.parents) - text = file(self.basedir + '/' + href).read() - parser.feed(text) - parser.finish() - parser.close() - if parent in self.parents: - self.parents.remove(parent) - -class PyIdxHTMLParser(htmllib.HTMLParser): - def __init__(self, formatter, basedir, fn, indent): - htmllib.HTMLParser.__init__(self, formatter) - self.basedir = basedir - self.dir, self.fn = os.path.split(fn) - self.data = '' - self.link = {} - self.indent = indent - self.active = False - self.indented = False - self.nolink = False - self.header = '' - self.last_letter = 'Z' - self.last_text = '' - - def process_link(self): - new_href = os.path.join(self.dir, self.link['href']) - text = self.link['text'] - if not self.active: - return - if text.startswith('['): - return - if self.link.get('rel', None) in ('prev', 'parent', 'next', 'contents', 'index'): - return - if self.indented: - text = self.last_text + ' ' + text - else: - # Save it in case we need it again - self.last_text = re.sub(' \([\w\-\.\s]+\)', '', text) - indent = self.indent - print '%s<function link="%s" name="%s"/>' % (' ' * indent, new_href, text) - - def start_dl(self, attrs): - if self.last_text: - # Looks like we found the second part to a command - self.indented = True - - def end_dl(self): - self.indented = False - - def start_dt(self, attrs): - self.data = '' - self.nolink = True - - def end_dt(self): - if not self.active: - return - if self.nolink == True: - # Looks like we found the first part to a command - self.last_text = re.sub(' \([\w\-\.\s]+\)', '', self.data) - self.nolink = False - - def start_h2(self, attrs): - for k, v in attrs: - if k == 'id': - self.header = v - if v == '_': - self.active = True - - def start_td(self, attrs): - self.indented = False - self.last_text = '' - - def start_table(self, attrs): - pass - - def end_table(self): - if self.header == self.last_letter: - self.active = False - - def start_a(self, attrs): - self.nolink = False - self.link = {} - for attr in attrs: - self.link[attr[0]] = attr[1] - self.data = '' - - def end_a(self): - text = self.data.replace('\t', '').replace('\n', ' ').replace('&', '&').replace('<', '<').replace('>', '>') - self.link['text'] = text - # handle a tag without href attribute - try: - href = self.link['href'] - except KeyError: - return - self.process_link() - - def handle_data(self, data): - self.data += data - -def main(): - base = sys.argv[1] - fn = sys.argv[2] - - parser = PyHTMLParser(formatter.NullFormatter(), base, fn, indent=0) - print '<?xml version="1.0" encoding="iso-8859-1"?>' - print '<book title="PySide %s Documentation" name="PySide" version="%s" link="index.html">' % (sys.argv[3], sys.argv[3]) - print '<chapters>' - parser.parse_file(fn) - print '</chapters>' - - print '<functions>' - - fn = 'genindex.html' - parser = PyIdxHTMLParser(formatter.NullFormatter(), base, fn, indent=1) - text = file(base + '/' + fn).read() - parser.feed(text) - parser.close() - - print '</functions>' - print '</book>' - -main() - |