summaryrefslogtreecommitdiff
path: root/helpcontent2/to-wiki/getalltitles.py
blob: f4034ab34dcac722d12f663a6dbc77050a4f430f (plain)
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#!/usr/bin/env python

import sys
import os
import xml.parsers.expat

title=""
parsing=True
istitle=False
alltitles=[]

def is_present(title):
    for i in alltitles:
        try:
            if i.strip() == title.strip():
                return True
        except:
            return False
    return False

def make_unique(title):
    n=0
    t = title
    while is_present(t):
        n=n+1
        t = title+"_%d"%(n)
    return t

replace_text_list = [
        ["$[officename]","LibreOffice"],
        ["%PRODUCTNAME","LibreOffice"],
        ['"+"',"Plus"],
        ['"*"',"Star"],
        ['"-"',"Minus"],
        ['"/"',"Slash"],
        ['"^"',"Cap"],
        [')','_'],
        ['(','_'],
        ['\\','_'],
        ['/','_'],
        ['&',"and"],
        [';','_']
        ]

replace_readable_list = [
        ["$[officename]","{{ProductName}}"],
        ["%PRODUCTNAME","{{ProductName}}"]
        ]

modules_list = [
        ["sbasic","Basic"],
        ["scalc","Calc"],
        ["schart","Chart"],
        ["sdraw","Draw"],
        ["shared","All"],
        ["simpress","Impress"],
        ["smath","Math"],
        ["swriter","Writer"]
        ]

def get_module(text):
    for i in modules_list:
        if text.find(i[0]) >=0:
            return i[1]
    return ""

def replace_text(text, replace_list):
    for i in replace_list:
        if text.find(i[0]) >= 0:
            text = text.replace(i[0],i[1])
    return text

def wiki_text(text):
    return replace_text(text, replace_text_list)

def readable_text(text):
    return replace_text(text, replace_readable_list)

def start_element(name, attrs):
    global parsing, istitle, title
    if not parsing:
        return
    if name == 'title':
        istitle=True
        title = ""

def end_element(name):
    global parsing, istitle
    if not parsing:
        return
    if name == 'title':
        parsing = False
        istitle = False

def char_data(data):
    global title, parsing
    if not istitle:
        return
    title = title + data

def parsexhp(filename):
    global parsing, title
    parsing = True
    file=open(filename,"r")
    p = xml.parsers.expat.ParserCreate()
    p.StartElementHandler = start_element
    p.EndElementHandler = end_element
    p.CharacterDataHandler = char_data
    buf = file.read()
    try:
        p.Parse(buf)
    except:
        sys.stderr.write('Cannot parse %s, skipping it\n'% filename)
        file.close()
        return
    file.close()
    if len(title):
        readable_title = readable_text(title)
        title = get_module(filename) + "/" + wiki_text(title)
        title = title.replace(" ", "_")
        title = make_unique(title)
        alltitles.append(title)
        print filename + ";" + title + ";" + readable_title

if len(sys.argv) < 2:
    print "getalltitles.py <directory>"
    print "e.g. getalltitles.py helcontent2/source/text/scalc"
    sys.exit(1)

pattern = "xhp"

for root, dirs, files in os.walk(sys.argv[1]):
    for i in files:
        if i.find(pattern) >= 0:
            parsexhp(root+"/"+i)