From: Robert Bradshaw Date: Fri, 22 Jan 2010 00:41:28 +0000 (-0800) Subject: Verbose type inference directive. X-Git-Tag: 0.12.1~17 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=75ab0c6e289aadcebe16d5a0b1bcf88a94d173aa;p=cython.git Verbose type inference directive. --- diff --git a/Cython/Compiler/Options.py b/Cython/Compiler/Options.py index 6019c6ca..7970ddeb 100644 --- a/Cython/Compiler/Options.py +++ b/Cython/Compiler/Options.py @@ -63,6 +63,7 @@ directive_defaults = { 'callspec' : "", 'profile': False, 'infer_types': False, + 'infer_types.verbose': False, 'autotestdict': True, 'warn': None, diff --git a/Cython/Compiler/TypeInference.py b/Cython/Compiler/TypeInference.py index 605b1afa..4cd4fe6a 100644 --- a/Cython/Compiler/TypeInference.py +++ b/Cython/Compiler/TypeInference.py @@ -1,3 +1,4 @@ +from Errors import error, warning, warn_once, InternalError import ExprNodes import Nodes import Builtin @@ -132,6 +133,7 @@ class SimpleAssignmentTypeInferer: # (Something more powerful than just extending this one...) def infer_types(self, scope): enabled = scope.directives['infer_types'] + verbose = scope.directives['infer_types.verbose'] if enabled == True: spanning_type = aggressive_spanning_type elif enabled is None: # safe mode @@ -178,6 +180,8 @@ class SimpleAssignmentTypeInferer: # FIXME: raise a warning? # print "No assignments", entry.pos, entry entry.type = py_object_type + if verbose: + warning(entry.pos, "inferred '%s' to be of type '%s'" % (entry.name, entry.type), 1) resolve_dependancy(entry) # Deal with simple circular dependancies... for entry, deps in dependancies_by_entry.items(): @@ -197,6 +201,8 @@ class SimpleAssignmentTypeInferer: # We can't figure out the rest with this algorithm, let them be objects. for entry in dependancies_by_entry: entry.type = py_object_type + if verbose: + warning(entry.pos, "inferred '%s' to be of type '%s' (default)" % (entry.name, entry.type), 1) def find_spanning_type(type1, type2): if type1 is type2: