Struct gitql_core::environment::Environment

source ·
pub struct Environment {
    pub schema: Schema,
    pub std_signatures: HashMap<&'static str, Signature>,
    pub std_functions: HashMap<&'static str, Function>,
    pub aggregation_signatures: HashMap<&'static str, Signature>,
    pub aggregation_functions: HashMap<&'static str, Aggregation>,
    pub globals: HashMap<String, Value>,
    pub globals_types: HashMap<String, DataType>,
    pub scopes: HashMap<String, DataType>,
}
Expand description

Environment that track schema, functions, scopes and types to be used in different places in the query engine

Fields§

§schema: Schema

Data schema information contains table, fields names and types

§std_signatures: HashMap<&'static str, Signature>

Standard function signatures

§std_functions: HashMap<&'static str, Function>

Standard function references

§aggregation_signatures: HashMap<&'static str, Signature>

Aggregation function signatures

§aggregation_functions: HashMap<&'static str, Aggregation>

Aggregation function references

§globals: HashMap<String, Value>

All Global Variables values that can life for this program session

§globals_types: HashMap<String, DataType>

All Global Variables Types that can life for this program session

§scopes: HashMap<String, DataType>

Local variables types in the current scope, later will be multi layer scopes

Implementations§

source§

impl Environment

source

pub fn new(schema: Schema) -> Self

Create new Environment instance with Data Schema

source

pub fn with_standard_functions( &mut self, signatures: &HashMap<&'static str, Signature>, functions: &HashMap<&'static str, Function> )

Register standard functions signatures and references

source

pub fn with_aggregation_functions( &mut self, signatures: &HashMap<&'static str, Signature>, aggregation: &HashMap<&'static str, Aggregation> )

Register aggregation functions signatures and references

source

pub fn is_std_function(&self, str: &str) -> bool

Return true if this name is a valid standard function

source

pub fn std_signature(&self, str: &str) -> Option<&Signature>

Return Standard function signature by name

source

pub fn std_function(&self, str: &str) -> Option<&Function>

Return Standard function reference by name

source

pub fn is_aggregation_function(&self, str: &str) -> bool

Return true if this name is a valid aggregation function

source

pub fn aggregation_signature(&self, str: &str) -> Option<&Signature>

Return Aggregation function signature by name

source

pub fn aggregation_function(&self, str: &str) -> Option<&Aggregation>

Return Aggregation function reference by name

source

pub fn define(&mut self, str: String, data_type: DataType)

Define in the current scope

source

pub fn define_global(&mut self, str: String, data_type: DataType)

Define in the global scope

source

pub fn contains(&self, str: &String) -> bool

Returns true if local or global scopes has contains field

source

pub fn resolve_type(&self, str: &String) -> Option<&DataType>

Resolve Global or Local type using symbol name

source

pub fn clear_session(&mut self)

Clear all locals scopes and only save globals

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.