geoarrow-array 0.8.0

GeoArrow array definitions.
Documentation
use arrow_array::OffsetSizeTrait;
use geozero::error::GeozeroError;
use geozero::{GeomProcessor, GeozeroGeometry};

use crate::array::{GenericWktArray, WktViewArray};
use crate::geozero::export::scalar::process_geometry;
use crate::{GeoArrowArray, GeoArrowArrayAccessor};

impl<O: OffsetSizeTrait> GeozeroGeometry for GenericWktArray<O> {
    fn process_geom<P: GeomProcessor>(&self, processor: &mut P) -> geozero::error::Result<()>
    where
        Self: Sized,
    {
        let num_geometries = self.len();
        processor.geometrycollection_begin(num_geometries, 0)?;

        for geom_idx in 0..num_geometries {
            let geom = &self
                .value(geom_idx)
                .map_err(|err| GeozeroError::Geometry(err.to_string()))?;
            process_geometry(geom, geom_idx, processor)?;
        }

        processor.geometrycollection_end(num_geometries - 1)?;
        Ok(())
    }
}

impl GeozeroGeometry for WktViewArray {
    fn process_geom<P: GeomProcessor>(&self, processor: &mut P) -> geozero::error::Result<()>
    where
        Self: Sized,
    {
        let num_geometries = self.len();
        processor.geometrycollection_begin(num_geometries, 0)?;

        for geom_idx in 0..num_geometries {
            let geom = &self
                .value(geom_idx)
                .map_err(|err| GeozeroError::Geometry(err.to_string()))?;
            process_geometry(geom, geom_idx, processor)?;
        }

        processor.geometrycollection_end(num_geometries - 1)?;
        Ok(())
    }
}