Mailing List Archive

python/dist/src/Modules pypcre.c,2.23,2.24
Update of /cvsroot/python/python/dist/src/Modules
In directory usw-pr-cvs1:/tmp/cvs-serv31971/python/Modules

Modified Files:
pypcre.c
Log Message:
First stab at rationalizing the PyMem_ API. Mixing PyObject_xyz with
PyMem_{Del, DEL} doesn't work yet (compilation problems).

pyport.h: _PyMem_EXTRA is gone.

pmem.h: Repaired comments. PyMem_{Malloc, MALLOC} and
PyMem_{Realloc, REALLOC} now make the same x-platform guarantees when
asking for 0 bytes, and when passing a NULL pointer to the latter.

object.c: PyMem_{Malloc, Realloc} just call their macro versions
now, since the latter take care of the x-platform 0 and NULL stuff
by themselves now.

pypcre.c, grow_stack(): So sue me. On two lines, this called
PyMem_RESIZE to grow a "const" area. It's not legit to realloc a
const area, so the compiler warned given the new expansion of
PyMem_RESIZE. It would have gotten the same warning before if it
had used PyMem_Resize() instead; the older macro version, but not the
function version, silently cast away the constness. IMO that was a wrong
thing to do, and the docs say the macro versions of PyMem_xyz are
deprecated anyway. If somebody else is resizing const areas with the
macro spelling, they'll get a warning when they recompile now too.


Index: pypcre.c
===================================================================
RCS file: /cvsroot/python/python/dist/src/Modules/pypcre.c,v
retrieving revision 2.23
retrieving revision 2.24
diff -C2 -d -r2.23 -r2.24
*** pypcre.c 15 Mar 2002 09:16:40 -0000 2.23
--- pypcre.c 12 Apr 2002 07:22:56 -0000 2.24
***************
*** 3079,3084 ****
}
PyMem_RESIZE(md->offset_top, int, md->length);
! PyMem_RESIZE(md->eptr, const uschar *, md->length);
! PyMem_RESIZE(md->ecode, const uschar *, md->length);
PyMem_RESIZE(md->off_num, int, md->length);
PyMem_RESIZE(md->r1, int, md->length);
--- 3079,3087 ----
}
PyMem_RESIZE(md->offset_top, int, md->length);
! /* Can't realloc a pointer-to-const; cast const away. */
! md->eptr = (const uschar **)PyMem_Realloc((void *)md->eptr,
! sizeof(uschar *) * md->length);
! md->ecode = (const uschar **)PyMem_Realloc((void *)md->ecode,
! sizeof(uschar *) * md->length);
PyMem_RESIZE(md->off_num, int, md->length);
PyMem_RESIZE(md->r1, int, md->length);