first re-commit.
This commit is contained in:
563
pigpio-master/DOC/bin/cmakdoc.py
Normal file
563
pigpio-master/DOC/bin/cmakdoc.py
Normal file
@@ -0,0 +1,563 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
import sys
|
||||
|
||||
pigpio_m1="""
|
||||
.\" Process this file with
|
||||
.\" groff -man -Tascii pigpio.3
|
||||
.\"
|
||||
.TH pigpio 3 2012-2020 Linux "pigpio archive"
|
||||
.SH NAME
|
||||
pigpio - A C library to manipulate the Pi's GPIO.\n
|
||||
.SH SYNOPSIS\n
|
||||
#include <pigpio.h>\n
|
||||
|
||||
gcc -Wall -pthread -o prog prog.c -lpigpio -lrt\n
|
||||
sudo ./prog
|
||||
.SH DESCRIPTION\n
|
||||
"""
|
||||
|
||||
pigpiod_if_m1="""
|
||||
.\" Process this file with
|
||||
.\" groff -man -Tascii pigpiod_if.3
|
||||
.\"
|
||||
.TH pigpiod_if 3 2012-2020 Linux "pigpio archive"
|
||||
.SH NAME
|
||||
pigpiod_if - A C library to interface to the pigpio daemon.\n
|
||||
.SH SYNOPSIS\n
|
||||
#include <pigpiod_if.h>\n
|
||||
|
||||
gcc -Wall -pthread -o prog prog.c -lpigpiod_if -lrt\n
|
||||
./prog
|
||||
.SH DESCRIPTION\n
|
||||
"""
|
||||
|
||||
pigpiod_if2_m1="""
|
||||
.\" Process this file with
|
||||
.\" groff -man -Tascii pigpiod_if2.3
|
||||
.\"
|
||||
.TH pigpiod_if2 3 2012-2020 Linux "pigpio archive"
|
||||
.SH NAME
|
||||
pigpiod_if2 - A C library to interface to the pigpio daemon.\n
|
||||
.SH SYNOPSIS\n
|
||||
#include <pigpiod_if2.h>\n
|
||||
|
||||
gcc -Wall -pthread -o prog prog.c -lpigpiod_if2 -lrt\n
|
||||
./prog
|
||||
.SH DESCRIPTION\n
|
||||
"""
|
||||
|
||||
pigpiod_m1="""
|
||||
.\" Process this file with
|
||||
.\" groff -man -Tascii pigpiod.1
|
||||
.\"
|
||||
.TH pigpiod 1 2012-2020 Linux "pigpio archive"
|
||||
.SH NAME
|
||||
pigpiod - A utility to start the pigpio library as a daemon.\n
|
||||
.SH SYNOPSIS\n
|
||||
sudo pigpiod [OPTION]...
|
||||
.SH DESCRIPTION\n
|
||||
"""
|
||||
|
||||
pig2vcd_m1="""
|
||||
.\" Process this file with
|
||||
.\" groff -man -Tascii pig2vcd.1
|
||||
.\"
|
||||
.TH pig2vcd 1 2012-2020 Linux "pigpio archive"
|
||||
.SH NAME
|
||||
pig2vd - A utility to convert pigpio notifications to VCD.\n
|
||||
.SH SYNOPSIS\n
|
||||
pig2vcd </dev/pigpioXX >file.VCD
|
||||
.SH DESCRIPTION\n
|
||||
"""
|
||||
|
||||
pigpio_m2="""
|
||||
.SH SEE ALSO\n
|
||||
pigpiod(1), pig2vcd(1), pigs(1), pigpiod_if(3), pigpiod_if2(3)
|
||||
.SH AUTHOR\n
|
||||
joan@abyz.me.uk
|
||||
"""
|
||||
|
||||
pigpiod_if_m2="""
|
||||
.SH SEE ALSO\n
|
||||
pigpiod(1), pig2vcd(1), pigs(1), pigpio(3), pigpiod_if2(3)
|
||||
.SH AUTHOR\n
|
||||
joan@abyz.me.uk
|
||||
"""
|
||||
|
||||
pigpiod_if2_m2="""
|
||||
.SH SEE ALSO\n
|
||||
pigpiod(1), pig2vcd(1), pigs(1), pigpio(3), pigpiod_if(3)
|
||||
.SH AUTHOR\n
|
||||
joan@abyz.me.uk
|
||||
"""
|
||||
|
||||
pigpiod_m2="""
|
||||
.SH SEE ALSO\n
|
||||
pig2vcd(1), pigs(1), pigpio(3), pigpiod_if(3), pigpiod_if2(3)
|
||||
.SH AUTHOR\n
|
||||
joan@abyz.me.uk
|
||||
"""
|
||||
|
||||
pig2vcd_m2="""
|
||||
.SH SEE ALSO\n
|
||||
pigpiod(1), pigs(1), pigpio(3), pigpiod_if(3), pigpiod_if2(3)
|
||||
.SH AUTHOR\n
|
||||
joan@abyz.me.uk
|
||||
"""
|
||||
|
||||
|
||||
def emit(s):
|
||||
sys.stdout.write(s)
|
||||
|
||||
def get_line(f):
|
||||
line = f.readline()
|
||||
if man:
|
||||
line = line.replace(" \n", "\n.br\n")
|
||||
else:
|
||||
line = line.replace("<", "<")
|
||||
line = line.replace(">", ">")
|
||||
line = line.replace(" \n", "<br>\n")
|
||||
return line
|
||||
|
||||
def nostar(k):
|
||||
if k[0] == "*":
|
||||
return k[1:]
|
||||
else:
|
||||
return k
|
||||
|
||||
NONE =0
|
||||
MAN =1
|
||||
TEXT =2
|
||||
OVERVIEW=4
|
||||
FUNC =5
|
||||
DESC =6
|
||||
OPT =7
|
||||
PARAMS =8
|
||||
DEFS =9
|
||||
|
||||
param_used = []
|
||||
param_defd = []
|
||||
param_refd = []
|
||||
|
||||
at = NONE
|
||||
|
||||
in_code = False
|
||||
in_pard = False
|
||||
in_table = False
|
||||
|
||||
if len(sys.argv) > 2:
|
||||
obj = sys.argv[1]
|
||||
fn = sys.argv[2]
|
||||
if len(sys.argv) > 3:
|
||||
man = True
|
||||
else:
|
||||
man = False
|
||||
else:
|
||||
exit("bad args, need page file [man]")
|
||||
try:
|
||||
f = open(fn, "r")
|
||||
except:
|
||||
exit("aborting, can't open {}".format(fn))
|
||||
|
||||
if man:
|
||||
if obj == "pigpio":
|
||||
emit(pigpio_m1)
|
||||
elif obj == "pigpiod_if":
|
||||
emit(pigpiod_if_m1)
|
||||
elif obj == "pigpiod_if2":
|
||||
emit(pigpiod_if2_m1)
|
||||
elif obj == "pigpiod":
|
||||
emit(pigpiod_m1)
|
||||
elif obj == "pig2vcd":
|
||||
emit(pig2vcd_m1)
|
||||
|
||||
emit("\n.ad l\n")
|
||||
emit("\n.nh\n")
|
||||
|
||||
while True:
|
||||
|
||||
line = get_line(f)
|
||||
|
||||
if line == "":
|
||||
for p in param_used:
|
||||
if p not in param_defd:
|
||||
sys.stderr.write("{} used but not defined.\n".format(p))
|
||||
for p in param_defd:
|
||||
if p not in param_used and p not in param_refd:
|
||||
sys.stderr.write("{} defined but not used.\n".format(p))
|
||||
break
|
||||
|
||||
if line == "/*MAN\n":
|
||||
at = MAN
|
||||
continue
|
||||
|
||||
elif line == "MAN*/\n":
|
||||
at = NONE
|
||||
continue
|
||||
|
||||
if line == "/*TEXT\n":
|
||||
at = TEXT
|
||||
continue
|
||||
|
||||
elif line == "TEXT*/\n":
|
||||
at = NONE
|
||||
continue
|
||||
|
||||
elif line == "/*OVERVIEW\n":
|
||||
|
||||
if man:
|
||||
emit("\n.SH OVERVIEW\n")
|
||||
else:
|
||||
emit("<h2>OVERVIEW</h2>")
|
||||
emit(
|
||||
"<table border=\"0\" cellpadding=\"2\" cellspacing=\"2\"><tbody>")
|
||||
|
||||
at = OVERVIEW
|
||||
continue
|
||||
|
||||
elif line == "OVERVIEW*/\n":
|
||||
|
||||
if man:
|
||||
emit(".SH FUNCTIONS\n")
|
||||
else:
|
||||
emit("</tbody></table>")
|
||||
emit("<h2>FUNCTIONS</h2>")
|
||||
|
||||
at = NONE
|
||||
|
||||
elif line == "/*F*/\n":
|
||||
in_code = False
|
||||
fdef=""
|
||||
line = get_line(f)
|
||||
at = FUNC
|
||||
|
||||
elif line == "/*D\n":
|
||||
# Function definition should be complete.
|
||||
fdef = fdef.replace("\n", " ")
|
||||
|
||||
while fdef.find(" ") != -1:
|
||||
fdef = fdef.replace(" ", " ")
|
||||
|
||||
fdef = fdef.replace("( ", "(")
|
||||
|
||||
(rf, sep1, end1) = fdef.partition("(")
|
||||
(parl, sep2, end2) = end1.partition(")")
|
||||
tps = parl.split(",")
|
||||
rf = rf.split(" ")
|
||||
ret = rf[0]
|
||||
func = rf[1]
|
||||
|
||||
if ret not in param_used:
|
||||
param_used.append(ret)
|
||||
|
||||
if man:
|
||||
t = "\\fB" + ret + " " + func + "(" + parl + ")\\fP"
|
||||
emit("\n.IP \"{}\"\n.IP \"\" 4\n".format(t))
|
||||
else:
|
||||
emit("<h3><a name=\"{}\"></a><a href=\"#{}\"><small>{}</small></a> {}".
|
||||
format(nostar(func), ret, ret,func))
|
||||
emit("<small>(")
|
||||
|
||||
x = 0
|
||||
for tp in tps:
|
||||
tp = tp.strip()
|
||||
(t, sep3, p) = tp.partition(" ")
|
||||
t = t.strip()
|
||||
p = p.strip()
|
||||
if (p != ""):
|
||||
if p not in param_used:
|
||||
param_used.append(p)
|
||||
if t not in param_used:
|
||||
param_used.append(t)
|
||||
if x > 0:
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit(", ")
|
||||
|
||||
x += 1
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
|
||||
emit("<a href=\"#{}\">{}</a> <a href=\"#{}\">{}</a>".
|
||||
format(t, t, p, p))
|
||||
|
||||
else:
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit("{}".format(t))
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit(")</small></h3>\n")
|
||||
|
||||
line = get_line(f)
|
||||
at = DESC
|
||||
|
||||
elif line == "D*/\n":
|
||||
at = NONE
|
||||
|
||||
elif line == "/*O\n":
|
||||
if man:
|
||||
emit(".SH OPTIONS\n")
|
||||
else:
|
||||
emit("<table border=\"1\" cellpadding=\"2\" cellspacing=\"2\"><tbody>")
|
||||
at = OPT
|
||||
continue
|
||||
|
||||
elif line == "O*/\n":
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit("</tbody></table>")
|
||||
at = NONE
|
||||
continue
|
||||
|
||||
elif line == "/*PARAMS\n":
|
||||
last_par = "*"
|
||||
|
||||
if man:
|
||||
emit(".SH PARAMETERS\n")
|
||||
else:
|
||||
emit("<h2>PARAMETERS</h2>")
|
||||
|
||||
at = PARAMS
|
||||
continue
|
||||
|
||||
elif line == "PARAMS*/\n":
|
||||
at = NONE
|
||||
|
||||
elif line.startswith("/*DEF_S "):
|
||||
title = line[8:-3]
|
||||
in_code = True
|
||||
if man:
|
||||
emit(".SH {}\n".format(title))
|
||||
emit("\n.EX\n")
|
||||
else:
|
||||
emit("<h2>{}</h2>".format(title))
|
||||
emit("<code>")
|
||||
at = DEFS
|
||||
continue
|
||||
|
||||
elif line == "/*DEF_E*/\n":
|
||||
in_code = False
|
||||
if man:
|
||||
emit("\n.EE\n")
|
||||
else:
|
||||
emit("</code>")
|
||||
at = NONE
|
||||
continue
|
||||
|
||||
|
||||
if at != NONE and at != OVERVIEW:
|
||||
if line.find("@") != -1:
|
||||
if not in_table:
|
||||
in_table = True
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit("<table border=\"1\" cellpadding=\"2\" cellspacing=\"2\"><tbody>")
|
||||
|
||||
if man:
|
||||
line = line.replace("@", " ")
|
||||
emit(line)
|
||||
# emit("\n.br\n")
|
||||
emit(".br\n")
|
||||
else:
|
||||
emit("<tr>")
|
||||
cols = line.split("@")
|
||||
for col in cols:
|
||||
emit("<td>{}</td>".format(col.strip()))
|
||||
emit("</tr>")
|
||||
|
||||
continue
|
||||
|
||||
else:
|
||||
if in_table:
|
||||
in_table = False
|
||||
|
||||
if man:
|
||||
pass
|
||||
else:
|
||||
emit("</tbody></table>")
|
||||
|
||||
if line == "...\n" or line == ". .\n":
|
||||
if in_code:
|
||||
in_code = False
|
||||
|
||||
if man:
|
||||
emit("\n.EE\n")
|
||||
else:
|
||||
emit("</code>")
|
||||
|
||||
else:
|
||||
in_code = True
|
||||
if line == "...\n":
|
||||
|
||||
if man:
|
||||
emit("\\fBExample\\fP\n.br\n")
|
||||
else:
|
||||
emit("<b><small>Example</small></b><br><br>")
|
||||
|
||||
if man:
|
||||
emit("\n.EX\n")
|
||||
else:
|
||||
emit("<code>")
|
||||
|
||||
continue
|
||||
|
||||
if line == "\n":
|
||||
|
||||
if man:
|
||||
emit("\n.br\n")
|
||||
else:
|
||||
emit("<br>")
|
||||
|
||||
if not in_code:
|
||||
if man:
|
||||
emit("\n.br\n")
|
||||
else:
|
||||
emit("<br>")
|
||||
|
||||
continue
|
||||
|
||||
if in_code:
|
||||
|
||||
if man:
|
||||
line = line.replace("\n", "\n.br\n")
|
||||
else:
|
||||
line = line.replace(" ", " ")
|
||||
line = line.replace("\n", "<br>")
|
||||
|
||||
while line.find("[*") != -1 and line.find("*]") != -1:
|
||||
(b, s, e) = line.partition("[*")
|
||||
(l, s, e) = e.partition("*]")
|
||||
|
||||
if man:
|
||||
line = "{}\\fB{}\\fP{}".format(b, l, e)
|
||||
else:
|
||||
line = "{}<a href=\"#{}\">{}</a>{}".format(b, l, l, e)
|
||||
|
||||
if l not in param_refd:
|
||||
param_refd.append(l)
|
||||
|
||||
while line.find("[[") != -1 and line.find("]]") != -1:
|
||||
(b, s, e) = line.partition("[[")
|
||||
(l, s, e) = e.partition("]]")
|
||||
|
||||
if man:
|
||||
line = "{}\\fB{}\\fP{}".format(b, l, e)
|
||||
else:
|
||||
line = "{}<a href=\"{}\">{}</a>{}".format(b, l, l, e)
|
||||
|
||||
if at == TEXT:
|
||||
if line[0] == '*' and line[-2] == '*':
|
||||
if man:
|
||||
emit(".SS {}".format(line[1:-2]))
|
||||
else:
|
||||
emit("<h3>{}</h3>".format(line[1:-2]))
|
||||
elif line[0] == '^' and line[-2] == '^':
|
||||
if man:
|
||||
emit(".SS {}".format(line[1:-2]))
|
||||
else:
|
||||
emit("<br><b>{}</b><br>".format(line[1:-2]))
|
||||
else:
|
||||
emit(line)
|
||||
|
||||
elif at == OVERVIEW:
|
||||
if line == "\n":
|
||||
|
||||
if man:
|
||||
emit("\n.br\n")
|
||||
else:
|
||||
emit("<tr><td></td><td></td></tr>")
|
||||
|
||||
else:
|
||||
(func, sep, desc) = line.partition(" ")
|
||||
if desc != "":
|
||||
|
||||
if man:
|
||||
emit("\n.br\n{}".format(line.strip()))
|
||||
else:
|
||||
emit("<tr><td><a href=\"#{}\">{}</a></td><td>{}</td></tr>".
|
||||
format(func, func, desc))
|
||||
|
||||
else:
|
||||
|
||||
if man:
|
||||
emit(".SS {}".format(line.replace("_", " ").strip()))
|
||||
else:
|
||||
emit("<tr><td><b>{}</b></td><td></td></tr>".
|
||||
format(func.replace("_", " ")))
|
||||
|
||||
elif at == FUNC:
|
||||
fdef += line
|
||||
|
||||
elif at == DESC:
|
||||
emit(line)
|
||||
|
||||
elif at == PARAMS:
|
||||
if line.find("::") != -1:
|
||||
(par, sep, end) = line.partition("::")
|
||||
par = par.strip()
|
||||
end = end.strip()
|
||||
|
||||
if nostar(par.lower()) < nostar(last_par.lower()):
|
||||
sys.stderr.write("Out of order {} after {}.\n".
|
||||
format(par, last_par))
|
||||
last_par = par
|
||||
|
||||
if par in param_defd:
|
||||
sys.stderr.write("Duplicate definition of {}.\n".format(par))
|
||||
else:
|
||||
param_defd.append(par)
|
||||
|
||||
if end != "":
|
||||
end = ": " + end
|
||||
if man:
|
||||
emit("\n.IP \"\\fB{}\\fP{}\" 0\n".format(par, end))
|
||||
else:
|
||||
emit("<h3><a name=\"{}\">{}</a>{}</h3>\n".format(par, par, end))
|
||||
|
||||
else:
|
||||
emit(line)
|
||||
|
||||
elif at == MAN:
|
||||
if man:
|
||||
emit(line)
|
||||
|
||||
elif at == OPT:
|
||||
line = line.split("|")
|
||||
if man:
|
||||
emit("\n.IP \"\\fB{}\\fP\"\n{}.\n{}.\n{}.".format(
|
||||
line[0], line[1], line[2], line[3]))
|
||||
else:
|
||||
emit("<tr><td><b>{}</b></td><td>{}</td><td>{}</td><td>{}</td></tr>".
|
||||
format(line[0], line[1], line[2], line[3]))
|
||||
|
||||
elif at == DEFS:
|
||||
emit(line)
|
||||
|
||||
if man:
|
||||
if obj == "pigpio":
|
||||
emit(pigpio_m2)
|
||||
elif obj == "pigpiod_if":
|
||||
emit(pigpiod_if_m2)
|
||||
elif obj == "pigpiod_if2":
|
||||
emit(pigpiod_if2_m2)
|
||||
elif obj == "pigpiod":
|
||||
emit(pigpiod_m2)
|
||||
elif obj == "pig2vcd":
|
||||
emit(pig2vcd_m2)
|
||||
|
||||
|
||||
f.close()
|
||||
|
Reference in New Issue
Block a user