|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | changes stay. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | New functions:
  unsigned long PyInt_AsUnsignedLongMask(PyObject *);
  unsigned PY_LONG_LONG) PyInt_AsUnsignedLongLongMask(PyObject *);
  unsigned long PyLong_AsUnsignedLongMask(PyObject *);
  unsigned PY_LONG_LONG) PyLong_AsUnsignedLongLongMask(PyObject *);
New and changed format codes:
b unsigned char 0..UCHAR_MAX
B unsigned char none **
h unsigned short 0..USHRT_MAX
H unsigned short none **
i int INT_MIN..INT_MAX
I * unsigned int 0..UINT_MAX
l long LONG_MIN..LONG_MAX
k * unsigned long none
L long long LLONG_MIN..LLONG_MAX
K * unsigned long long none
Notes:
* New format codes.
** Changed from previous "range-and-a-half" to "none"; the
range-and-a-half checking wasn't particularly useful.
New test test_getargs2.py, to verify all this. | 
| | |  | 
| | 
| 
| 
| | instead of raising a TypeError.  Closes #660144 (again). | 
| | 
| 
| 
| 
| | Calling PyInt_AsLong() on a float truncates it which is almost never
the desired behavior.  This closes SF bug #660144. | 
| | 
| 
| 
| 
| | the --disable-unicode build doesn't complain about an
unused variable. | 
| | |  | 
| | 
| 
| 
| | Bugfix candidate. | 
| | 
| 
| 
| 
| 
| | going through the buffer interface API.
Added tests for this to the _testcapi module and updated docs. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | use wrappers on all platforms, to make this as consistent as possible x-
platform (in particular, make sure there's at least one \0 byte in
the output buffer).  Also document more of the truth about what these do.
getargs.c, seterror():  Three computations of remaining buffer size were
backwards, thus telling PyOS_snprintf the buffer is larger than it
actually is.  This matters a lot now that PyOS_snprintf ensures there's a
trailing \0 byte (because it didn't get the truth about the buffer size,
it was storing \0 beyond the true end of the buffer).
sysmodule.c, mywrite():  Simplify, now that PyOS_vsnprintf guarantees to
produce a \0 byte. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | vgetargskeywords():  Now that this routine is checking for bad input
(rather than dump core in some cases), some bad calls are raising errors
that previously "worked".  This patch makes the error strings more
revealing, and changes the exceptions from SystemError to RuntimeError
(under the theory that SystemError is more of a "can't happen!" assert-
like thing, and so inappropriate for bad arguments to a public C API
function). | 
| | 
| 
| 
| 
| | Also change all the helper functions to pass along the size of the
msgbuf and use PyOS_snprintf() when writing into the buffer. | 
| | 
| 
| 
| 
| 
| | seterror() uses a char array and a pointer to the current position in
that array.  Use snprintf() and compute the amount of space left in
the buffer based on the current pointer position. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | + Squash another potential buffer overrun.
+ Simplify the keyword-arg loop by decrementing the count of keywords
  remaining instead of incrementing Yet Another Variable; also break
  out early if the number of keyword args remaining hits 0.
Since I hit the function's closing curly brace with this patch, that's
enough of this for now <wink>. | 
| | 
| 
| 
| | we're ensuring that's true during the format parse, get rid of nkwlist. | 
| | |  | 
| | 
| 
| 
| 
| | the format, instead of waiting until after we can overindex it by
mistake. | 
| | 
| 
| 
| 
| | this routine will report an error now when it didn't before, but, if so,
it's a legitimate error that should never have been suppressed. | 
| | 
| 
| 
| 
| | dict API everywhere on it instead of sometimes using the slower mapping
API. | 
| | 
| 
| 
| 
| 
| 
| | The "need" for this was probably removed by an earlier patch that stopped
the loop right before it from passing NULL to a dict lookup routine.
I still haven't convinced myself that the next loop is correct, so am
leaving the next mysterious PyErr_Clear() call in for now. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | + Generally test nkeywords against 0 instead of keywords against NULL
  (saves a little work if an empty keywords dict is passed, and is
  conceptually more on-target regardless).
+ When a call erroneously specifies a keyword argument both by position
  and by keyword name:
    - It was easy to provoke this routine into an internal buffer overrun
      by using a long argument name.  Now uses PyErr_format instead (which
      computes a safe buffer size).
    - Improved the error msg. | 
| | 
| 
| 
| 
| 
| | + Got rid of now-redundant dict typecheck.
+ Renamed nkwds to nkwlist.  Now all the "counting" vrbls have names
  related to the things they're counting in an obvious way. | 
| | 
| 
| 
| 
| 
| 
| | + Renamed argslen to nargs.
+ Renamed kwlen to nkeywords.  This one was especially confusing because
  kwlen wasn't the length of the kwlist argument, but of the keywords
  argument. | 
