Skip to content

Commit

Permalink
docs: update example for storing Py<T> in structs
Browse files Browse the repository at this point in the history
  • Loading branch information
davidhewitt committed Feb 19, 2024
1 parent 0bb9cab commit 769846e
Showing 1 changed file with 10 additions and 5 deletions.
15 changes: 10 additions & 5 deletions src/instance.rs
Original file line number Diff line number Diff line change
Expand Up @@ -656,9 +656,14 @@ impl<T> IntoPy<PyObject> for Borrowed<'_, '_, T> {
/// These require passing in the [`Python<'py>`](crate::Python) token but are otherwise similar to the corresponding
/// methods on [`PyAny`].
///
/// # Example: Storing Python objects in structs
/// # Example: Storing Python objects in `#[pyclass]` structs
///
/// Usually `Bound<'py, T>` is recommended for interacting with Python objects as its lifetime `'py`
/// is an association to the GIL and that enables many operations to be done as efficiently as possible.
///
/// However, `#[pyclass]` structs cannot carry a lifetime, so `Py<T>` is the only way to store
/// a Python object in a `#[pyclass]` struct.
///
/// As all the native Python objects only appear as references, storing them in structs doesn't work well.
/// For example, this won't compile:
///
/// ```compile_fail
Expand All @@ -667,17 +672,17 @@ impl<T> IntoPy<PyObject> for Borrowed<'_, '_, T> {
/// #
/// #[pyclass]
/// struct Foo<'py> {
/// inner: &'py PyDict,
/// inner: Bound<'py, PyDict>,
/// }
///
/// impl Foo {
/// fn new() -> Foo {
/// let foo = Python::with_gil(|py| {
/// // `py` will only last for this scope.
///
/// // `&PyDict` derives its lifetime from `py` and
/// // `Bound<'py, PyDict>` inherits the GIL lifetime from `py` and
/// // so won't be able to outlive this closure.
/// let dict: &PyDict = PyDict::new(py);
/// let dict: Bound<'_, PyDict> = PyDict::new_bound(py);
///
/// // because `Foo` contains `dict` its lifetime
/// // is now also tied to `py`.
Expand Down

0 comments on commit 769846e

Please sign in to comment.