mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 04:13:53 -06:00

Keeping it in error.py will create some cyclic import problems when we add types to the QAPISchemaParser. Callers don't need to know the details of QAPIParseError unless they are parsing or dealing directly with the parser, so this won't create any harsh new requirements for callers in the general case. Update error.py with a little docstring that gives a nod to where the error may now be found. Signed-off-by: John Snow <jsnow@redhat.com> Message-Id: <20210421192233.3542904-6-jsnow@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
43 lines
1.1 KiB
Python
43 lines
1.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
# Copyright (c) 2017-2019 Red Hat Inc.
|
|
#
|
|
# Authors:
|
|
# Markus Armbruster <armbru@redhat.com>
|
|
# Marc-André Lureau <marcandre.lureau@redhat.com>
|
|
#
|
|
# This work is licensed under the terms of the GNU GPL, version 2.
|
|
# See the COPYING file in the top-level directory.
|
|
|
|
"""
|
|
QAPI error classes
|
|
|
|
Common error classes used throughout the package. Additional errors may
|
|
be defined in other modules. At present, `QAPIParseError` is defined in
|
|
parser.py.
|
|
"""
|
|
|
|
|
|
class QAPIError(Exception):
|
|
"""Base class for all exceptions from the QAPI package."""
|
|
|
|
|
|
class QAPISourceError(QAPIError):
|
|
"""Error class for all exceptions identifying a source location."""
|
|
def __init__(self, info, msg, col=None):
|
|
super().__init__()
|
|
self.info = info
|
|
self.msg = msg
|
|
self.col = col
|
|
|
|
def __str__(self):
|
|
assert self.info is not None
|
|
loc = str(self.info)
|
|
if self.col is not None:
|
|
assert self.info.line is not None
|
|
loc += ':%s' % self.col
|
|
return loc + ': ' + self.msg
|
|
|
|
|
|
class QAPISemError(QAPISourceError):
|
|
"""Error class for semantic QAPI errors."""
|