Commit bd9f861c authored by Olivier Aubert's avatar Olivier Aubert

python-ctypes: accomodate new event type definitions (cf 96a96f60)

Code still works for both old and new versions of includes.
parent 56637aa9
...@@ -88,6 +88,7 @@ python_param_re=re.compile('(@param\s+\S+)(.+)') ...@@ -88,6 +88,7 @@ python_param_re=re.compile('(@param\s+\S+)(.+)')
forward_re=re.compile('.+\(\s*(.+?)\s*\)(\s*\S+)') forward_re=re.compile('.+\(\s*(.+?)\s*\)(\s*\S+)')
enum_re=re.compile('typedef\s+(enum)\s*(\S+\s*)?\{\s*(.+)\s*\}\s*(\S+);') enum_re=re.compile('typedef\s+(enum)\s*(\S+\s*)?\{\s*(.+)\s*\}\s*(\S+);')
special_enum_re=re.compile('^(enum)\s*(\S+\s*)?\{\s*(.+)\s*\};') special_enum_re=re.compile('^(enum)\s*(\S+\s*)?\{\s*(.+)\s*\};')
event_def_re=re.compile('^DEF\(\s*(\w+)\s*\)')
# Definition of parameter passing mode for types. This should not be # Definition of parameter passing mode for types. This should not be
# hardcoded this way, but works alright ATM. # hardcoded this way, but works alright ATM.
...@@ -139,6 +140,8 @@ class Parser(object): ...@@ -139,6 +140,8 @@ class Parser(object):
with type == 'enum' (for the moment) and value_list being a list of (name, value) with type == 'enum' (for the moment) and value_list being a list of (name, value)
Note that values are string, since this is intended for code generation. Note that values are string, since this is intended for code generation.
""" """
event_names=[]
f=open(name, 'r') f=open(name, 'r')
accumulator='' accumulator=''
for l in f: for l in f:
...@@ -185,21 +188,35 @@ class Parser(object): ...@@ -185,21 +188,35 @@ class Parser(object):
comment='' comment=''
continue continue
# Special case, used only for libvlc_events.h
# (version after 96a96f60bb0d1f2506e68b356897ceca6f6b586d)
m=event_def_re.match(l)
if m:
# Event definition.
event_names.append('libvlc_'+m.group(1))
continue
# Special case, used only for libvlc_events.h # Special case, used only for libvlc_events.h
m=special_enum_re.match(l) m=special_enum_re.match(l)
if m: if m:
values=[]
(typ, name, data)=m.groups() (typ, name, data)=m.groups()
for i, l in enumerate(paramlist_re.split(data)): if event_names:
l=l.strip() # event_names were defined through DEF macro
if l.startswith('/*') or l.startswith('#'): # (see 96a96f60bb0d1f2506e68b356897ceca6f6b586d)
continue values=list( (n, str(i)) for i, n in enumerate(event_names))
if '=' in l: else:
# A value was specified. Use it. # Before 96a96f60bb0d1f2506e68b356897ceca6f6b586d
values.append(re.split('\s*=\s*', l)) values=[]
else: for i, l in enumerate(paramlist_re.split(data)):
if l: l=l.strip()
values.append( (l, str(i)) ) if l.startswith('/*') or l.startswith('#'):
continue
if '=' in l:
# A value was specified. Use it.
values.append(re.split('\s*=\s*', l))
else:
if l:
values.append( (l, str(i)) )
comment=comment.replace('@{', '').replace('@see', 'See').replace('\ingroup', '') comment=comment.replace('@{', '').replace('@see', 'See').replace('\ingroup', '')
yield (typ, name.strip(), values, comment) yield (typ, name.strip(), values, comment)
comment='' comment=''
...@@ -396,7 +413,7 @@ class PythonGenerator(object): ...@@ -396,7 +413,7 @@ class PythonGenerator(object):
self.output("# Not wrapped methods:") self.output("# Not wrapped methods:")
for m in not_wrapped: for m in not_wrapped:
self.output("# ", m) self.output("# ", m)
if self.fd != sys.stdout: if self.fd != sys.stdout:
self.fd.close() self.fd.close()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment