- 29 Jun, 2001 8 commits
-
-
Fred Drake authored
example. It actually confused a reader.
-
Fred Drake authored
Reported by Milan Zamazal <pdm@zamazal.org>.
-
Fred Drake authored
consistency errors (mostly omitted "()" at the end of function and method names). Reported by Milan Zamazal <pdm@zamazal.org>.
-
Fred Drake authored
-
Fred Drake authored
Use a portable format in the example that creates a timestamp suitable for use in email, also updating it and the footnote from RFC 822 to RFC 2822.
-
Fred Drake authored
Do not use an extra flag variable to test only once in one subsequent if statement.
-
Guido van Rossum authored
class FieldStorage: this patch changes read_lines() and co. to use a StringIO() instead of a real file. The write() calls are redirected to a private method that replaces it with a real, external file only when it gets too big (> 1000 bytes). This avoids problems in forms using the multipart/form-data encoding with many fields. The original code created a temporary file for *every* field (not just for file upload fields), thereby sometimes exceeding the open file limit of some systems. Note that the simpler solution "use a real file only for file uploads" can't be used because the form field parser has no way to tell which fields correspond to file uploads. It's *possible* but extremely unlikely that this would break someone's code; they would have to be stepping way outside the documented interface for FieldStorage and use f.file.fileno(), or depend on overriding make_file() to return a file-like object with additional known properties.
-
Tim Peters authored
examples of use. These poke stuff not specifically targeted before, incl. recursive local generators relying on nested scopes, ditto but also inside class methods and rebinding instance vars, and anonymous partially-evaluated generators (the N-Queens solver creates a different column-generator for each row -- AFAIK this is my invention, and it's really pretty <wink>). No problems, not even a new leak.
-
- 28 Jun, 2001 3 commits
-
-
Jack Jansen authored
-
Jack Jansen authored
Make basechain a class variable in stead of initializing it in __init__. That way it's more easily overridden.
-
Tim Peters authored
"return expr" instances in generators (which latter may be generators due to otherwise invisible "yield" stmts hiding in "if 0" blocks). This was fun the first time, but this has gotten truly ugly now.
-
- 27 Jun, 2001 13 commits
-
-
Fredrik Lundh authored
predicates
-
Jack Jansen authored
CFStrings are in better shape, but Unicode support and automatic conversion to/from Python strings remains to be done.
-
Jack Jansen authored
-
Andrew M. Kuchling authored
-
Martin v. Löwis authored
-
Fredrik Lundh authored
-
Fred Drake authored
Python interpreter. This change adds two new C-level APIs: PyEval_SetProfile() and PyEval_SetTrace(). These can be used to install profile and trace functions implemented in C, which can operate at much higher speeds than Python-based functions. The overhead for calling a C-based profile function is a very small fraction of a percent of the overhead involved in calling a Python-based function. The machinery required to call a Python-based profile or trace function been moved to sysmodule.c, where sys.setprofile() and sys.setprofile() simply become users of the new interface. As a side effect, SF bug #436058 is fixed; there is no longer a _PyTrace_Init() function to declare.
-
Fred Drake authored
Python interpreter. This change adds two new C-level APIs: PyEval_SetProfile() and PyEval_SetTrace(). These can be used to install profile and trace functions implemented in C, which can operate at much higher speeds than Python-based functions. The overhead for calling a C-based profile function is a very small fraction of a percent of the overhead involved in calling a Python-based function. The machinery required to call a Python-based profile or trace function been moved to sysmodule.c, where sys.setprofile() and sys.setprofile() simply become users of the new interface.
-
Fredrik Lundh authored
tests.
-
Barry Warsaw authored
-
Thomas Wouters authored
-
Tim Peters authored
that required explicitly calling LazyList.clear() in the two tests that use LazyList (I added a LazyList Fibonacci generator too). A real bitch: the extremely inefficient first version of the 2-3-5 test *looked* like a slow leak on Win98SE, but it wasn't "really": it generated so many results that the heap grew over 4Mb (tons of frames! the number of frames grows exponentially in that test). Then Win98SE malloc() starts fragmenting address space allocating more and more heaps, and the visible memory use grew very slowly while the disk was thrashing like mad. Printing fewer results (i.e., keeping the heap burden under 4Mb) made that illusion vanish. Looks like there's no hope for plugging the LazyList leaks automatically short of adding frameobjects and genobjects to gc. OTOH, they're very easy to break by hand, and they're the only *kind* of plausibly realistic leaks I've been able to provoke. Dilemma.
-
Martin v. Löwis authored
Implement sys.maxunicode. Explicitly wrap around upper/lower computations for wide Py_UNICODE. When decoding large characters with UTF-8, represent expected test results using the \U notation.
-
- 26 Jun, 2001 16 commits
-
-
Guido van Rossum authored
- the correct range for the error message is range(0x110000); - put the 4-byte Unicode-size code inside the same else branch as the 2-byte code, rather generating unreachable code in the 2-byte case. - Don't hide the 'else' behine the '}'. (I would prefer that in 4-byte mode, any value should be accepted, but reasonable people can argue about that, so I'll put that off.)
-
Fredrik Lundh authored
-
Martin v. Löwis authored
when checking surrogates.
-
Tim Peters authored
SIZEOF_SHORT by hand here. Also added dynamic check that SIZEOF_SHORT is correct for the platform (in _testcapimodule).
-
Tim Peters authored
not writable -- too dangerous!) from Python code.
-
Martin v. Löwis authored
Add configure option --enable-unicode. Add config.h macros Py_USING_UNICODE, PY_UNICODE_TYPE, Py_UNICODE_SIZE, SIZEOF_WCHAR_T. Define Py_UCS2. Encode and decode large UTF-8 characters into single Py_UNICODE values for wide Unicode types; likewise for UTF-16. Remove test whether sizeof Py_UNICODE is two.
-
Jack Jansen authored
such as the Core Foundation ones.
-
Jack Jansen authored
-
Jack Jansen authored
First small step towards bgen-generated CoreFoundation. there is hardly any real functionality yet, but method chains seem to work, and so do Retain/Release semantics.
-
Tim Peters authored
Makes it much easier to find references via dumb editor search (former "frame" in particular was near-hopeless).
-
Fredrik Lundh authored
sizeof(int)
-
Barry Warsaw authored
-
Barry Warsaw authored
mapping objects as an argument.
-
Barry Warsaw authored
a non-dictionary mapping object. Include tests for several expected failure modes.
-
Barry Warsaw authored
"mapping" object, specifically one that supports PyMapping_Keys() and PyObject_GetItem(). This allows you to say e.g. {}.update(UserDict()) We keep the special case for concrete dict objects, although that seems moderately questionable. OTOH, the code exists and works, so why change that? .update()'s docstring already claims that D.update(E) implies calling E.keys() so it's appropriate not to transform AttributeErrors in PyMapping_Keys() to TypeErrors. Patch eyeballed by Tim.
-
Fredrik Lundh authored
wrt surrogates. (this extends the valid range from 65535 to 1114111)
-