pub trait TypeVisitor<R, C> {
    // Required methods
    fn visit_primitive(
        &mut self,
        primitive_type: TypePtr,
        context: C,
    ) -> Result<R>;
    fn visit_struct(&mut self, struct_type: TypePtr, context: C) -> Result<R>;
    fn visit_map(&mut self, map_type: TypePtr, context: C) -> Result<R>;
    fn visit_list_with_item(
        &mut self,
        list_type: TypePtr,
        item_type: TypePtr,
        context: C,
    ) -> Result<R>;
    // Provided methods
    fn visit_list(&mut self, list_type: TypePtr, context: C) -> Result<R> { ... }
    fn dispatch(&mut self, cur_type: TypePtr, context: C) -> Result<R> { ... }
}Expand description
A utility trait to help user to traverse against parquet type.
Required Methods§
Sourcefn visit_primitive(&mut self, primitive_type: TypePtr, context: C) -> Result<R>
 
fn visit_primitive(&mut self, primitive_type: TypePtr, context: C) -> Result<R>
Called when a primitive type hit.
Sourcefn visit_struct(&mut self, struct_type: TypePtr, context: C) -> Result<R>
 
fn visit_struct(&mut self, struct_type: TypePtr, context: C) -> Result<R>
Called when a struct type hit.
Sourcefn visit_map(&mut self, map_type: TypePtr, context: C) -> Result<R>
 
fn visit_map(&mut self, map_type: TypePtr, context: C) -> Result<R>
Called when a map type hit.
Sourcefn visit_list_with_item(
    &mut self,
    list_type: TypePtr,
    item_type: TypePtr,
    context: C,
) -> Result<R>
 
fn visit_list_with_item( &mut self, list_type: TypePtr, item_type: TypePtr, context: C, ) -> Result<R>
Called by visit_list.
Provided Methods§
Sourcefn visit_list(&mut self, list_type: TypePtr, context: C) -> Result<R>
 
fn visit_list(&mut self, list_type: TypePtr, context: C) -> Result<R>
Default implementation when visiting a list.
It checks list type definition and calls Self::visit_list_with_item with extracted
item type.
To fully understand this algorithm, please refer to parquet doc.
For example, a standard list type looks like:
required/optional group my_list (LIST) {In such a case, Self::visit_list_with_item will be called with my_list as the list
type, and element as the item_type