#![doc(
html_logo_url = "https://raw.githubusercontent.com/apache/datafusion/19fe44cf2f30cbdd63d4a4f52c74055163c6cc38/docs/logos/standalone_logo/logo_original.svg",
html_favicon_url = "https://raw.githubusercontent.com/apache/datafusion/19fe44cf2f30cbdd63d4a4f52c74055163c6cc38/docs/logos/standalone_logo/logo_original.svg"
)]
#![cfg_attr(docsrs, feature(doc_auto_cfg))]
#![cfg_attr(not(test), deny(clippy::clone_on_ref_ptr))]
pub mod generate_series;
use datafusion_catalog::TableFunction;
use std::sync::Arc;
pub fn all_default_table_functions() -> Vec<Arc<TableFunction>> {
vec![generate_series(), range()]
}
#[macro_export]
macro_rules! create_udtf_function {
($module:path, $name:expr) => {
paste::paste! {
pub fn [<$name:lower>]() -> Arc<TableFunction> {
static INSTANCE: std::sync::LazyLock<Arc<TableFunction>> =
std::sync::LazyLock::new(|| {
std::sync::Arc::new(TableFunction::new(
$name.to_string(),
Arc::new($module {}),
))
});
std::sync::Arc::clone(&INSTANCE)
}
}
};
}
create_udtf_function!(generate_series::GenerateSeriesFunc, "generate_series");
create_udtf_function!(generate_series::RangeFunc, "range");