ffi: cleanup sliceobject
This commit is contained in:
parent
68cba78a44
commit
126df617b0
|
@ -12,6 +12,15 @@ pub unsafe fn Py_Ellipsis() -> *mut PyObject {
|
||||||
&mut _Py_EllipsisObject
|
&mut _Py_EllipsisObject
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(not(Py_LIMITED_API))]
|
||||||
|
#[repr(C)]
|
||||||
|
pub struct PySliceObject {
|
||||||
|
pub ob_base: PyObject,
|
||||||
|
pub start: *mut PyObject,
|
||||||
|
pub stop: *mut PyObject,
|
||||||
|
pub step: *mut PyObject,
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg_attr(windows, link(name = "pythonXY"))]
|
#[cfg_attr(windows, link(name = "pythonXY"))]
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#[cfg_attr(PyPy, link_name = "PyPySlice_Type")]
|
#[cfg_attr(PyPy, link_name = "PyPySlice_Type")]
|
||||||
|
@ -24,14 +33,6 @@ pub unsafe fn PySlice_Check(op: *mut PyObject) -> c_int {
|
||||||
(Py_TYPE(op) == &mut PySlice_Type) as c_int
|
(Py_TYPE(op) == &mut PySlice_Type) as c_int
|
||||||
}
|
}
|
||||||
|
|
||||||
#[repr(C)]
|
|
||||||
pub struct PySliceObject {
|
|
||||||
pub ob_base: PyObject,
|
|
||||||
pub start: *mut PyObject,
|
|
||||||
pub stop: *mut PyObject,
|
|
||||||
pub step: *mut PyObject,
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#[cfg_attr(PyPy, link_name = "PyPySlice_New")]
|
#[cfg_attr(PyPy, link_name = "PyPySlice_New")]
|
||||||
pub fn PySlice_New(
|
pub fn PySlice_New(
|
||||||
|
@ -39,6 +40,10 @@ extern "C" {
|
||||||
stop: *mut PyObject,
|
stop: *mut PyObject,
|
||||||
step: *mut PyObject,
|
step: *mut PyObject,
|
||||||
) -> *mut PyObject;
|
) -> *mut PyObject;
|
||||||
|
|
||||||
|
// skipped non-limited _PySlice_FromIndices
|
||||||
|
// skipped non-limited _PySlice_GetLongIndices
|
||||||
|
|
||||||
#[cfg_attr(PyPy, link_name = "PyPySlice_GetIndices")]
|
#[cfg_attr(PyPy, link_name = "PyPySlice_GetIndices")]
|
||||||
pub fn PySlice_GetIndices(
|
pub fn PySlice_GetIndices(
|
||||||
r: *mut PyObject,
|
r: *mut PyObject,
|
||||||
|
@ -47,6 +52,8 @@ extern "C" {
|
||||||
stop: *mut Py_ssize_t,
|
stop: *mut Py_ssize_t,
|
||||||
step: *mut Py_ssize_t,
|
step: *mut Py_ssize_t,
|
||||||
) -> c_int;
|
) -> c_int;
|
||||||
|
|
||||||
|
#[cfg(not(Py_3_7))]
|
||||||
#[cfg_attr(PyPy, link_name = "PyPySlice_GetIndicesEx")]
|
#[cfg_attr(PyPy, link_name = "PyPySlice_GetIndicesEx")]
|
||||||
pub fn PySlice_GetIndicesEx(
|
pub fn PySlice_GetIndicesEx(
|
||||||
r: *mut PyObject,
|
r: *mut PyObject,
|
||||||
|
@ -57,3 +64,39 @@ extern "C" {
|
||||||
slicelength: *mut Py_ssize_t,
|
slicelength: *mut Py_ssize_t,
|
||||||
) -> c_int;
|
) -> c_int;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(Py_3_7)]
|
||||||
|
#[inline]
|
||||||
|
pub unsafe fn PySlice_GetIndicesEx(
|
||||||
|
slice: *mut PyObject,
|
||||||
|
length: Py_ssize_t,
|
||||||
|
start: *mut Py_ssize_t,
|
||||||
|
stop: *mut Py_ssize_t,
|
||||||
|
step: *mut Py_ssize_t,
|
||||||
|
slicelength: *mut Py_ssize_t,
|
||||||
|
) -> c_int {
|
||||||
|
if PySlice_Unpack(slice, start, stop, step) < 0 {
|
||||||
|
*slicelength = 0;
|
||||||
|
-1
|
||||||
|
} else {
|
||||||
|
*slicelength = PySlice_AdjustIndices(length, start, stop, *step);
|
||||||
|
0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#[cfg_attr(PyPy, link_name = "PyPySlice_Unpack")]
|
||||||
|
pub fn PySlice_Unpack(
|
||||||
|
slice: *mut PyObject,
|
||||||
|
start: *mut Py_ssize_t,
|
||||||
|
stop: *mut Py_ssize_t,
|
||||||
|
step: *mut Py_ssize_t,
|
||||||
|
) -> c_int;
|
||||||
|
|
||||||
|
pub fn PySlice_AdjustIndices(
|
||||||
|
length: Py_ssize_t,
|
||||||
|
start: *mut Py_ssize_t,
|
||||||
|
stop: *mut Py_ssize_t,
|
||||||
|
step: Py_ssize_t,
|
||||||
|
) -> Py_ssize_t;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue