|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| | 1.6a2 caused by wrong return values in routine allcaps83.  [GvR: I
also changed the case for end-s>8 to return 0.] | 
| | 
| 
| 
| | because we've added Unicode marshalling to the repertoire. | 
| | 
| 
| 
| 
| 
| 
| 
| | Follow a suggestion in an /*XXX*/ comment [in com_add()] to speed up
compilation by using supplemental dictionaries to keep track of names
and constants, eliminating quadratic behavior.  With this patch in
place, the time to import a 5000-line file with lots of constants [at
the global level] is reduced from 20 seconds to under 3 on my system. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Here's a patch which changes modsupport to add 'u' and 'u#',
to support building Unicode objects from a null-terminated
Py_UNICODE *, and a Py_UNICODE * with length, respectively.
[Conversion from 'U' to 'u' by Fred, based on python-dev comments.]
Note that the use of None for NULL values of the Py_UNICODE* value is
still in; I'm not sure of the conclusion on that issue. | 
| | 
| 
| 
| 
| 
| | remaining object references if the environment variable PYTHONDUMPREFS
exists.  The default behaviour caused problems for background or
otherwise invisible processes that use the debug build of Python. | 
| | 
| 
| 
| 
| 
| 
| 
| | Fixed a memory leak found by Fredrik Lundh.  Instead of
PyUnicode_AsUTF8String() we now use _PyUnicode_AsUTF8String() which
returns the string object without incremented refcount (and assures
that the so obtained object remains alive until the Unicode object is
garbage collected). | 
| | 
| 
| 
| | has a few slightly different calls from the old one. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | """
Running "test_extcall" repeatedly results in memory leaks.
One of these can't be fixed (at least not easily!), it happens since
this code:
def saboteur(**kw):
    kw['x'] = locals()
d = {}
saboteur(a=1, **d)
creates a circular reference - d['x']['d']==d
The others are due to some missing decrefs in ceval.c, fixed by the
patch attached below.
Note:  I originally wrote this without the "goto", just adding the
missing decref's where needed.  But I think the goto is justified in
keeping the executable code size of ceval as small as possible.
"""
[I think the circular reference is more like kw['x']['kw'] == kw. --GvR] | 
| | 
| 
| 
| 
| | Note that comparisons of deeply nested objects can still dump core in
extreme cases. | 
| | 
| 
| 
| | suggestion from Greg Stein. | 
| | 
| 
| 
| 
| 
| | major, minor, micro, level, serial
Values are now monotonically increasing with each new release. | 
| | 
| 
| 
| 
| 
| | is a string "a2", "b1", "c1", or '' for a final release.
Added version_info and hexversion to the module docstring. | 
| | 
| 
| 
| 
| | Fixed problem with Unicode string concatenation:
u = (u"abc" u"abc") previously dumped core. | 
| | 
| 
| 
| 
| | docstrings, the documentation guidelines call for "Unicode", not
"unicode".  Comply. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | Added special case to unicode(): when being passed a
Unicode object as first argument, return the object as-is.
Raises an exception when given a Unicode object *and* an
encoding name. | 
| | 
| 
| 
| 
| 
| 
| | comparing code objects.  This give sless surprising results in
-Optimized code.  It also sorts code objects by name, now.
[I changed the patch to hash() slightly to touch fewer lines.] | 
| | 
| 
| 
| | to prevent possible buffer overruns. | 
| | 
| 
| 
| 
| | representation of code objects when optimization is on (python -O). It
was always reported as -1 instead of the real lineno. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | his copy of test_contains.py seems to be broken -- the lines he
deleted were already absent).  Checkin messages:
New Unicode support for int(), float(), complex() and long().
- new APIs PyInt_FromUnicode() and PyLong_FromUnicode()
- added support for Unicode to PyFloat_FromString()
- new encoding API PyUnicode_EncodeDecimal() which converts
  Unicode to a decimal char* string (used in the above new
  APIs)
- shortcuts for calls like int(<int object>) and float(<float obj>)
- tests for all of the above
Unicode compares and contains checks:
- comparing Unicode and non-string types now works; TypeErrors
  are masked, all other errors such as ValueError during
  Unicode coercion are passed through (note that PyUnicode_Compare
  does not implement the masking -- PyObject_Compare does this)
- contains now works for non-string types too; TypeErrors are
  masked and 0 returned; all other errors are passed through
Better testing support for the standard codecs.
Misc minor enhancements, such as an alias dbcs for the mbcs codec.
Changes:
- PyLong_FromString() now applies the same error checks as
  does PyInt_FromString(): trailing garbage is reported
  as error and not longer silently ignored. The only characters
  which may be trailing the digits are 'L' and 'l' -- these
  are still silently ignored.
