Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
varnish-cache
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
varnishcache
varnish-cache
Commits
a5b03294
Commit
a5b03294
authored
Feb 27, 2018
by
Poul-Henning Kamp
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Pycodestyle-ify
parent
63f051db
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
40 deletions
+41
-40
vmodtool.py
lib/libvcc/vmodtool.py
+41
-40
No files found.
lib/libvcc/vmodtool.py
View file @
a5b03294
...
@@ -154,7 +154,7 @@ def lwrap(s, width=64):
...
@@ -154,7 +154,7 @@ def lwrap(s, width=64):
"""
"""
Wrap a C-prototype like string into a number of lines.
Wrap a C-prototype like string into a number of lines.
"""
"""
l
=
[]
l
l
=
[]
p
=
""
p
=
""
while
len
(
s
)
>
width
:
while
len
(
s
)
>
width
:
y
=
s
[:
width
]
.
rfind
(
','
)
y
=
s
[:
width
]
.
rfind
(
','
)
...
@@ -162,12 +162,12 @@ def lwrap(s, width=64):
...
@@ -162,12 +162,12 @@ def lwrap(s, width=64):
y
=
s
[:
width
]
.
rfind
(
'('
)
y
=
s
[:
width
]
.
rfind
(
'('
)
if
y
==
-
1
:
if
y
==
-
1
:
break
break
l
.
append
(
p
+
s
[:
y
+
1
])
l
l
.
append
(
p
+
s
[:
y
+
1
])
s
=
s
[
y
+
1
:]
.
lstrip
()
s
=
s
[
y
+
1
:]
.
lstrip
()
p
=
" "
p
=
" "
if
len
(
s
)
>
0
:
if
len
(
s
)
>
0
:
l
.
append
(
p
+
s
)
l
l
.
append
(
p
+
s
)
return
l
return
l
l
def
quote
(
s
):
def
quote
(
s
):
...
@@ -233,6 +233,7 @@ class ctype(object):
...
@@ -233,6 +233,7 @@ class ctype(object):
while
jl
[
-
1
][
-
1
]
is
None
:
while
jl
[
-
1
][
-
1
]
is
None
:
jl
[
-
1
]
.
pop
(
-
1
)
jl
[
-
1
]
.
pop
(
-
1
)
def
vtype
(
txt
):
def
vtype
(
txt
):
j
=
len
(
txt
)
j
=
len
(
txt
)
for
i
in
(
','
,
' '
,
'
\n
'
,
'
\t
'
):
for
i
in
(
','
,
' '
,
'
\n
'
,
'
\t
'
):
...
@@ -298,27 +299,29 @@ def arg(txt):
...
@@ -298,27 +299,29 @@ def arg(txt):
return
a
,
s
return
a
,
s
def
nmlegal
(
nm
):
def
nmlegal
(
nm
):
return
re
.
match
(
'^[a-zA-Z0-9_]+$'
,
nm
)
return
re
.
match
(
'^[a-zA-Z0-9_]+$'
,
nm
)
# XXX cant have ( or ) in an argument default value
# XXX cant have ( or ) in an argument default value
class
prototype
(
object
):
class
prototype
(
object
):
def
__init__
(
self
,
st
,
retval
=
True
,
prefix
=
""
):
def
__init__
(
self
,
st
,
retval
=
True
,
prefix
=
""
):
l
=
st
.
line
[
1
]
l
l
=
st
.
line
[
1
]
while
True
:
while
True
:
a1
=
l
.
count
(
"("
)
a1
=
l
l
.
count
(
"("
)
a2
=
l
.
count
(
")"
)
a2
=
l
l
.
count
(
")"
)
if
a1
>
0
and
a1
==
a2
:
if
a1
>
0
and
a1
==
a2
:
break
break
n
=
st
.
doc
.
split
(
"
\n
"
,
1
)
n
=
st
.
doc
.
split
(
"
\n
"
,
1
)
l
+=
n
[
0
]
l
l
+=
n
[
0
]
st
.
doc
=
n
[
1
]
st
.
doc
=
n
[
1
]
if
retval
:
if
retval
:
self
.
retval
,
s
=
vtype
(
l
)
self
.
retval
,
s
=
vtype
(
l
l
)
else
:
else
:
self
.
retval
=
None
self
.
retval
=
None
s
=
l
s
=
l
l
i
=
s
.
find
(
"("
)
i
=
s
.
find
(
"("
)
assert
i
>
0
assert
i
>
0
self
.
name
=
prefix
+
s
[:
i
]
.
strip
()
self
.
name
=
prefix
+
s
[:
i
]
.
strip
()
...
@@ -359,7 +362,7 @@ class prototype(object):
...
@@ -359,7 +362,7 @@ class prototype(object):
if
self
.
retval
is
not
None
:
if
self
.
retval
is
not
None
:
s
+=
self
.
retval
.
vcl
()
+
" "
s
+=
self
.
retval
.
vcl
()
+
" "
s
+=
self
.
name
+
"("
s
+=
self
.
name
+
"("
l
=
[]
l
l
=
[]
for
i
in
self
.
args
:
for
i
in
self
.
args
:
t
=
i
.
vcl
()
t
=
i
.
vcl
()
if
t
in
privs
:
if
t
in
privs
:
...
@@ -369,18 +372,18 @@ class prototype(object):
...
@@ -369,18 +372,18 @@ class prototype(object):
t
+=
" "
+
i
.
nm
t
+=
" "
+
i
.
nm
if
i
.
defval
is
not
None
:
if
i
.
defval
is
not
None
:
t
+=
"="
+
i
.
defval
t
+=
"="
+
i
.
defval
l
.
append
(
t
)
l
l
.
append
(
t
)
s
+=
", "
.
join
(
l
)
+
")"
s
+=
", "
.
join
(
l
l
)
+
")"
return
s
return
s
def
c_ret
(
self
):
def
c_ret
(
self
):
return
self
.
retval
.
ct
return
self
.
retval
.
ct
def
c_args
(
self
,
a
=
[]):
def
c_args
(
self
,
a
=
[]):
l
=
list
(
a
)
l
l
=
list
(
a
)
for
i
in
self
.
args
:
for
i
in
self
.
args
:
l
.
append
(
i
.
ct
)
l
l
.
append
(
i
.
ct
)
return
", "
.
join
(
l
)
return
", "
.
join
(
l
l
)
def
c_fn
(
self
,
args
=
[],
h
=
False
):
def
c_fn
(
self
,
args
=
[],
h
=
False
):
s
=
fn
=
''
s
=
fn
=
''
...
@@ -499,19 +502,19 @@ class s_module(stanza):
...
@@ -499,19 +502,19 @@ class s_module(stanza):
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
return
return
l
=
[]
l
l
=
[]
for
i
in
self
.
vcc
.
contents
[
1
:]:
for
i
in
self
.
vcc
.
contents
[
1
:]:
j
=
i
.
rstlbl
j
=
i
.
rstlbl
if
j
is
not
None
:
if
j
is
not
None
:
l
.
append
([
j
.
split
(
"_"
,
1
)[
1
],
j
])
l
l
.
append
([
j
.
split
(
"_"
,
1
)[
1
],
j
])
if
i
.
methods
is
None
:
if
i
.
methods
is
None
:
continue
continue
for
x
in
i
.
methods
:
for
x
in
i
.
methods
:
j
=
x
.
rstlbl
j
=
x
.
rstlbl
l
.
append
([
j
.
split
(
"_"
,
1
)[
1
],
j
])
l
l
.
append
([
j
.
split
(
"_"
,
1
)[
1
],
j
])
l
.
sort
()
l
l
.
sort
()
for
i
in
l
:
for
i
in
l
l
:
fo
.
write
(
"* :ref:`
%
s`
\n
"
%
i
[
1
])
fo
.
write
(
"* :ref:`
%
s`
\n
"
%
i
[
1
])
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
...
@@ -557,6 +560,7 @@ class s_event(stanza):
...
@@ -557,6 +560,7 @@ class s_event(stanza):
"Vmod_
%
s_Func._event"
%
self
.
vcc
.
modname
"Vmod_
%
s_Func._event"
%
self
.
vcc
.
modname
])
])
class
s_function
(
stanza
):
class
s_function
(
stanza
):
def
parse
(
self
):
def
parse
(
self
):
self
.
proto
=
prototype
(
self
)
self
.
proto
=
prototype
(
self
)
...
@@ -575,13 +579,13 @@ class s_function(stanza):
...
@@ -575,13 +579,13 @@ class s_function(stanza):
def
cstruct_init
(
self
,
fo
):
def
cstruct_init
(
self
,
fo
):
fo
.
write
(
"
\t
"
+
self
.
proto
.
cname
(
pfx
=
True
)
+
",
\n
"
)
fo
.
write
(
"
\t
"
+
self
.
proto
.
cname
(
pfx
=
True
)
+
",
\n
"
)
def
json
(
self
,
jl
):
def
json
(
self
,
jl
):
jl
.
append
([
jl
.
append
([
"$FUNC"
,
"$FUNC"
,
"
%
s"
%
self
.
proto
.
name
,
"
%
s"
%
self
.
proto
.
name
,
])
])
self
.
proto
.
json
(
jl
[
-
1
],
'Vmod_
%
s_Func.
%
s'
%
self
.
proto
.
json
(
jl
[
-
1
],
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
proto
.
cname
()))
(
self
.
vcc
.
modname
,
self
.
proto
.
cname
()))
class
s_object
(
stanza
):
class
s_object
(
stanza
):
...
@@ -653,25 +657,24 @@ class s_object(stanza):
...
@@ -653,25 +657,24 @@ class s_object(stanza):
"$OBJ"
,
"$OBJ"
,
self
.
proto
.
name
,
self
.
proto
.
name
,
"struct
%
s
%
s_
%
s"
%
"struct
%
s
%
s_
%
s"
%
(
self
.
vcc
.
sympfx
,
self
.
vcc
.
modname
,
self
.
proto
.
name
),
(
self
.
vcc
.
sympfx
,
self
.
vcc
.
modname
,
self
.
proto
.
name
),
]
]
l2
=
[
"$INIT"
]
l2
=
[
"$INIT"
]
ll
.
append
(
l2
)
ll
.
append
(
l2
)
self
.
init
.
json
(
l2
,
self
.
init
.
json
(
l2
,
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
init
.
name
))
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
init
.
name
))
l2
=
[
"$FINI"
]
l2
=
[
"$FINI"
]
ll
.
append
(
l2
)
ll
.
append
(
l2
)
self
.
fini
.
json
(
l2
,
self
.
fini
.
json
(
l2
,
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
fini
.
name
))
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
fini
.
name
))
for
i
in
self
.
methods
:
for
i
in
self
.
methods
:
i
.
json
(
ll
)
i
.
json
(
ll
)
jl
.
append
(
ll
)
jl
.
append
(
ll
)
def
dump
(
self
):
def
dump
(
self
):
super
(
s_object
,
self
)
.
dump
()
super
(
s_object
,
self
)
.
dump
()
for
i
in
self
.
methods
:
for
i
in
self
.
methods
:
...
@@ -699,7 +702,8 @@ class s_method(stanza):
...
@@ -699,7 +702,8 @@ class s_method(stanza):
self
.
proto
.
name
[
len
(
self
.
pfx
)
+
1
:]
self
.
proto
.
name
[
len
(
self
.
pfx
)
+
1
:]
])
])
self
.
proto
.
json
(
jl
[
-
1
],
self
.
proto
.
json
(
jl
[
-
1
],
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
proto
.
cname
()))
'Vmod_
%
s_Func.
%
s'
%
(
self
.
vcc
.
modname
,
self
.
proto
.
cname
()))
#######################################################################
#######################################################################
...
@@ -794,8 +798,7 @@ class vcc(object):
...
@@ -794,8 +798,7 @@ class vcc(object):
fo
.
write
(
"#endif
\n
"
)
fo
.
write
(
"#endif
\n
"
)
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
l
=
sorted
(
enum_values
)
for
j
in
sorted
(
enum_values
):
for
j
in
l
:
fo
.
write
(
"extern VCL_ENUM
%
senum_
%
s;
\n
"
%
(
self
.
sympfx
,
j
))
fo
.
write
(
"extern VCL_ENUM
%
senum_
%
s;
\n
"
%
(
self
.
sympfx
,
j
))
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
...
@@ -809,8 +812,7 @@ class vcc(object):
...
@@ -809,8 +812,7 @@ class vcc(object):
for
j
in
self
.
contents
:
for
j
in
self
.
contents
:
j
.
cstruct
(
fo
)
j
.
cstruct
(
fo
)
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
l
=
sorted
(
enum_values
)
for
j
in
sorted
(
enum_values
):
for
j
in
l
:
fo
.
write
(
"
\t
VCL_ENUM
\t\t\t
*enum_
%
s;
\n
"
%
j
)
fo
.
write
(
"
\t
VCL_ENUM
\t\t\t
*enum_
%
s;
\n
"
%
j
)
fo
.
write
(
"};
\n
"
)
fo
.
write
(
"};
\n
"
)
...
@@ -819,17 +821,16 @@ class vcc(object):
...
@@ -819,17 +821,16 @@ class vcc(object):
for
j
in
self
.
contents
:
for
j
in
self
.
contents
:
j
.
cstruct_init
(
fo
)
j
.
cstruct_init
(
fo
)
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
l
=
sorted
(
enum_values
)
for
j
in
sorted
(
enum_values
):
for
j
in
l
:
fo
.
write
(
"
\t
&
%
senum_
%
s,
\n
"
%
(
self
.
sympfx
,
j
))
fo
.
write
(
"
\t
&
%
senum_
%
s,
\n
"
%
(
self
.
sympfx
,
j
))
fo
.
write
(
"};
\n
"
)
fo
.
write
(
"};
\n
"
)
def
json
(
self
,
fo
):
def
json
(
self
,
fo
):
jl
=
[
[
"$VMOD"
,
"1.0"
]
]
jl
=
[
[
"$VMOD"
,
"1.0"
]
]
for
j
in
self
.
contents
:
for
j
in
self
.
contents
:
j
.
json
(
jl
)
j
.
json
(
jl
)
bz
=
bytearray
(
json
.
dumps
(
jl
,
separators
=
(
","
,
":"
)))
+
"
\0
"
bz
=
bytearray
(
json
.
dumps
(
jl
,
separators
=
(
","
,
":"
)))
+
"
\0
"
fo
.
write
(
"
\n
static const char Vmod_Json[
%
d] = {
\n
"
%
len
(
bz
))
fo
.
write
(
"
\n
static const char Vmod_Json[
%
d] = {
\n
"
%
len
(
bz
))
t
=
"
\t
"
t
=
"
\t
"
for
i
in
bz
:
for
i
in
bz
:
...
@@ -891,8 +892,7 @@ class vcc(object):
...
@@ -891,8 +892,7 @@ class vcc(object):
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
l
=
sorted
(
enum_values
)
for
j
in
sorted
(
enum_values
):
for
j
in
l
:
fo
.
write
(
'VCL_ENUM
%
senum_
%
s = "
%
s";
\n
'
%
(
self
.
sympfx
,
j
,
j
))
fo
.
write
(
'VCL_ENUM
%
senum_
%
s = "
%
s";
\n
'
%
(
self
.
sympfx
,
j
,
j
))
fo
.
write
(
"
\n
"
)
fo
.
write
(
"
\n
"
)
...
@@ -952,6 +952,7 @@ def runmain(inputvcc, rstdir, outputprefix):
...
@@ -952,6 +952,7 @@ def runmain(inputvcc, rstdir, outputprefix):
v
.
commit
()
v
.
commit
()
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
usagetext
=
"Usage:
%
prog [options] <vmod.vcc>"
usagetext
=
"Usage:
%
prog [options] <vmod.vcc>"
oparser
=
optparse
.
OptionParser
(
usage
=
usagetext
)
oparser
=
optparse
.
OptionParser
(
usage
=
usagetext
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment