- 11 May, 2001 6 kayıt (commit)
-
-
Jeremy Hylton yazdı
For rich comparisons, use instance_getattr2() when possible to avoid the expense of setting an AttributeError. Also intern the name_op[] table and use the interned strings rather than creating a new string and interning it each time through.
-
Fred Drake yazdı
Remove unused import of "sys". If the file TESTFN exists before we start, try to remove it. Add spaces around the = in some assignments.
-
Tim Peters yazdı
-
Fred Drake yazdı
"\begin{classdesc*}{SomeClass}" -- the rendering of \unspecified was identical to \moreargs, so this helps clarify things just a little.
-
Fred Drake yazdı
excclassdesc environment.
-
Fred Drake yazdı
class without providing any information about the constructor. This should be used for classes which only exist to act as containers rather than as factories for instances.
-
- 10 May, 2001 25 kayıt (commit)
-
-
Fred Drake yazdı
useful documentation on the Scrap Manager.
-
Fred Drake yazdı
-
Tim Peters yazdı
doesn't know how to do LE, LT, GE, GT. dict_richcompare can't do the latter any faster than dict_compare can. More importantly, for cmp(dict1, dict2), Python *first* tries rich compares with EQ, LT, and GT one at a time, even if the tp_compare slot is defined, and dict_richcompare called dict_compare for the latter two because it couldn't do them itself. The result was a lot of wasted calls to dict_compare. Now dict_richcompare gives up at once the times Python calls it with LT and GT from try_rich_to_3way_compare(), and dict_compare is called only once (when Python gets around to trying the tp_compare slot). Continued mystery: despite that this cut the number of calls to dict_compare approximately in half in test_mutants.py, the latter still runs amazingly slowly. Running under the debugger doesn't show excessive activity in the dict comparison code anymore, so I'm guessing the culprit is somewhere else -- but where? Perhaps in the element (key/value) comparison code? We clearly spend a lot of time figuring out how to compare things.
-
Tim Peters yazdı
A Mystery: test_mutants ran amazingly slowly even before dictobject.c "got fixed". I don't have a clue as to why. dict comparison was and remains linear-time in the size of the dicts, and test_mutants only tries 100 dict pairs, of size averaging just 50. So "it should" run in less than an eyeblink; but it takes at least a second on this 800MHz box.
-
Tim Peters yazdı
and wrap the body in try/finally to ensure TESTFN gets cleaned up no matter what.
-
Tim Peters yazdı
-
Tim Peters yazdı
-
Fred Drake yazdı
-
Fred Drake yazdı
This closes SF bug #423087.
-
Fred Drake yazdı
both weakref.Weak*Dictionary classes. This closes SF bug #416480.
-
Fred Drake yazdı
-
Fred Drake yazdı
module for useful constants.
-
Fred Drake yazdı
-
Fred Drake yazdı
-
Fred Drake yazdı
-
Fred Drake yazdı
(The string "strop" is found in the rexec documentation, but that should not be changed until strop is actually removed or rexec no longer allows it.)
-
Jack Jansen yazdı
-
Jack Jansen yazdı
-
Tim Peters yazdı
Fixed a half dozen ways in which general dict comparison could crash Python (even cause Win98SE to reboot) in the presence of kay and/or value comparison routines that mutate the dict during dict comparison. Bugfix candidate.
-
Fred Drake yazdı
*not* define O_RDWR; get that from the os module.
-
Steve Purcell yazdı
-
Tim Peters yazdı
meaning infinity -- but at least warn about it in the code! I pissed away a couple hours on this today, and don't wish the same on the next in line. Bugfix candidate.
-
Tim Peters yazdı
means "replace everything". But the string module, string.replace() amd test_string.py believe a 0 count means "replace nothing". "Nothing" wins, strop loses. Bugfix candidate.
-
Tim Peters yazdı
out of synch than I realized, and I managed to break replace's "count" argument when it was 0. All is well again. Maybe. Bugfix candidate.
-
Tim Peters yazdı
mymemXXX stuff, and they were already out of synch. Fix the remaining bugs in both and get them back in synch. Bugfix release candidate.
-
- 09 May, 2001 9 kayıt (commit)
-
-
Tim Peters yazdı
Platform blew up on "123".replace("123", ""). Michael Hudson pinned the blame on platform malloc(0) returning NULL. This is a candidate for all bugfix releases.
-
Tim Peters yazdı
-
Fred Drake yazdı
needed now that fcntl exports the constants.
-
Fred Drake yazdı
warning. This is similar to the TERMIOS backward compatbility module.
-
Fred Drake yazdı
and using the constants defined there instead of FCNTL.
-
Fred Drake yazdı
-
Fred Drake yazdı
This closes SF bug #231328. Added all constants needed to use the functions defined in this module that are not defined elsewhere (the O_* symbols are available in the os module). No additonal modules are needed to use this now.
-
Fred Drake yazdı
PyObject_AsFileDescriptor() -- it does the same thing everywhere, so use it the same way everyone else does so that exceptions are consistent. This means we have less code here, and we do not need to resort to hackish ways of getting the Python-visible function name to fdconv().
-
Tim Peters yazdı
Thanks to Mark Favas.
-