use arrow_schema::{DataType, Field as ArrowField};
use std::sync::LazyLock;
pub mod cache;
pub mod container;
pub mod datatypes;
pub mod error;
pub mod traits;
pub mod utils;
pub use error::{ArrowResult, Error, Result};
pub const ROW_ID: &str = "_rowid";
pub const ROW_ADDR: &str = "_rowaddr";
pub const ROW_OFFSET: &str = "_rowoffset";
pub static ROW_ID_FIELD: LazyLock<ArrowField> =
LazyLock::new(|| ArrowField::new(ROW_ID, DataType::UInt64, true));
pub static ROW_ADDR_FIELD: LazyLock<ArrowField> =
LazyLock::new(|| ArrowField::new(ROW_ADDR, DataType::UInt64, true));
pub static ROW_OFFSET_FIELD: LazyLock<ArrowField> =
LazyLock::new(|| ArrowField::new(ROW_OFFSET, DataType::UInt64, true));