| | 
| 
| 
| 
| 
| 
| | + Removed now-redundant tuple typecheck.
+ Renamed "tplen" local to "argslen" (it's the length of the "args"
  argument; I suppose "tp" was for "Tim Peters should rename me
  someday <wink>). | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | introduced this bug just a little while ago, when *adding* internal error
checks).
vgetargskeywords:  Rewrote the section that crawls over the format string.
+ Added block comment so it won't take the next person 15 minutes to
  reverse-engineer what it's doing.
+ Lined up the "else" clauses.
+ Rearranged the ifs in decreasing order of likelihood (for speed). | 
| | 
| 
| 
| 
| 
| | and raise an error if they're insane.
vgetargskeywords:  the same, except that since this is an internal routine,
just assert that the arguments are sane. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the kwlist vector whenever there was a mix of positional and keyword
arguments, and the number of positional arguments exceeded the length
of the kwlist vector.  If there was just one more positional arg than
keyword, the kwlist-terminating NULL got passed to PyMapping_HasKeyString,
which set an internal error that vgetargskeywords() then squashed (but
it's impossible to say whether it knew it was masking an error).  If
more than one more positional argument, it went on to pass random trash
to PyMapping_HasKeyString, which is why the example at the start
happened to kill the process.
Pure bugfix candidate. | 
| | 
| 
| 
| | removing useless obfuscation. | 
| | 
| 
| 
| | Fulton, based on code Jim supplied. | 
| | 
| 
| 
| | Make convertbuffer() static like the prototype says.  Not used elsewhere. | 
| | 
| 
| 
| 
| | convertbuffer() uses the buffer interface's getreadbuffer(), but 't'
should use getcharbuffer(). | 
| | 
| 
| 
| | PyString_Check() had already succeeded. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Reported by Fredrik Lundh on python-dev.
The conversimple() code that handles Unicode arguments and converts
them to the default encoding now calls converterr() with the original
Unicode argument instead of the NULL returned by the failed encoding
attempt. | 
| | 
| 
| 
| | rather than a type equality test. | 
| | 
| 
| 
| 
| 
| 
| 
| | - Do not compile unicodeobject, unicodectype, and unicodedata if Unicode is disabled
- check for Py_USING_UNICODE in all places that use Unicode functions
- disables unicode literals, and the builtin functions
- add the types.StringTypes list
- remove Unicode literals from most tests. | 
| | 
| 
| 
| 
| 
| 
| | And remove all the extern decls in the middle of .c files.
Apparently, it was excluded from the header file because it is
intended for internal use by the interpreter.  It's still intended for
internal use and documented as such in the header file. | 
| | 
| 
| 
| 
| 
| 
| 
| | In the default branch, keep three ifs that are used if level == 0, the
most common case.  Note that first if here is a slight optimization
for the 'O' format.
Second part of SF patch 426072. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Note that lots of code was re-indented.
Replace two-step of convertsimple() and convertsimple1() with
convertsimple() and helper converterr(), which is called to format
error messages when convertsimple() fails.  The old code did all the
real work in convertsimple1(), but deferred error message formatting
to conversimple().  The result was paying the price of a second
function call on every call just to format error messages in the
failure cases.
Factor out of the buffer-handling code in convertsimple() and package
it as convertbuffer().
Add two macros to ease readability of Unicode coversions,
UNICODE_DEFAULT_ENCODING() and CONV_UNICODE, an error string.
The convertsimple() routine had awful indentation problems, primarily
because there were two tabs between the case line and the body of the
case statements.  This patch reformats the entire function to have a
single tab between case line and case body, which makes the code
easier to read (and consistent with ceval).  The introduction of
converterr() exacerbated the problem and prompted this fix.
Also, eliminate non-standard whitespace after opening paren and before
closing paren in a few if statements.
(This checkin is part of SF patch 426072.) | 
| | |  | 
| | 
| 
| 
| 
| | PyTuple_GetItem() with PyTuple_GET_SIZE() and PyTuple_GET_ITEM().
    The code has already done a PyTuple_Check(). | 
| | 
| 
| 
| | dealing with the file system.  As discussed on python-dev and in patch 410465. | 
| | 
| 
| 
| 
| 
| 
| | objects but instead assume that they use the requested encoding.
This is needed on Windows to enable opening files by passing in
Unicode file names. | 
| | 
| 
| 
| 
| 
| 
| 
| | _testcapimodule.c
    make sure PyList_Reverse doesn't blow up again
getargs.c
    assert args isn't NULL at the top of vgetargs1 instead of
    waiting for a NULL-pointer dereference at the end | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | message, and tries to make the messages more consistent and helpful when
the wrong number of arguments or duplicate keyword arguments are supplied.
Comes with more tests for test_extcall.py and and an update to an error
message in test/output/test_pyexpat. | 
| | |  | 
| | 
| 
| 
| | buffer" replaced by "string or read-only character buffer". |