mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-20 03:25:18 +00:00
Add parsing for VIR_ENUM_IMPL & VIR_ENUM_DECL in apibuild.py
The apibuild.py parser needs to be able to parse & ignore any VIR_ENUM_IMPL/VIR_ENUM_DECL macros in the source. Add some special case code to deal with this rather than trying to figure out a generic syntax for parsing macros. * apibuild.py: Special case VIR_ENUM_IMPL & VIR_ENUM_DECL (cherry picked from commit 45b43a8cab69db315b07ef17f80bb5d752074002)
This commit is contained in:
parent
f44e18ed93
commit
3e416ba91f
112
docs/apibuild.py
112
docs/apibuild.py
@ -1355,6 +1355,95 @@ class CParser:
|
|||||||
token = self.token()
|
token = self.token()
|
||||||
return token
|
return token
|
||||||
|
|
||||||
|
def parseVirEnumDecl(self, token):
|
||||||
|
if token[0] != "name":
|
||||||
|
self.error("parsing VIR_ENUM_DECL: expecting name", token)
|
||||||
|
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
if token[0] != "sep":
|
||||||
|
self.error("parsing VIR_ENUM_DECL: expecting ')'", token)
|
||||||
|
|
||||||
|
if token[1] != ')':
|
||||||
|
self.error("parsing VIR_ENUM_DECL: expecting ')'", token)
|
||||||
|
|
||||||
|
token = self.token()
|
||||||
|
if token[0] == "sep" and token[1] == ';':
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
return token
|
||||||
|
|
||||||
|
def parseVirEnumImpl(self, token):
|
||||||
|
# First the type name
|
||||||
|
if token[0] != "name":
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting name", token)
|
||||||
|
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
if token[0] != "sep":
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting ','", token)
|
||||||
|
|
||||||
|
if token[1] != ',':
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting ','", token)
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
# Now the sentinel name
|
||||||
|
if token[0] != "name":
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting name", token)
|
||||||
|
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
if token[0] != "sep":
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting ','", token)
|
||||||
|
|
||||||
|
if token[1] != ',':
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting ','", token)
|
||||||
|
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
# Now a list of strings (optional comments)
|
||||||
|
while token is not None:
|
||||||
|
isGettext = False
|
||||||
|
# First a string, optionally with N_(...)
|
||||||
|
if token[0] == 'name':
|
||||||
|
if token[1] != 'N_':
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting 'N_'", token)
|
||||||
|
token = self.token()
|
||||||
|
if token[0] != "sep" or token[1] != '(':
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting '('", token)
|
||||||
|
token = self.token()
|
||||||
|
isGettext = True
|
||||||
|
|
||||||
|
if token[0] != "string":
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting a string", token)
|
||||||
|
token = self.token()
|
||||||
|
elif token[0] == "string":
|
||||||
|
token = self.token()
|
||||||
|
else:
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting a string", token)
|
||||||
|
|
||||||
|
# Then a separator
|
||||||
|
if token[0] == "sep":
|
||||||
|
if isGettext and token[1] == ')':
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
if token[1] == ',':
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
if token[1] == ')':
|
||||||
|
token = self.token()
|
||||||
|
break
|
||||||
|
|
||||||
|
# Then an optional comment
|
||||||
|
if token[0] == "comment":
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
|
||||||
|
if token[0] == "sep" and token[1] == ';':
|
||||||
|
token = self.token()
|
||||||
|
|
||||||
|
return token
|
||||||
|
|
||||||
#
|
#
|
||||||
# Parse a C definition block, used for structs or unions it parse till
|
# Parse a C definition block, used for structs or unions it parse till
|
||||||
# the balancing }
|
# the balancing }
|
||||||
@ -1502,6 +1591,29 @@ class CParser:
|
|||||||
not self.is_header, "enum",
|
not self.is_header, "enum",
|
||||||
(enum[1], enum[2], enum_type))
|
(enum[1], enum[2], enum_type))
|
||||||
return token
|
return token
|
||||||
|
elif token[0] == "name" and token[1] == "VIR_ENUM_DECL":
|
||||||
|
token = self.token()
|
||||||
|
if token != None and token[0] == "sep" and token[1] == "(":
|
||||||
|
token = self.token()
|
||||||
|
token = self.parseVirEnumDecl(token)
|
||||||
|
else:
|
||||||
|
self.error("parsing VIR_ENUM_DECL: expecting '('", token)
|
||||||
|
if token != None:
|
||||||
|
self.lexer.push(token)
|
||||||
|
token = ("name", "virenumdecl")
|
||||||
|
return token
|
||||||
|
|
||||||
|
elif token[0] == "name" and token[1] == "VIR_ENUM_IMPL":
|
||||||
|
token = self.token()
|
||||||
|
if token != None and token[0] == "sep" and token[1] == "(":
|
||||||
|
token = self.token()
|
||||||
|
token = self.parseVirEnumImpl(token)
|
||||||
|
else:
|
||||||
|
self.error("parsing VIR_ENUM_IMPL: expecting '('", token)
|
||||||
|
if token != None:
|
||||||
|
self.lexer.push(token)
|
||||||
|
token = ("name", "virenumimpl")
|
||||||
|
return token
|
||||||
|
|
||||||
elif token[0] == "name":
|
elif token[0] == "name":
|
||||||
if self.type == "":
|
if self.type == "":
|
||||||
|
Loading…
x
Reference in New Issue
Block a user