From edf0c96b3c1cb48240b262ca7d5e41e657b8a245 Mon Sep 17 00:00:00 2001 From: Jeremy Leibs Date: Tue, 15 Oct 2024 17:00:36 -0400 Subject: [PATCH] Warn when selection only includes static data --- rerun_py/src/dataframe.rs | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/rerun_py/src/dataframe.rs b/rerun_py/src/dataframe.rs index d6352aff90f6..8832f898a554 100644 --- a/rerun_py/src/dataframe.rs +++ b/rerun_py/src/dataframe.rs @@ -42,6 +42,16 @@ pub(crate) fn register(m: &Bound<'_, PyModule>) -> PyResult<()> { Ok(()) } +fn py_rerun_warn(msg: &str) -> PyResult<()> { + Python::with_gil(|py| { + let warning_type = PyModule::import_bound(py, "rerun")? + .getattr("error_utils")? + .getattr("RerunWarning")?; + PyErr::warn_bound(py, &warning_type, msg, 0)?; + Ok(()) + }) +} + /// Python binding for `IndexColumnDescriptor` #[pyclass(frozen, name = "IndexColumnDescriptor")] #[derive(Clone)] @@ -513,6 +523,15 @@ impl PyRecordingView { let query_handle = engine.query(query_expression); + if query_handle + .view_contents() + .iter() + .filter(|c| matches!(c, ColumnDescriptor::Component(_))) + .all(|c| c.is_static()) + { + py_rerun_warn("RecordingView::select: contents only include static columns. No results will be returned. Either include non-static data or consider using `select_static()` instead.")?; + } + let schema = query_handle.schema(); let fields: Vec = schema.fields.iter().map(|f| f.clone().into()).collect();