- string.ato?() now directly interface to int(), long() and
  float(). The error strings are now a little different, but
  the type still remains the same. These functions are now
  ready to get declared obsolete ;-)
- PyNumber_Int() now also does a check for embedded NULL chars
  in the input string; PyNumber_Long() already did this (and
  still does)
Followed by:
Looks like I've gone a step too far there... (and test_contains.py
seem to have a bug too).
I've changed back to reporting all errors in PyUnicode_Contains()
and added a few more test cases to test_contains.py (plus corrected
the join() NameError). | 
| | 
| 
| 
| | mechanism is enhanced to be more informative. | 
| | |  | 
| | 
| 
| 
| 
| 
| | override)
add missing DECREFs in error handling code of CALL_FUNCTION | 
| | 
| 
| 
| | "innermost last".  The latter was mysterious to newbies. | 
| | 
| 
| 
| | (Mostly.) | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | If a non-tuple sequence is passed as the *arg, convert it to a tuple
before checking its length.
If named keyword arguments are used in combination with **kwargs, make
a copy of kwargs before inserting the new keys. | 
| | 
| 
| 
| 
| | PyErr_Occurred(), just set x=NULL and break.  Oh, and make Jeremy stop
nagging me about the "special" indentation for this block. | 
| | 
| 
| 
| 
| 
| | the return value of PySequence_Length().  If an exception occurred,
the returned length will be -1.  Make sure this doesn't get obscurred,
and that the bogus length isn't used. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | executive summary:
Instead of typing 'apply(f, args, kwargs)' you can type 'f(*arg, **kwargs)'.
Some file-by-file details follow.
Grammar/Grammar:
    simplify varargslist, replacing '*' '*' with '**'
    add * & ** options to arglist
Include/opcode.h & Lib/dis.py:
    define three new opcodes
        CALL_FUNCTION_VAR
        CALL_FUNCTION_KW
        CALL_FUNCTION_VAR_KW
Python/ceval.c:
    extend TypeError "keyword parameter redefined" message to include
        the name of the offending keyword
    reindent CALL_FUNCTION using four spaces
    add handling of sequences and dictionaries using extend calls
    fix function import_from to use PyErr_Format | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The attached patch set includes a workaround to get Python with
Unicode compile on BSDI 4.x (courtesy Thomas Wouters; the cause
is a bug in the BSDI wchar.h header file) and Python interfaces
for the MBCS codec donated by Mark Hammond.
Also included are some minor corrections w/r to the docs of
the new "es" and "es#" parser markers (use PyMem_Free() instead
of free(); thanks to Mark Hammond for finding these).
The unicodedata tests are now in a separate file
(test_unicodedata.py) to avoid problems if the module cannot
be found. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Attached you find the latest update of the Unicode implementation.
The patch is against the current CVS version.
It includes the fix I posted yesterday for the core dump problem
in codecs.c (was introduced by my previous patch set -- sorry),
adds more tests for the codecs and two new parser markers
"es" and "es#". | 
| | 
| 
| 
| 
| 
| | Andy Robinson noted a core dump in the codecs.c file. This
was introduced by my latest patch which fixed a memory leak
in codecs.c. The bug causes all successful codec lookups to fail. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Attached you find an update of the Unicode implementation.
    The patch is against the current CVS version. I would appreciate
    if someone with CVS checkin permissions could check the changes
    in.
    The patch contains all bugs and patches sent this week and also
    fixes a leak in the codecs code and a bug in the free list code
    for Unicode objects (which only shows up when compiling Python
    with Py_DEBUG; thanks to MarkH for spotting this one). | 
| | 
| 
| 
| 
| 
| 
| 
| | Added wrapping macros to dictobject.c, listobject.c, tupleobject.c,
frameobject.c, traceback.c that safely prevends core dumps
on stack overflow. Macros and functions in object.c, object.h.
The method is an "elevator destructor" that turns cascading
deletes into tail recursive behavior when some limit is hit. | 
| | |  | 
| | 
| 
| 
| | Codec registry. | 
| | |  | 
| | 
| 
| 
| | object. | 
| | |  | 
| | 
| 
| 
| 
| | unichr(); changed ord() to support Unicode strings; added new
exception UnicodeError; fixed a typo in doc string for buffer(). | 
| | 
| 
| 
| | Lemburg. | 
| | 
| 
| 
| | in PyErr_SetFromWindowsErrWithFilename() like he intended to... :-) | 
| | 
| 
| 
| | PyArg_ParseTuple() format string arguments as possible. | 
| | |  | 
| | 
| 
| 
| 
| | PyEval_EvalCode() is *not* a "backward compatible interface", it's the
one to use! | 
| | 
| 
| 
| 
| | enough, it could be negative.  Add i > 0 test.  (Not i >= 0; zero isn't
a valid error number.) |