summaryrefslogtreecommitdiff
path: root/doc/tools/makedoku.py
diff options
context:
space:
mode:
Diffstat (limited to 'doc/tools/makedoku.py')
-rw-r--r--doc/tools/makedoku.py224
1 files changed, 112 insertions, 112 deletions
diff --git a/doc/tools/makedoku.py b/doc/tools/makedoku.py
index 1ab16841b1..97819d7da3 100644
--- a/doc/tools/makedoku.py
+++ b/doc/tools/makedoku.py
@@ -19,14 +19,14 @@ def validate_tag(elem,tag):
if (elem.tag != tag):
print("Tag mismatch, expected '"+tag+"', got "+elem.tag);
sys.exit(255)
-
+
class_names=[]
classes={}
def make_class_list(class_list,columns):
-
+
f=open("class_list.txt","wb")
prev=0
col_max = len(class_list) / columns + 1
@@ -35,13 +35,13 @@ def make_class_list(class_list,columns):
row_count = 0
last_initial = ""
fit_columns=[]
-
+
for n in range(0,columns):
fit_columns+=[[]]
indexers=[]
last_initial=""
-
+
idx=0
for n in class_list:
col = idx/col_max
@@ -52,36 +52,36 @@ def make_class_list(class_list,columns):
if (n[:1]!=last_initial):
indexers+=[n]
last_initial=n[:1]
-
+
row_max=0
-
+
for n in range(0,columns):
if (len(fit_columns[n])>row_max):
row_max=len(fit_columns[n])
-
+
for r in range(0,row_max):
s="|"
- for c in range(0,columns):
+ for c in range(0,columns):
if (r>=len(fit_columns[c])):
continue
-
+
classname = fit_columns[c][r]
initial=classname[0]
if (classname in indexers):
s+="**"+initial+"**|"
else:
s+=" |"
-
+
s+="[["+classname.lower()+"|"+classname+"]]|"
-
+
s+="\n"
f.write(s)
-
-
+
+
def dokuize_text(txt):
-
+
return txt
@@ -95,13 +95,13 @@ def dokuize_text(text):
endq_pos=text.find("]",pos+1)
if (endq_pos==-1):
break
-
+
pre_text=text[:pos]
post_text=text[endq_pos+1:]
tag_text=text[pos+1:endq_pos]
if (tag_text in class_names):
- tag_text="[["+tag_text.lower()+"|"+tag_text+"]]"
+ tag_text="[["+tag_text.lower()+"|"+tag_text+"]]"
else: #command
cmd=tag_text
space_pos=tag_text.find(" ")
@@ -112,7 +112,7 @@ def dokuize_text(text):
elif(cmd.find("method")==0):
cmd=tag_text[:space_pos]
param=tag_text[space_pos+1:]
-
+
if (param.find(".")!=-1):
class_param,method_param=param.split(".")
tag_text="[["+class_param.lower()+"#"+method_param+"|"+class_param+'.'+method_param+"]]"
@@ -123,7 +123,7 @@ def dokuize_text(text):
elif (cmd.find("url=")==0):
tag_text="[["+cmd[4:]+"|"
elif (cmd=="/url"):
- tag_text="]]>"
+ tag_text="]]>"
elif (cmd=="center"):
tag_text=""
elif (cmd=="/center"):
@@ -138,25 +138,25 @@ def dokuize_text(text):
tag_text="__"
else:
tag_text="["+tag_text+"]"
-
-
+
+
text=pre_text+tag_text+post_text
pos=len(pre_text)+len(tag_text)
-
+
#tnode = ET.SubElement(parent,"div")
#tnode.text=text
return text
-
-
+
+
def make_type(t):
global class_names
if (t in class_names):
return "[["+t.lower()+"|"+t+"]]"
return t
-
-
+
+
def make_method(f,name,m,declare,event=False):
-
+
s=" * "
ret_type="void"
args=list(m)
@@ -169,66 +169,66 @@ def make_method(f,name,m,declare,event=False):
idx=int(a.attrib["index"])
else:
continue
-
+
mdata["argidx"].append(idx)
mdata[idx]=a
-
-
- if (not event):
+
+
+ if (not event):
if (-1 in mdata["argidx"]):
s+=make_type(mdata[-1].attrib["type"])
- else:
+ else:
s+="void"
s+=" "
-
+
if (declare):
-
+
#span.attrib["class"]="funcdecl"
#a=ET.SubElement(span,"a")
#a.attrib["name"]=name+"_"+m.attrib["name"]
#a.text=name+"::"+m.attrib["name"]
s+="**"+m.attrib["name"]+"**"
- else:
+ else:
s+="[[#"+m.attrib["name"]+"|"+m.attrib["name"]+"]]"
-
+
s+="**(**"
argfound=False
for a in mdata["argidx"]:
arg=mdata[a]
if (a<0):
continue
- if (a>0):
+ if (a>0):
s+=", "
else:
s+=" "
-
+
s+=make_type(arg.attrib["type"])
if ("name" in arg.attrib):
s+=" "+arg.attrib["name"]
else:
s+=" arg"+str(a)
-
+
if ("default" in arg.attrib):
s+="="+arg.attrib["default"]
-
-
+
+
argfound=True
-
+
if (argfound):
s+=" "
s+="**)**"
-
+
if ("qualifiers" in m.attrib):
s+=" "+m.attrib["qualifiers"]
-
+
f.write(s+"\n")
-
-
+
+
def make_doku_class(node):
name = node.attrib["name"]
-
+
f=open(name.lower()+".txt","wb")
f.write("====== "+name+" ======\n")
@@ -238,26 +238,26 @@ def make_doku_class(node):
f.write("**Inherits:** [["+inh.lower()+"|"+inh+"]]\\\\\n")
if ("category" in node.attrib):
f.write("**Category:** "+node.attrib["category"].strip()+"\\\\\n")
-
+
briefd = node.find("brief_description")
if (briefd!=None):
f.write("===== Brief Description ======\n")
f.write( dokuize_text(briefd.text.strip())+"\n" )
-
- methods = node.find("methods")
-
+
+ methods = node.find("methods")
+
if(methods!=None and len(list(methods))>0):
f.write("===== Member Functions ======\n")
for m in list(methods):
make_method(f,node.attrib["name"],m,False)
-
- events = node.find("signals")
- if(events!=None and len(list(events))>0):
+
+ events = node.find("signals")
+ if(events!=None and len(list(events))>0):
f.write("===== Signals ======\n")
for m in list(events):
make_method(f,node.attrib["name"],m,True,True)
-
- members = node.find("members")
+
+ members = node.find("members")
if(members!=None and len(list(members))>0):
f.write("===== Member Variables ======\n")
@@ -269,33 +269,33 @@ def make_doku_class(node):
if (c.text.strip()!=""):
s+=" - "+c.text.strip()
f.write(s+"\n")
-
-
-
- constants = node.find("constants")
+
+
+
+ constants = node.find("constants")
if(constants!=None and len(list(constants))>0):
f.write("===== Numeric Constants ======\n")
for c in list(constants):
s = " * "
s+="**"+c.attrib["name"]+"**"
if ("value" in c.attrib):
- s+=" = **"+c.attrib["value"]+"**"
+ s+=" = **"+c.attrib["value"]+"**"
if (c.text.strip()!=""):
s+=" - "+c.text.strip()
f.write(s+"\n")
-
-
+
+
descr=node.find("description")
if (descr!=None and descr.text.strip()!=""):
f.write("===== Description ======\n")
f.write(dokuize_text(descr.text.strip())+"\n")
- methods = node.find("methods")
-
+ methods = node.find("methods")
+
if(methods!=None and len(list(methods))>0):
f.write("===== Member Function Description ======\n")
for m in list(methods):
-
+
d=m.find("description")
if (d==None or d.text.strip()==""):
continue
@@ -304,18 +304,18 @@ def make_doku_class(node):
f.write("\\\\\n")
f.write(dokuize_text(d.text.strip()))
f.write("\n")
-
-
-
-
+
+
+
+
"""
div=ET.Element("div")
div.attrib["class"]="class";
a=ET.SubElement(div,"a")
a.attrib["name"]=node.attrib["name"]
-
+
h3=ET.SubElement(a,"h3")
h3.attrib["class"]="title class_title"
h3.text=node.attrib["name"]
@@ -325,63 +325,63 @@ def make_doku_class(node):
div2=ET.SubElement(div,"div")
div2.attrib["class"]="description class_description"
div2.text=briefd.text
-
+
if ("inherits" in node.attrib):
ET.SubElement(div,"br")
- div2=ET.SubElement(div,"div")
+ div2=ET.SubElement(div,"div")
div2.attrib["class"]="inheritance";
span=ET.SubElement(div2,"span")
span.text="Inherits: "
-
+
make_type(node.attrib["inherits"],div2)
-
+
if ("category" in node.attrib):
ET.SubElement(div,"br")
-
- div3=ET.SubElement(div,"div")
+
+ div3=ET.SubElement(div,"div")
div3.attrib["class"]="category";
-
+
span=ET.SubElement(div3,"span")
span.attrib["class"]="category"
span.text="Category: "
-
+
a = ET.SubElement(div3,"a")
a.attrib["class"]="category_ref"
a.text=node.attrib["category"]
catname=a.text
if (catname.rfind("/")!=-1):
- catname=catname[catname.rfind("/"):]
+ catname=catname[catname.rfind("/"):]
catname="CATEGORY_"+catname
-
+
if (single_page):
a.attrib["href"]="#"+catname
else:
a.attrib["href"]="category.html#"+catname
-
-
- methods = node.find("methods")
-
+
+
+ methods = node.find("methods")
+
if(methods!=None and len(list(methods))>0):
h4=ET.SubElement(div,"h4")
h4.text="Public Methods:"
- method_table=ET.SubElement(div,"table")
+ method_table=ET.SubElement(div,"table")
method_table.attrib["class"]="method_list";
for m in list(methods):
# li = ET.SubElement(div2, "li")
method_table.append( make_method_def(node.attrib["name"],m,False) )
- events = node.find("signals")
-
+ events = node.find("signals")
+
if(events!=None and len(list(events))>0):
h4=ET.SubElement(div,"h4")
h4.text="Events:"
- event_table=ET.SubElement(div,"table")
+ event_table=ET.SubElement(div,"table")
event_table.attrib["class"]="method_list";
for m in list(events):
@@ -389,20 +389,20 @@ def make_doku_class(node):
event_table.append( make_method_def(node.attrib["name"],m,False,True) )
- members = node.find("members")
+ members = node.find("members")
if(members!=None and len(list(members))>0):
h4=ET.SubElement(div,"h4")
h4.text="Public Variables:"
- div2=ET.SubElement(div,"div")
+ div2=ET.SubElement(div,"div")
div2.attrib["class"]="member_list";
-
+
for c in list(members):
-
+
li = ET.SubElement(div2, "li")
div3=ET.SubElement(li,"div")
div3.attrib["class"]="member";
- make_type(c.attrib["type"],div3)
+ make_type(c.attrib["type"],div3)
span=ET.SubElement(div3,"span")
span.attrib["class"]="identifier member_name"
span.text=" "+c.attrib["name"]+" "
@@ -411,19 +411,19 @@ def make_doku_class(node):
span.text=c.text
- constants = node.find("constants")
+ constants = node.find("constants")
if(constants!=None and len(list(constants))>0):
h4=ET.SubElement(div,"h4")
h4.text="Constants:"
- div2=ET.SubElement(div,"div")
+ div2=ET.SubElement(div,"div")
div2.attrib["class"]="constant_list";
-
+
for c in list(constants):
li = ET.SubElement(div2, "li")
div3=ET.SubElement(li,"div")
div3.attrib["class"]="constant";
-
+
span=ET.SubElement(div3,"span")
span.attrib["class"]="identifier constant_name"
span.text=c.attrib["name"]+" "
@@ -437,23 +437,23 @@ def make_doku_class(node):
span=ET.SubElement(div3,"span")
span.attrib["class"]="constant_description"
span.text=c.text
-
+
# ET.SubElement(div,"br")
-
-
+
+
descr=node.find("description")
if (descr!=None and descr.text.strip()!=""):
h4=ET.SubElement(div,"h4")
h4.text="Description:"
-
+
make_text_def(node.attrib["name"],div,descr.text)
-# div2=ET.SubElement(div,"div")
+# div2=ET.SubElement(div,"div")
# div2.attrib["class"]="description";
# div2.text=descr.text
-
-
-
+
+
+
if(methods!=None or events!=None):
h4=ET.SubElement(div,"h4")
@@ -467,7 +467,7 @@ def make_doku_class(node):
for m in iter_list:
descr=m.find("description")
-
+
if (descr==None or descr.text.strip()==""):
continue;
@@ -479,11 +479,11 @@ def make_doku_class(node):
#anchor = ET.SubElement(div2, "a")
#anchor.attrib["name"] =
make_text_def(node.attrib["name"],div2,descr.text)
- #div3=ET.SubElement(div2,"div")
+ #div3=ET.SubElement(div2,"div")
#div3.attrib["class"]="description";
#div3.text=descr.text
-
-
+
+
return div
"""
for file in input_list:
@@ -501,14 +501,14 @@ for file in input_list:
continue
class_names.append(c.attrib["name"])
classes[c.attrib["name"]]=c
-
+
class_names.sort()
-
+
make_class_list(class_names,4)
for cn in class_names:
c=classes[cn]
make_doku_class(c)
-
+