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:
Markus Armbruster 2018-03-09 08:52:59 -05:00 committed by Lioncash
parent d74daa8fce
commit 3ab06081d4
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7

View file

@ -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)