[Python-checkins] r59204 - in python/trunk: Doc/library/warnings.rst Lib/new.py Lib/warnings.py Misc/NEWS Python/sysmodule.c
christian.heimes
python-checkins at python.org
Wed Nov 28 00:16:44 CET 2007
Author: christian.heimes
Date: Wed Nov 28 00:16:44 2007
New Revision: 59204
Modified:
python/trunk/Doc/library/warnings.rst
python/trunk/Lib/new.py
python/trunk/Lib/warnings.py
python/trunk/Misc/NEWS
python/trunk/Python/sysmodule.c
Log:
Expose Py_Py3kWarningFlag as sys.py3kwarning as discussed in #1504
Also added a warning.warnpy3k() as convenient method for Python 3.x related deprecation warnings.
Modified: python/trunk/Doc/library/warnings.rst
==============================================================================
--- python/trunk/Doc/library/warnings.rst (original)
+++ python/trunk/Doc/library/warnings.rst Wed Nov 28 00:16:44 2007
@@ -200,6 +200,14 @@
was added in Python 2.5.)
+.. function:: warnpy3k(message[, category[, stacklevel]])
+
+ Issue a warning related to Python 3.x deprecation. Warnings are only shown
+ when Python is started with the -3 option. Like func:`warn` *message* must
+ be a string and *category* a subclass of :exc:`Warning`. :func:`warnpy3k`
+ is using :exc:`DeprecationWarning` as default warning class.
+
+
.. function:: showwarning(message, category, filename, lineno[, file])
Write a warning to a file. The default implementation calls
Modified: python/trunk/Lib/new.py
==============================================================================
--- python/trunk/Lib/new.py (original)
+++ python/trunk/Lib/new.py Wed Nov 28 00:16:44 2007
@@ -3,9 +3,9 @@
This module is no longer required except for backward compatibility.
Objects of most types can now be created by calling the type object.
"""
-from warnings import warn as _warn
-_warn("The 'new' module is not supported in 3.x, use the 'types' module "
- "instead.", DeprecationWarning, 2)
+from warnings import warnpy3k as _warnpy3k
+_warnpy3k("The 'new' module is not supported in 3.x, use the 'types' module "
+ "instead.", stacklevel=2)
from types import ClassType as classobj
from types import FunctionType as function
Modified: python/trunk/Lib/warnings.py
==============================================================================
--- python/trunk/Lib/warnings.py (original)
+++ python/trunk/Lib/warnings.py Wed Nov 28 00:16:44 2007
@@ -125,6 +125,16 @@
# Print message and context
showwarning(message, category, filename, lineno)
+def warnpy3k(message, category=None, stacklevel=1):
+ """Issue a deprecation warning for Python 3.x related changes.
+
+ Warnings are omitted unless Python is started with the -3 option.
+ """
+ if sys.py3kwarning:
+ if category is None:
+ category = DeprecationWarning
+ warn(message, category, stacklevel+1)
+
def showwarning(message, category, filename, lineno, file=None):
"""Hook to write a warning to a file; replace if you like."""
if file is None:
Modified: python/trunk/Misc/NEWS
==============================================================================
--- python/trunk/Misc/NEWS (original)
+++ python/trunk/Misc/NEWS Wed Nov 28 00:16:44 2007
@@ -12,6 +12,8 @@
Core and builtins
-----------------
+- Expose the Py_Py3kWarningFlag as sys.py3kwarning.
+
- Issue #1445: Fix a SystemError when accessing the ``cell_contents``
attribute of an empty cell object.
@@ -837,6 +839,8 @@
Extension Modules
-----------------
+- Added warnpy3k function to the warnings module.
+
- Marshal.dumps() now expects exact type matches for int, long, float, complex,
tuple, list, dict, set, and frozenset. Formerly, it would silently miscode
subclasses of those types. Now, it raises a ValueError instead.
Modified: python/trunk/Python/sysmodule.c
==============================================================================
--- python/trunk/Python/sysmodule.c (original)
+++ python/trunk/Python/sysmodule.c Wed Nov 28 00:16:44 2007
@@ -1167,6 +1167,8 @@
PyString_FromString(Py_GetExecPrefix()));
SET_SYS_FROM_STRING("maxint",
PyInt_FromLong(PyInt_GetMax()));
+ SET_SYS_FROM_STRING("py3kwarning",
+ PyBool_FromLong(Py_Py3kWarningFlag));
#ifdef Py_USING_UNICODE
SET_SYS_FROM_STRING("maxunicode",
PyInt_FromLong(PyUnicode_GetMax()));
More information about the Python-checkins
mailing list