2008-09-10 17:47:37 +08:00
|
|
|
import py, sys
|
|
|
|
|
2009-12-30 21:07:20 +08:00
|
|
|
class DeprecationWarning(DeprecationWarning):
|
2008-09-10 17:47:37 +08:00
|
|
|
def __init__(self, msg, path, lineno):
|
|
|
|
self.msg = msg
|
|
|
|
self.path = path
|
2010-07-27 03:15:15 +08:00
|
|
|
self.lineno = lineno
|
2008-09-10 17:47:37 +08:00
|
|
|
def __repr__(self):
|
|
|
|
return "%s:%d: %s" %(self.path, self.lineno+1, self.msg)
|
|
|
|
def __str__(self):
|
2010-07-27 03:15:15 +08:00
|
|
|
return self.msg
|
2008-09-10 17:47:37 +08:00
|
|
|
|
2009-09-07 23:53:50 +08:00
|
|
|
def _apiwarn(startversion, msg, stacklevel=2, function=None):
|
2009-04-10 05:04:51 +08:00
|
|
|
# below is mostly COPIED from python2.4/warnings.py's def warn()
|
|
|
|
# Get context information
|
2009-11-12 20:10:30 +08:00
|
|
|
if isinstance(stacklevel, str):
|
|
|
|
frame = sys._getframe(1)
|
|
|
|
level = 1
|
|
|
|
found = frame.f_code.co_filename.find(stacklevel) != -1
|
2009-08-28 03:12:55 +08:00
|
|
|
while frame:
|
|
|
|
co = frame.f_code
|
2009-11-12 20:10:30 +08:00
|
|
|
if co.co_filename.find(stacklevel) == -1:
|
|
|
|
if found:
|
2010-07-27 03:15:15 +08:00
|
|
|
stacklevel = level
|
2009-11-12 20:10:30 +08:00
|
|
|
break
|
|
|
|
else:
|
|
|
|
found = True
|
2009-08-28 03:12:55 +08:00
|
|
|
level += 1
|
|
|
|
frame = frame.f_back
|
|
|
|
else:
|
|
|
|
stacklevel = 1
|
2009-04-10 05:04:51 +08:00
|
|
|
msg = "%s (since version %s)" %(msg, startversion)
|
2009-05-06 04:31:18 +08:00
|
|
|
warn(msg, stacklevel=stacklevel+1, function=function)
|
2008-09-10 17:47:37 +08:00
|
|
|
|
2009-05-06 04:31:18 +08:00
|
|
|
def warn(msg, stacklevel=1, function=None):
|
|
|
|
if function is not None:
|
|
|
|
filename = py.std.inspect.getfile(function)
|
2009-09-01 22:10:21 +08:00
|
|
|
lineno = py.code.getrawcode(function).co_firstlineno
|
2009-04-10 05:04:51 +08:00
|
|
|
else:
|
2009-05-06 04:31:18 +08:00
|
|
|
try:
|
|
|
|
caller = sys._getframe(stacklevel)
|
|
|
|
except ValueError:
|
|
|
|
globals = sys.__dict__
|
|
|
|
lineno = 1
|
|
|
|
else:
|
|
|
|
globals = caller.f_globals
|
|
|
|
lineno = caller.f_lineno
|
|
|
|
if '__name__' in globals:
|
|
|
|
module = globals['__name__']
|
|
|
|
else:
|
|
|
|
module = "<string>"
|
|
|
|
filename = globals.get('__file__')
|
2009-04-10 05:04:51 +08:00
|
|
|
if filename:
|
|
|
|
fnl = filename.lower()
|
|
|
|
if fnl.endswith(".pyc") or fnl.endswith(".pyo"):
|
|
|
|
filename = filename[:-1]
|
2009-10-28 04:34:11 +08:00
|
|
|
elif fnl.endswith("$py.class"):
|
|
|
|
filename = filename.replace('$py.class', '.py')
|
2009-04-10 05:04:51 +08:00
|
|
|
else:
|
|
|
|
if module == "__main__":
|
|
|
|
try:
|
|
|
|
filename = sys.argv[0]
|
|
|
|
except AttributeError:
|
|
|
|
# embedded interpreters don't have sys.argv, see bug #839151
|
|
|
|
filename = '__main__'
|
|
|
|
if not filename:
|
|
|
|
filename = module
|
|
|
|
path = py.path.local(filename)
|
2009-12-30 21:07:20 +08:00
|
|
|
warning = DeprecationWarning(msg, path, lineno)
|
2010-07-27 03:15:15 +08:00
|
|
|
py.std.warnings.warn_explicit(warning, category=Warning,
|
|
|
|
filename=str(warning.path),
|
2009-04-10 05:04:51 +08:00
|
|
|
lineno=warning.lineno,
|
|
|
|
registry=py.std.warnings.__dict__.setdefault(
|
|
|
|
"__warningsregistry__", {})
|
|
|
|
)
|
2008-09-10 17:47:37 +08:00
|
|
|
|