mirror of
https://github.com/python/cpython.git
synced 2025-07-07 19:35:27 +00:00

exposed in header files. Fixed a few comments in these headers. As we might have expected, writing down invariants systematically exposed a (minor) bug. In this case, function objects have a writeable func_code attribute, which could be set to code objects with the wrong number of free variables. Calling the resulting function segfaulted the interpreter. Added a corresponding test.
42 lines
1.1 KiB
C
42 lines
1.1 KiB
C
#ifndef Py_SLICEOBJECT_H
|
|
#define Py_SLICEOBJECT_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* The unique ellipsis object "..." */
|
|
|
|
PyAPI_DATA(PyObject) _Py_EllipsisObject; /* Don't use this directly */
|
|
|
|
#define Py_Ellipsis (&_Py_EllipsisObject)
|
|
|
|
/* Slice object interface */
|
|
|
|
/*
|
|
|
|
A slice object containing start, stop, and step data members (the
|
|
names are from range). After much talk with Guido, it was decided to
|
|
let these be any arbitrary python type. Py_None stands for omitted values.
|
|
*/
|
|
|
|
typedef struct {
|
|
PyObject_HEAD
|
|
PyObject *start, *stop, *step; /* not NULL */
|
|
} PySliceObject;
|
|
|
|
PyAPI_DATA(PyTypeObject) PySlice_Type;
|
|
|
|
#define PySlice_Check(op) ((op)->ob_type == &PySlice_Type)
|
|
|
|
PyAPI_FUNC(PyObject *) PySlice_New(PyObject* start, PyObject* stop,
|
|
PyObject* step);
|
|
PyAPI_FUNC(int) PySlice_GetIndices(PySliceObject *r, int length,
|
|
int *start, int *stop, int *step);
|
|
PyAPI_FUNC(int) PySlice_GetIndicesEx(PySliceObject *r, int length,
|
|
int *start, int *stop,
|
|
int *step, int *slicelength);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* !Py_SLICEOBJECT_H */
|