1. 04 Jul, 2001 9 commits
  2. 03 Jul, 2001 3 commits
    • Fred Drake's avatar
      This change adjusts the profiling/tracing support so that the common · 9e3ad784
      Fred Drake authored
      path (with no profile/trace function) through eval_code2() and
      eval_frame() avoids several checks.
      
      In the common cases of calls, returns, and exception propogation,
      eval_code2() and eval_frame() used to test two values in the
      thread-state: the profiling function and the tracing function.  With
      this change, a flag is set in the thread-state if either of these is
      active, allowing a single check to suffice when both are NULL.  This
      also simplifies the code needed when either function is in use but is
      already active (to avoid profiling/tracing the profiler/tracer); the
      flag is set to 0 when the profile/trace code is entered, allowing the
      same check to suffice for "already in the tracer" for call/return/
      exception events.
      9e3ad784
    • Fredrik Lundh's avatar
      bug #416670 · d89a2e77
      Fredrik Lundh authored
      added copy/deepcopy support to SRE (still not enabled, since it's not
      covered by the test suite)
      d89a2e77
    • Fredrik Lundh's avatar
      bug #232815 · ee2f18d0
      Fredrik Lundh authored
      ch is unsigned, so testing for negative values doesn't make
      sense (as noticed by the OpenVMS compiler)
      ee2f18d0
  3. 02 Jul, 2001 12 commits
  4. 01 Jul, 2001 2 commits
  5. 30 Jun, 2001 1 commit
  6. 29 Jun, 2001 9 commits
    • Tim Peters's avatar
      Turns out Neil didn't intend for *all* of his gen-branch work to get · 4efb6e96
      Tim Peters authored
      committed.
      
      tokenize.py:  I like these changes, and have tested them extensively
      without even realizing it, so I just updated the docstring and the docs.
      
      tabnanny.py:  Also liked this, but did a little code fiddling.  I should
      really rewrite this to *exploit* generators, but that's near the bottom
      of my effort/benefit scale so doubt I'll get to it anytime soon (it
      would be most useful as a non-trivial example of ideal use of generators;
      but test_generators.py has already grown plenty of food-for-thought
      examples).
      
      inspect.py:  I'm sure Ping intended for this to continue running even
      under 1.5.2, so I reverted this to the last pre-gen-branch version.  The
      "bugfix" I checked in in-between was actually repairing a bug *introduced*
      by the conversion to generators, so it's OK that the reverted version
      doesn't reflect that checkin.
      4efb6e96
    • Fred Drake's avatar
      Use the more conventional "self" as the name of the self parameter in an · 88e66254
      Fred Drake authored
      example.  It actually confused a reader.
      88e66254
    • Fred Drake's avatar
      Correct a markup error for an accented character. · 0c209047
      Fred Drake authored
      Reported by Milan Zamazal <pdm@zamazal.org>.
      0c209047
    • Fred Drake's avatar
      Removed some stray periods, and fix up a number of visible markup · 58c95391
      Fred Drake authored
      consistency errors (mostly omitted "()" at the end of function and
      method names).
      
      Reported by Milan Zamazal <pdm@zamazal.org>.
      58c95391
    • Fred Drake's avatar
      Two more names. · 9c3c5e40
      Fred Drake authored
      9c3c5e40
    • Fred Drake's avatar
      SourceForge bug #437041: · f29ca18d
      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.
      f29ca18d
    • Fred Drake's avatar
      Simplify an example based on comment from Thomas Holenstein <thomas@hex.ch>: · 9f9bd6af
      Fred Drake authored
      Do not use an extra flag variable to test only once in one subsequent if
      statement.
      9f9bd6af
    • Guido van Rossum's avatar
      Solve SF bug #231249: cgi.py opens too many (temporary) files. · 52b8c29c
      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.
      52b8c29c
    • Tim Peters's avatar
      Added a simple but general backtracking generator (conjoin), and a couple · be4f0a77
      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.
      be4f0a77
  7. 28 Jun, 2001 3 commits
  8. 27 Jun, 2001 1 commit