mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-22 23:01:02 +00:00
qapi: Improve include file name reporting in error messages
Error messages print absolute file names of included files even if the user gave a relative one on the command line: $ PYTHONPATH=scripts python -B tests/qapi-schema/test-qapi.py tests/qapi-schema/include-cycle.json In file included from tests/qapi-schema/include-cycle.json:1: In file included from /work/armbru/qemu/tests/qapi-schema/include-cycle-b.json:1: /work/armbru/qemu/tests/qapi-schema/include-cycle-c.json:1: Inclusion loop for include-cycle.json Improve this to In file included from tests/qapi-schema/include-cycle.json:1: In file included from tests/qapi-schema/include-cycle-b.json:1: tests/qapi-schema/include-cycle-c.json:1: Inclusion loop for include-cycle.json The error message when an include file can't be opened prints the include directive's file name, which is relative to the including file. Change this to print the file name relative to the working directory. Visible in tests/qapi-schema/include-no-file.err. Backports commit af97502ce9c648ae5c746b9e562d6e4586f02eee from qemu
This commit is contained in:
parent
d74daa8fce
commit
3ab06081d4
|
@ -267,10 +267,9 @@ class QAPIDoc(object):
|
||||||
class QAPISchemaParser(object):
|
class QAPISchemaParser(object):
|
||||||
|
|
||||||
def __init__(self, fp, previously_included=[], incl_info=None):
|
def __init__(self, fp, previously_included=[], incl_info=None):
|
||||||
abs_fname = os.path.abspath(fp.name)
|
|
||||||
fname = fp.name
|
fname = fp.name
|
||||||
self.fname = fname
|
self.fname = fname
|
||||||
previously_included.append(abs_fname)
|
previously_included.append(os.path.abspath(fp.name))
|
||||||
self.incl_info = incl_info
|
self.incl_info = incl_info
|
||||||
self.src = fp.read()
|
self.src = fp.read()
|
||||||
if self.src == '' or self.src[-1] != '\n':
|
if self.src == '' or self.src[-1] != '\n':
|
||||||
|
@ -301,7 +300,7 @@ class QAPISchemaParser(object):
|
||||||
if not isinstance(include, str):
|
if not isinstance(include, str):
|
||||||
raise QAPISemError(info,
|
raise QAPISemError(info,
|
||||||
"Value of 'include' must be a string")
|
"Value of 'include' must be a string")
|
||||||
self._include(include, info, os.path.dirname(abs_fname),
|
self._include(include, info, os.path.dirname(self.fname),
|
||||||
previously_included)
|
previously_included)
|
||||||
elif "pragma" in expr:
|
elif "pragma" in expr:
|
||||||
self.reject_expr_doc()
|
self.reject_expr_doc()
|
||||||
|
@ -334,7 +333,8 @@ class QAPISchemaParser(object):
|
||||||
% self.cur_doc.symbol)
|
% self.cur_doc.symbol)
|
||||||
|
|
||||||
def _include(self, include, info, base_dir, previously_included):
|
def _include(self, include, info, base_dir, previously_included):
|
||||||
incl_abs_fname = os.path.join(base_dir, include)
|
incl_fname = os.path.join(base_dir, include)
|
||||||
|
incl_abs_fname = os.path.abspath(incl_fname)
|
||||||
# catch inclusion cycle
|
# catch inclusion cycle
|
||||||
inf = info
|
inf = info
|
||||||
while inf:
|
while inf:
|
||||||
|
@ -346,9 +346,9 @@ class QAPISchemaParser(object):
|
||||||
if incl_abs_fname in previously_included:
|
if incl_abs_fname in previously_included:
|
||||||
return
|
return
|
||||||
try:
|
try:
|
||||||
fobj = open(incl_abs_fname, 'r')
|
fobj = open(incl_fname, 'r')
|
||||||
except IOError as e:
|
except IOError as e:
|
||||||
raise QAPISemError(info, '%s: %s' % (e.strerror, include))
|
raise QAPISemError(info, '%s: %s' % (e.strerror, incl_fname))
|
||||||
exprs_include = QAPISchemaParser(fobj, previously_included, info)
|
exprs_include = QAPISchemaParser(fobj, previously_included, info)
|
||||||
self.exprs.extend(exprs_include.exprs)
|
self.exprs.extend(exprs_include.exprs)
|
||||||
self.docs.extend(exprs_include.docs)
|
self.docs.extend(exprs_include.docs)
|
||||||
|
|
Loading…
Reference in a new issue