Add support for timers and run/quit_event_loop

This commit is contained in:
Simon Hausmann 2023-12-14 17:31:09 +01:00 committed by Simon Hausmann
parent ebaecbcb7e
commit 33a1d07226
5 changed files with 148 additions and 1 deletions

View file

@ -4,16 +4,37 @@
mod interpreter;
use interpreter::{ComponentCompiler, PyDiagnostic, PyDiagnosticLevel, PyValueType};
mod errors;
mod timer;
mod value;
#[pyfunction]
fn run_event_loop() -> Result<(), errors::PyPlatformError> {
slint_interpreter::run_event_loop().map_err(|e| e.into())
}
#[pyfunction]
fn quit_event_loop() -> Result<(), errors::PyEventLoopError> {
slint_interpreter::quit_event_loop().map_err(|e| e.into())
}
use pyo3::prelude::*;
#[pymodule]
fn slint(_py: Python<'_>, m: &PyModule) -> PyResult<()> {
i_slint_backend_selector::with_platform(|_b| {
// Nothing to do, just make sure a backend was created
Ok(())
})
.map_err(|e| errors::PyPlatformError(e))?;
m.add_class::<ComponentCompiler>()?;
m.add_class::<PyValueType>()?;
m.add_class::<PyDiagnosticLevel>()?;
m.add_class::<PyDiagnostic>()?;
m.add_class::<timer::PyTimerMode>()?;
m.add_class::<timer::PyTimer>()?;
m.add_function(wrap_pyfunction!(run_event_loop, m)?)?;
m.add_function(wrap_pyfunction!(quit_event_loop, m)?)?;
Ok(())
}