[scanner] Remove old logging functions
authorJohan Dahlin <johan@gnome.org>
Thu, 2 Sep 2010 14:44:47 +0000 (11:44 -0300)
committerJohan Dahlin <johan@gnome.org>
Thu, 2 Sep 2010 15:37:55 +0000 (12:37 -0300)
And migrate over to using the message logger

giscanner/scannermain.py
giscanner/transformer.py

index ea1299e793bc1d9d08b96f79f659001d3d7ad3a6..bf2af396124ab89a086f19149efbb27cfd4ff155 100644 (file)
@@ -265,8 +265,9 @@ def scanner_main(args):
                           options.namespace_version,
                           identifier_prefixes=identifier_prefixes,
                           symbol_prefixes=symbol_prefixes)
-    message.MessageLogger.get(namespace=namespace,
-                              enable_warnings=options.warn_all)
+    logger = message.MessageLogger.get(namespace=namespace)
+    if options.warn_all:
+        logger.enable_warnings(True)
     transformer = Transformer(namespace,
                               accept_unprefixed=options.accept_unprefixed)
     transformer.set_include_paths(options.include_paths)
@@ -328,7 +329,7 @@ def scanner_main(args):
     final = IntrospectablePass(transformer)
     final.validate()
 
-    if options.warn_fatal and transformer.did_warn():
+    if options.warn_fatal and logger.did_warn():
         message.fatal("warnings configured as fatal")
         return 1
 
index f83339c9b9e1387085b863cbc0da2cad6cde185f..735c153bafd8d13846fef2f61471c58b22d7f2a2 100644 (file)
@@ -50,14 +50,11 @@ class Transformer(object):
     UCASE_CONSTANT_RE = re.compile(r'[_A-Z0-9]+')
 
     def __init__(self, namespace, accept_unprefixed=False):
-        self._cwd = os.getcwd() + os.sep
         self._cachestore = CacheStore()
         self._accept_unprefixed = accept_unprefixed
         self._namespace = namespace
         self._pkg_config_packages = set()
         self._typedefs_ns = {}
-        self._enable_warnings = False
-        self._warned = False
         self._includes = {}
         self._include_names = set()
         self._includepaths = []
@@ -65,12 +62,6 @@ class Transformer(object):
     def get_includes(self):
         return self._include_names
 
-    def enable_warnings(self, enable):
-        self._enable_warnings = enable
-
-    def did_warn(self):
-        return self._warned
-
     def get_pkgconfig_packages(self):
         return self._pkg_config_packages
 
@@ -150,83 +141,6 @@ None."""
 
     # Private
 
-    def log_warning(self, text, file_positions=None, prefix=None,
-                    fatal=False):
-        """Log a warning, using optional file positioning information.
-If the warning is related to a ast.Node type, see log_node_warning()."""
-        if not fatal and not self._enable_warnings:
-            return
-
-        self._warned = True
-
-        if file_positions is None or len(file_positions) == 0:
-            target_file_positions = [('<unknown>', -1, -1)]
-        else:
-            target_file_positions = file_positions
-
-        position_strings = []
-        for (filename, line, column) in target_file_positions:
-            if filename.startswith(self._cwd):
-                filename = filename[len(self._cwd):]
-            if column != -1:
-                position = '%s:%d:%d' % (filename, line, column)
-            elif line != -1:
-                position = '%s:%d' % (filename, line, )
-            else:
-                position = '%s:' % (filename, )
-            position_strings.append(position)
-
-        for position in position_strings[:-1]:
-            print >>sys.stderr, "%s:" % (position, )
-        last_position = position_strings[-1]
-        error_type = 'error' if fatal else 'warning'
-        if prefix:
-            print >>sys.stderr, \
-'''%s: %s: %s: %s: %s''' % (last_position, error_type, self._namespace.name,
-                                 prefix, text)
-        else:
-            print >>sys.stderr, \
-'''%s: %s: %s: %s''' % (last_position, error_type, self._namespace.name, text)
-        if fatal:
-            sys.exit(1)
-
-    def log_symbol_warning(self, symbol, text, **kwargs):
-        """Log a warning in the context of the given symbol."""
-        if symbol.source_filename:
-            file_positions = [(symbol.source_filename, symbol.line, -1)]
-        else:
-            file_positions = None
-        prefix = "symbol=%r" % (symbol.ident, )
-        self.log_warning(text, file_positions, prefix=prefix, **kwargs)
-
-    def log_node_warning(self, node, text, context=None, fatal=False):
-        """Log a warning, using information about file positions from
-the given node.  The optional context argument, if given, should be
-another ast.Node type which will also be displayed.  If no file position
-information is available from the node, the position data from the
-context will be used."""
-        if hasattr(node, 'file_positions'):
-            if (len(node.file_positions) == 0 and
-                (context is not None) and len(context.file_positions) > 0):
-                file_positions = context.file_positions
-            else:
-                file_positions = node.file_positions
-        else:
-            file_positions = None
-            if not context:
-                text = "context=%r %s" % (node, text)
-
-        if context:
-            if isinstance(context, ast.Function):
-                name = context.symbol
-            else:
-                name = context.name
-            text = "%s: %s" % (name, text)
-        elif len(file_positions) == 0 and hasattr(node, 'name'):
-            text = "(%s)%s: %s" % (node.__class__.__name__, node.name, text)
-
-        self.log_warning(text, file_positions, fatal=fatal)
-
     def _find_include(self, include):
         searchdirs = self._includepaths[:]
         for path in _xdg_data_dirs: