File: Help2Html.py

package info (click to toggle)
qgis 3.40.6%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 1,181,336 kB
  • sloc: cpp: 1,593,302; python: 370,494; xml: 23,474; perl: 3,664; sh: 3,482; ansic: 2,257; sql: 2,133; yacc: 1,068; lex: 577; javascript: 540; lisp: 411; makefile: 157
file content (107 lines) | stat: -rw-r--r-- 3,558 bytes parent folder | download | duplicates (6)
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
"""
***************************************************************************
    Help2Html.py
    ---------------------
    Date                 : August 2012
    Copyright            : (C) 2012 by Victor Olaya
    Email                : volayaf at gmail dot com
***************************************************************************
*                                                                         *
*   This program is free software; you can redistribute it and/or modify  *
*   it under the terms of the GNU General Public License as published by  *
*   the Free Software Foundation; either version 2 of the License, or     *
*   (at your option) any later version.                                   *
*                                                                         *
***************************************************************************
"""

__author__ = "Victor Olaya"
__date__ = "August 2012"
__copyright__ = "(C) 2012, Victor Olaya"

import os
import re
import json

from qgis.PyQt.QtCore import QCoreApplication, QUrl

from processing.tools import system

ALG_DESC = "ALG_DESC"
ALG_CREATOR = "ALG_CREATOR"
ALG_HELP_CREATOR = "ALG_HELP_CREATOR"
ALG_VERSION = "ALG_VERSION"

exps = [
    (r"\*(.*?)\*", r"<i>\1</i>"),
    ("``(.*?)``", r'<FONT FACE="courier">\1</FONT>'),
    ("(.*?)\n==+\n+?", r"<h2>\1</h2>"),
    ("(.*?)\n--+\n+?", r"<h3>\1</h3>"),
    (r"::(\s*\n(\s*\n)*((\s+).*?\n)(((\4).*?\n)|(\s*\n))*)", r"<pre>\1</pre>"),
    ("\n+", "</p><p>"),
]


def getHtmlFromRstFile(rst):
    if not os.path.exists(rst):
        return None
    with open(rst) as f:
        lines = f.readlines()
    s = "".join(lines)
    for exp, replace in exps:
        p = re.compile(exp)
        s = p.sub(replace, s)
    return s


def getHtmlFromHelpFile(alg, helpFile):
    if not os.path.exists(helpFile):
        return None
    try:
        with open(helpFile) as f:
            descriptions = json.load(f)

        content = getHtmlFromDescriptionsDict(alg, descriptions)
        algGroup, algName = alg.id().split(":")
        filePath = os.path.join(system.tempHelpFolder(), f"{algGroup}_{algName}.html")
        with open(filePath, "w", encoding="utf-8") as f:
            f.write(content)
        return QUrl.fromLocalFile(filePath).toString()
    except:
        return None


def getHtmlFromDescriptionsDict(alg, descriptions):
    s = tr("<html><body><h2>Algorithm description</h2>\n")
    s += "<p>" + getDescription(ALG_DESC, descriptions) + "</p>\n"
    s += tr("<h2>Input parameters</h2>\n")
    for param in alg.parameterDefinitions():
        s += "<h3>" + param.description() + "</h3>\n"
        s += "<p>" + getDescription(param.name(), descriptions) + "</p>\n"
    s += tr("<h2>Outputs</h2>\n")
    for out in alg.outputs:
        s += "<h3>" + out.description() + "</h3>\n"
        s += "<p>" + getDescription(out.name(), descriptions) + "</p>\n"
    s += "<br>"
    s += tr('<p align="right">Algorithm author: {0}</p>').format(
        getDescription(ALG_CREATOR, descriptions)
    )
    s += tr('<p align="right">Help author: {0}</p>').format(
        getDescription(ALG_HELP_CREATOR, descriptions)
    )
    s += tr('<p align="right">Algorithm version: {0}</p>').format(
        getDescription(ALG_VERSION, descriptions)
    )
    s += "</body></html>"
    return s


def getDescription(name, descriptions):
    if name in descriptions:
        return str(descriptions[name]).replace("\n", "<br>")
    else:
        return ""


def tr(string):
    return QCoreApplication.translate("Help2Html", string)