use super::{DataType, Metadata};
#[cfg(feature = "serde_types")]
use serde_derive::{Deserialize, Serialize};
#[derive(Debug, Clone, Eq, PartialEq, Hash)]
#[cfg_attr(feature = "serde_types", derive(Serialize, Deserialize))]
pub struct Field {
pub name: String,
pub data_type: DataType,
pub is_nullable: bool,
pub metadata: Metadata,
}
impl Field {
pub fn new<T: Into<String>>(name: T, data_type: DataType, is_nullable: bool) -> Self {
Field {
name: name.into(),
data_type,
is_nullable,
metadata: Default::default(),
}
}
#[inline]
pub fn with_metadata(self, metadata: Metadata) -> Self {
Self {
name: self.name,
data_type: self.data_type,
is_nullable: self.is_nullable,
metadata,
}
}
#[inline]
pub fn data_type(&self) -> &DataType {
&self.data_type
}
}
#[cfg(feature = "arrow")]
impl From<Field> for arrow_schema::Field {
fn from(value: Field) -> Self {
Self::new(value.name, value.data_type.into(), value.is_nullable)
.with_metadata(value.metadata.into_iter().collect())
}
}
#[cfg(feature = "arrow")]
impl From<arrow_schema::Field> for Field {
fn from(value: arrow_schema::Field) -> Self {
(&value).into()
}
}
#[cfg(feature = "arrow")]
impl From<&arrow_schema::Field> for Field {
fn from(value: &arrow_schema::Field) -> Self {
let data_type = value.data_type().clone().into();
let metadata = value
.metadata()
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
.collect();
Self::new(value.name(), data_type, value.is_nullable()).with_metadata(metadata)
}
}
#[cfg(feature = "arrow")]
impl From<arrow_schema::FieldRef> for Field {
fn from(value: arrow_schema::FieldRef) -> Self {
value.as_ref().into()
}
}
#[cfg(feature = "arrow")]
impl From<&arrow_schema::FieldRef> for Field {
fn from(value: &arrow_schema::FieldRef) -> Self {
value.as_ref().into()
}
}