summaryrefslogtreecommitdiff
path: root/helpcontent2/to-wiki
diff options
context:
space:
mode:
authorJan Holesovsky <kendy@suse.cz>2010-11-30 15:29:02 +0100
committerJan Holesovsky <kendy@suse.cz>2010-11-30 15:29:02 +0100
commit49b5213636d2775b240e3126a85ea99a6cb4e2fa (patch)
treec4a3a0f7be6140f498567004c8eb939a8e0c987e /helpcontent2/to-wiki
parentfb79b6adf84fb7bd613069b8ec007bfbf9ed0d7c (diff)
wikihelp: Improve the generation of conditionals (switch/switchinline).
Diffstat (limited to 'helpcontent2/to-wiki')
-rwxr-xr-xhelpcontent2/to-wiki/getalltitles.py25
-rwxr-xr-xhelpcontent2/to-wiki/wikiconv2.py49
2 files changed, 46 insertions, 28 deletions
diff --git a/helpcontent2/to-wiki/getalltitles.py b/helpcontent2/to-wiki/getalltitles.py
index 1e80584c2c..b1a7392617 100755
--- a/helpcontent2/to-wiki/getalltitles.py
+++ b/helpcontent2/to-wiki/getalltitles.py
@@ -51,15 +51,15 @@ modules_list = [
["scalc","Calc"],
["schart","Chart"],
["sdraw","Draw"],
- ["shared","All"],
["simpress","Impress"],
["smath","Math"],
- ["swriter","Writer"]
+ ["swriter","Writer"],
+ ["shared","All"]
]
def get_module(text):
for i in modules_list:
- if text.find(i[0]) >=0:
+ if text.find('/' + i[0] + '/') >=0:
return i[1]
return ""
@@ -98,6 +98,10 @@ class TitleParser:
return self.title.strip()
def parsexhp(filename):
+ module = get_module(filename)
+ if module == '':
+ return
+
parsing = True
file=open(filename,"r")
p = xml.parsers.expat.ParserCreate()
@@ -114,19 +118,20 @@ def parsexhp(filename):
return
file.close()
title = tp.get_title()
- if len(title):
+ if len(title) > 0:
readable_title = readable_text(title)
- title = get_module(filename) + "/" + wiki_text(title)
- title = title.replace(" ", "_")
- title = title.replace("___", "_")
- title = title.replace("__", "_")
+ title = module + '/' + wiki_text(title)
+ title = title.replace(' ', '_')
+ title = title.replace('___', '_')
+ title = title.replace('__', '_')
+ title = title.strip('_')
title = make_unique(title)
alltitles.append(title)
- print filename + ";" + title + ";" + readable_title
+ print filename + ';' + title + ';' + readable_title
if len(sys.argv) < 2:
print "getalltitles.py <directory>"
- print "e.g. getalltitles.py helcontent2/source/text/scalc"
+ print "e.g. getalltitles.py source/text/scalc"
sys.exit(1)
pattern = "xhp"
diff --git a/helpcontent2/to-wiki/wikiconv2.py b/helpcontent2/to-wiki/wikiconv2.py
index 5b4cef7371..543a6cf31b 100755
--- a/helpcontent2/to-wiki/wikiconv2.py
+++ b/helpcontent2/to-wiki/wikiconv2.py
@@ -7,7 +7,7 @@ import codecs
from threading import Thread
root="source/"
-max_threads = 4
+max_threads = 25
titles = [[]]
@@ -339,7 +339,7 @@ class XhpFile(ElementBase):
elif name == 'sort':
self.parse_child(Sort(attrs, self))
elif name == 'switch':
- self.parse_child(Switch(attrs, self))
+ self.parse_child(Switch(attrs, self, parser.embedding_app))
elif name == 'table':
self.parse_child(Table(attrs, self))
else:
@@ -653,7 +653,7 @@ class Section(ElementBase):
# sections can be nested
self.parse_child(Section(attrs, self, self.depth))
elif name == 'switch':
- self.parse_child(Switch(attrs, self))
+ self.parse_child(Switch(attrs, self, parser.embedding_app))
elif name == 'table':
self.parse_child(Table(attrs, self))
else:
@@ -738,13 +738,12 @@ class Link(ElementBase):
return text
class SwitchInline(ElementBase):
- def __init__(self, attrs, parent):
+ def __init__(self, attrs, parent, app):
ElementBase.__init__(self, 'switchinline', parent)
self.switch = attrs['select']
- self.embedding_app = ''
+ self.embedding_app = app
def start_element(self, parser, name, attrs):
- self.embedding_app = parser.embedding_app
if name == 'caseinline':
self.parse_child(CaseInline(attrs, self, False))
elif name == 'defaultinline':
@@ -782,22 +781,31 @@ class SwitchInline(ElementBase):
# 'shared' into an 'app'
if self.embedding_app == '':
text = ''
+ default = ''
for i in self.objects:
- appls = {'CALC':'Calc', 'CHART':'Chart', 'DRAW':'Draw', \
- 'IMPRESS': 'Impress', 'MATH':'Math', \
- 'WRITER':'Writer', 'default':''}
+ appls = {'BASIC':'Basic', 'CALC':'Calc', \
+ 'CHART':'Chart', 'DRAW':'Draw', \
+ 'IMAGE':'Draw', 'IMPRESS': 'Impress', \
+ 'MATH':'Math', 'WRITER':'Writer', \
+ 'OFFICE':'', 'default':''}
try:
app = appls[i.case]
all = i.get_all()
if all == '':
pass
elif app == '':
- text = text + all
+ default = all
else:
- text = text + '{{OnlyIn%s|%s}}'% (app, all)
+ text = text + '{{WhenIn%s|%s}}'% (app, all)
except:
sys.stderr.write('Unhandled "%s" case in "appl" switchinline.\n'% \
i.case)
+
+ if text == '':
+ text = default
+ elif default != '':
+ text = text + '{{WhenDefault|%s}}'% default
+
return text
else:
for i in self.objects:
@@ -839,8 +847,8 @@ class Case(ElementBase):
self.unhandled_element(parser, name)
class Switch(SwitchInline):
- def __init__(self, attrs, parent):
- SwitchInline.__init__(self, attrs, parent)
+ def __init__(self, attrs, parent, app):
+ SwitchInline.__init__(self, attrs, parent, app)
self.name = 'switch'
def start_element(self, parser, name, attrs):
@@ -931,7 +939,7 @@ class Paragraph(ElementBase):
elif name == 'link':
self.parse_child(Link(attrs, self))
elif name == 'switchinline':
- self.parse_child(SwitchInline(attrs, self))
+ self.parse_child(SwitchInline(attrs, self, parser.embedding_app))
elif name == 'variable':
self.parse_child(Variable(attrs, self, self.depth))
else:
@@ -1037,18 +1045,23 @@ class XhpParser:
self.head_obj = XhpFile()
self.filename = filename
self.follow_embed = follow_embed
- self.embedding_app = embedding_app
self.help_file_name = help_file_name
self.bookmarks = []
self.current_app = ''
- for i in [['scalc', 'CALC'], ['sdraw', 'DRAW'], \
- ['schart', 'CHART'], ['simpress', 'IMPRESS'], \
+ for i in [['sbasic', 'BASIC'], ['scalc', 'CALC'], \
+ ['sdraw', 'DRAW'], ['schart', 'CHART'], \
+ ['simpress', 'IMPRESS'], \
['smath', 'MATH'], ['swriter', 'WRITER']]:
if filename.find('/%s/'% i[0]) >= 0:
self.current_app = i[1]
break
+ if embedding_app != '':
+ self.embedding_app = embedding_app
+ else:
+ self.embedding_app = self.current_app
+
file = codecs.open(filename, "r", "utf-8")
p = xml.parsers.expat.ParserCreate()
@@ -1121,7 +1134,7 @@ if len(sys.argv) > 1:
for title in titles:
while threading.active_count() > max_threads:
- time.sleep(0.1)
+ time.sleep(0.001)
outfile = ""
infile = ""