use std::io::{BufReader, BufWriter, Read};
use pyo3::prelude::*;
use super::PyLazyFrame;
use crate::exceptions::ComputeError;
use crate::file::get_file_like;
use crate::prelude::*;
use crate::utils::EnterPolarsExt;
#[pymethods]
#[allow(clippy::should_implement_trait)]
impl PyLazyFrame {
fn serialize_binary(&self, py: Python<'_>, py_f: Py<PyAny>) -> PyResult<()> {
let file = get_file_like(py_f, true)?;
let writer = BufWriter::new(file);
py.enter_polars(|| {
self.ldf
.read()
.logical_plan
.serialize_versioned(writer, Default::default())
})
}
#[cfg(feature = "json")]
fn serialize_json(&self, py: Python<'_>, py_f: Py<PyAny>) -> PyResult<()> {
let file = get_file_like(py_f, true)?;
let writer = BufWriter::new(file);
py.enter_polars(|| {
serde_json::to_writer(writer, &self.ldf.read().logical_plan)
.map_err(|err| ComputeError::new_err(err.to_string()))
})
}
#[staticmethod]
fn deserialize_binary(py: Python<'_>, py_f: Py<PyAny>) -> PyResult<Self> {
let file = get_file_like(py_f, false)?;
let reader = BufReader::new(file);
let lp: DslPlan = py.enter_polars(|| DslPlan::deserialize_versioned(reader))?;
Ok(LazyFrame::from(lp).into())
}
#[staticmethod]
#[cfg(feature = "json")]
fn deserialize_json(py: Python<'_>, py_f: Py<PyAny>) -> PyResult<Self> {
let mut json = String::new();
get_file_like(py_f, false)?
.read_to_string(&mut json)
.unwrap();
let json = unsafe { std::mem::transmute::<&'_ str, &'static str>(json.as_str()) };
let lp = py.enter_polars(|| {
serde_json::from_str::<DslPlan>(json)
.map_err(|err| ComputeError::new_err(err.to_string()))
})?;
Ok(LazyFrame::from(lp).into())
}
}