Skip to content

Commit

Permalink
Add intern! macro which can be used to amortize the cost of creating …
Browse files Browse the repository at this point in the history
…Python objects by storing them inside a GILOnceCell.
  • Loading branch information
adamreichold committed Apr 3, 2022
1 parent 040ce86 commit ba45a44
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 0 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Allow dependent crates to access config values from `pyo3-build-config` via cargo link dep env vars. [#2092](https://github.com/PyO3/pyo3/pull/2092)
- Added methods on `InterpreterConfig` to run Python scripts using the configured executable. [#2092](https://github.com/PyO3/pyo3/pull/2092)
- Added FFI definitions for `PyType_FromModuleAndSpec`, `PyType_GetModule`, `PyType_GetModuleState` and `PyModule_AddType`. [#2250](https://github.com/PyO3/pyo3/pull/2250)
- Add `intern!` macro which can be used to amortize the cost of creating Python objects by storing them inside a `GILOnceCell`. [#2269](https://github.com/PyO3/pyo3/pull/2269)

### Changed

Expand Down
1 change: 1 addition & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,7 @@ pub mod impl_;
mod instance;
pub mod marker;
pub mod marshal;
#[macro_use]
pub mod once_cell;
pub mod panic;
pub mod prelude;
Expand Down
27 changes: 27 additions & 0 deletions src/once_cell.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,3 +101,30 @@ impl<T> GILOnceCell<T> {
Ok(())
}
}

/// Will convert the given value into a Python object and intern that within a [`GILOnceCell`]
///
/// # Example
///
/// ```
/// use pyo3::intern;
/// # use pyo3::{types::PyDict, Python};
///
/// # Python::with_gil(|py| {
/// let dict = PyDict::new(py);
/// dict.set_item(intern!(py, "foo"), 42).unwrap();
/// # });
/// ```
#[macro_export]
macro_rules! intern {
($py: expr, $value: expr) => {{
static INTERNED: $crate::once_cell::GILOnceCell<$crate::PyObject> =
$crate::once_cell::GILOnceCell::new();

INTERNED
.get_or_init($py, || {
$crate::conversion::ToPyObject::to_object($value, $py)
})
.as_ref($py)
}};
}

0 comments on commit ba45a44

Please sign in to comment.