ella_engine/
lib.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
mod catalog;
mod cluster;
pub mod codec;

pub mod config;
pub mod engine;
pub mod lazy;
pub(crate) mod metrics;
mod path;
mod plan;
pub mod registry;
pub mod schema;
pub mod table;
pub(crate) mod util;

pub use config::EllaConfig;
pub use ella_common::{error::EngineError, Error, Result};
pub use engine::EllaContext;
pub use path::Path;
pub use plan::Plan;
pub use schema::ArrowSchema;
pub use table::TableConfig;

pub async fn open(root: &str) -> crate::Result<EllaContext> {
    let state = engine::EllaState::open(root).await?;
    EllaContext::new(state)
}

pub async fn create(
    root: &str,
    config: EllaConfig,
    if_not_exists: bool,
) -> crate::Result<EllaContext> {
    let state = engine::EllaState::create(root, config, if_not_exists).await?;
    EllaContext::new(state)
}