From af8013425fe461a7ff2bac9ec96aef4c08ad5425 Mon Sep 17 00:00:00 2001 From: Nathan Goldbaum Date: Tue, 3 Sep 2024 10:15:47 -0600 Subject: [PATCH] simplify migration guide example --- guide/src/migration.md | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/guide/src/migration.md b/guide/src/migration.md index b9de0da78a3..4697e2d1d65 100644 --- a/guide/src/migration.md +++ b/guide/src/migration.md @@ -248,32 +248,28 @@ After: ```rust # use pyo3::prelude::*; # fn main() { -#[cfg(not(Py_GIL_DISABLED))] -use pyo3::sync::GILProtected; use pyo3::types::{PyDict, PyNone}; -#[cfg(not(Py_GIL_DISABLED))] -use std::cell::RefCell; -#[cfg(Py_GIL_DISABLED)] use std::sync::Mutex; -#[cfg(not(Py_GIL_DISABLED))] -static OBJECTS: GILProtected>>> = - GILProtected::new(RefCell::new(Vec::new())); -#[cfg(Py_GIL_DISABLED)] static OBJECTS: Mutex>> = Mutex::new(Vec::new()); Python::with_gil(|py| { // stand-in for something that executes arbitrary python code let d = PyDict::new(py); d.set_item(PyNone::get(py), PyNone::get(py)).unwrap(); - #[cfg(not(Py_GIL_DISABLED))] - OBJECTS.get(py).borrow_mut().push(d.unbind()); - #[cfg(Py_GIL_DISABLED)] + // we're not executing python code while holding the lock, so GILProtected + // was never needed OBJECTS.lock().unwrap().push(d.unbind()); }); # } ``` +If you are executing arbitrary Python code while holding the lock, then you will +need to use conditional compilation to use `GILProtected` on GIL-enabled python +builds and mutexes otherwise. Python 3.13 introduces `PyMutex`, which releases +the GIL while the lock is held, so that is another option if you only need to +support newer Python versions. + ## from 0.21.* to 0.22