Compatibility module to provide backwards compatibility for useful Python features.
This is mainly for use of internal Twisted code. We encourage you to use the latest version of Python directly from your code, if possible.
Variable | unicode | The type of Unicode strings, unicode on Python 2 and str on Python 3. |
Variable | NativeStringIO | An in-memory file-like object that operates on the native string type (bytes in Python 2, unicode in Python 3). |
Variable | urllib_parse | a URL-parsing module (urlparse on Python 2, urllib.parse on Python 3) |
Function | iteritems | Return an iterable of the items of d . |
Function | itervalues | Return an iterable of the values of d . |
Function | items | Return a list of the items of d . |
Function | currentframe | In Python 3, inspect.currentframe does not take a stack-level argument. Restore that functionality from Python 2 so we don't have to re-implement the f_back -walking loop in places where it's called. |
Function | execfile | Execute a Python script in the given namespaces. |
Function | cmp | Compare two objects. |
Function | comparable | Class decorator that ensures support for the special __cmp__ method. |
Function | ioType | Determine the type which will be returned from the given file object's read() and accepted by its write() method as an argument. |
Function | nativeString | Convert bytes or str to str type, using ASCII encoding if conversion is necessary. |
Function | reraise | Re-raise an exception, with an optional traceback. |
Function | iterbytes | Return an iterable wrapper for a bytes object that provides the behavior of iterating over bytes on Python 2. |
Function | intToBytes | Convert the given integer into bytes , as ASCII-encoded Arab numeral. |
Function | lazyByteSlice | Return a copy of the given bytes-like object. |
Function | networkString | Convert a string to bytes using ASCII encoding. |
Function | bytesEnviron | Return a dict of os.environ where all text-strings are encoded into bytes . |
Variable | _PY37PLUS | Undocumented |
Variable | _PYPY | Undocumented |
Function | _matchingString | No summary |
Function | _constructMethod | Construct a bound method. |
Function | _get_async_param | Provide a backwards-compatible way to get async param value that does not cause a syntax error under Python 3.7. |
Function | _pypy3BlockingHack | Work around this pypy bug by replacing socket.fromfd with a more conservative version. |
Return an iterable of the items of d
.
Parameters | d | Undocumented (type: dict ) |
Returns | Undocumented (type: iterable) |
Return an iterable of the values of d
.
Parameters | d | Undocumented (type: dict ) |
Returns | Undocumented (type: iterable) |
In Python 3, inspect.currentframe
does not take a stack-level argument. Restore that functionality from Python 2 so we don't have to re-implement the f_back
-walking loop in places where it's called.
Parameters | n | The number of stack levels above the caller to walk. (type: int ) |
Returns | a frame, n levels up the stack from the caller. (type: types.FrameType ) |
Execute a Python script in the given namespaces.
Similar to the execfile builtin, but a namespace is mandatory, partly because that's a sensible thing to require, and because otherwise we'd have to do some frame hacking.
This is a compatibility implementation for Python 3 porting, to avoid the use of the deprecated builtin execfile
function.
Compare two objects.
Returns a negative number if a < b
, zero if they are equal, and a positive number if a > b
.
Class decorator that ensures support for the special __cmp__
method.
__eq__
, __lt__
, etc. methods are added to the class, relying on __cmp__
to implement their comparisons.
Determine the type which will be returned from the given file object's read() and accepted by its write() method as an argument.
In other words, determine whether the given file is 'opened in text mode'.
Parameters | fileIshObject | Any object, but ideally one which resembles a file. (type: object ) |
default | A default value to return when the type of fileIshObject cannot be determined. (type: type ) | |
Returns | There are 3 possible return values:
type ) |
Some functions, such as os.path.join
, operate on string arguments which may be bytes or text, and wish to return a value of the same type. In those cases you may wish to have a string constant (in the case of os.path.join
, that constant would be os.path.sep
) involved in the parsing or processing, that must be of a matching type in order to use string operations on it. _matchingString
will take a constant string (either bytes
or str
) and convert it to the same type as the input string. constantString
should contain only characters from ASCII; to ensure this, it will be encoded or decoded regardless.
Parameters | constantString | A string literal used in processing. (type: str or bytes ) |
inputString | A byte string or text string provided by the user. (type: str or bytes ) | |
Returns | constantString converted into the same type as inputString (type: the type of inputString ) |
Re-raise an exception, with an optional traceback.
Re-raised exceptions will be mutated, with their __traceback__
attribute being set.
Parameters | exception | The exception instance. |
traceback | The traceback to use, or None indicating a new traceback. |
Return an iterable wrapper for a bytes
object that provides the behavior of iterating over bytes
on Python 2.
In particular, the results of iteration are the individual bytes (rather than integers as on Python 3).
Parameters | originalBytes | A bytes object that will be wrapped. |
Convert the given integer into bytes
, as ASCII-encoded Arab numeral.
Parameters | i | The int to convert to bytes . (type: int ) |
Returns | Undocumented (type: bytes ) |
Return a copy of the given bytes-like object.
If an offset is given, the copy starts at that offset. If a size is given, the copy will only be of that length.
Parameters | object | bytes to be copied. |
offset | int , starting index of copy. | |
size | Optional, if an int is given limit the length of copy to this size. |
Convert a string to bytes
using ASCII encoding.
This is useful for sending text-like bytes that are constructed using string interpolation. For example:
networkString("Hello %d" % (n,))
Parameters | s | A string to convert to bytes. (type: str ) |
Returns | Undocumented (type: bytes ) | |
Raises | UnicodeError | The input string is not ASCII encodable. |
TypeError | The input is not str . |
Return a dict
of os.environ
where all text-strings are encoded into bytes
.
This function is POSIX only; environment variables are always text strings on Windows.
Construct a bound method.
Parameters | cls | The class that the method should be bound to. (type: type ) |
name | The name of the method. (type: native str ) | |
self | The object that the method is bound to. (type: any object) | |
Returns | a bound method (type: types.MethodType ) |
Provide a backwards-compatible way to get async param value that does not cause a syntax error under Python 3.7.
Parameters | isAsync | isAsync param value (should default to None) (type: bool ) |
kwargs | keyword arguments of the caller (only async is allowed) (type: dict ) | |
Returns | Final isAsync param value (type: bool ) | |
Raises | TypeError | Both isAsync and async specified. |
Work around this pypy bug by replacing socket.fromfd
with a more conservative version.