Skip to content

Commit

Permalink
Merge pull request #820 from ijl/more-ffi
Browse files Browse the repository at this point in the history
More bytes, dict FFI
  • Loading branch information
kngwyu committed Mar 19, 2020
2 parents 5a822bc + e58249c commit 25b594c
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 2 deletions.
2 changes: 2 additions & 0 deletions src/ffi/bytesobject.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,4 +53,6 @@ extern "C" {
s: *mut *mut c_char,
len: *mut Py_ssize_t,
) -> c_int;
#[cfg(not(PyPy))]
pub fn _PyBytes_Resize(bytes: *mut *mut PyObject, newsize: Py_ssize_t) -> c_int;
}
16 changes: 14 additions & 2 deletions src/ffi/dictobject.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::ffi::object::*;
use crate::ffi::pyport::Py_ssize_t;
use crate::ffi::pyport::{Py_hash_t, Py_ssize_t};
use std::os::raw::{c_char, c_int};

#[cfg_attr(windows, link(name = "pythonXY"))]
Expand Down Expand Up @@ -79,7 +79,7 @@ extern "C" {
mp: *mut PyObject,
key: *mut PyObject,
item: *mut PyObject,
hash: crate::ffi::pyport::Py_hash_t,
hash: Py_hash_t,
) -> c_int;
#[cfg_attr(PyPy, link_name = "PyPyDict_DelItem")]
pub fn PyDict_DelItem(mp: *mut PyObject, key: *mut PyObject) -> c_int;
Expand All @@ -92,6 +92,14 @@ extern "C" {
key: *mut *mut PyObject,
value: *mut *mut PyObject,
) -> c_int;
#[cfg(not(PyPy))]
pub fn _PyDict_Next(
mp: *mut PyObject,
pos: *mut Py_ssize_t,
key: *mut *mut PyObject,
value: *mut *mut PyObject,
hash: *mut Py_hash_t,
) -> c_int;
#[cfg_attr(PyPy, link_name = "PyPyDict_Keys")]
pub fn PyDict_Keys(mp: *mut PyObject) -> *mut PyObject;
#[cfg_attr(PyPy, link_name = "PyPyDict_Values")]
Expand All @@ -104,6 +112,8 @@ extern "C" {
pub fn PyDict_Copy(mp: *mut PyObject) -> *mut PyObject;
#[cfg_attr(PyPy, link_name = "PyPyDict_Contains")]
pub fn PyDict_Contains(mp: *mut PyObject, key: *mut PyObject) -> c_int;
#[cfg(not(PyPy))]
pub fn _PyDict_Contains(mp: *mut PyObject, key: *mut PyObject, hash: Py_ssize_t) -> c_int;
#[cfg_attr(PyPy, link_name = "PyPyDict_Update")]
pub fn PyDict_Update(mp: *mut PyObject, other: *mut PyObject) -> c_int;
#[cfg_attr(PyPy, link_name = "PyPyDict_Merge")]
Expand All @@ -119,4 +129,6 @@ extern "C" {
) -> c_int;
#[cfg_attr(PyPy, link_name = "PyPyDict_DelItemString")]
pub fn PyDict_DelItemString(dp: *mut PyObject, key: *const c_char) -> c_int;
#[cfg(not(PyPy))]
pub fn _PyObject_GetDictPtr(obj: *mut PyObject) -> *mut *mut PyObject;
}

0 comments on commit 25b594c

Please sign in to comment.