datafusion_comet_spark_expr/
lib.rs1#![deny(clippy::clone_on_ref_ptr)]
21
22mod error;
23
24mod kernels;
25mod static_invoke;
26pub use static_invoke::*;
27
28mod struct_funcs;
29pub use struct_funcs::{CreateNamedStruct, GetStructField};
30
31mod json_funcs;
32pub mod test_common;
33pub mod timezone;
34mod unbound;
35pub use unbound::UnboundColumn;
36mod predicate_funcs;
37pub mod utils;
38pub use predicate_funcs::{spark_isnan, RLike};
39
40mod agg_funcs;
41mod array_funcs;
42mod bitwise_funcs;
43mod comet_scalar_funcs;
44pub mod hash_funcs;
45
46mod string_funcs;
47
48mod datetime_funcs;
49pub use agg_funcs::*;
50
51pub use cast::{spark_cast, Cast, SparkCastOptions};
52
53mod bloom_filter;
54pub use bloom_filter::{BloomFilterAgg, BloomFilterMightContain};
55
56mod conditional_funcs;
57mod conversion_funcs;
58mod map_funcs;
59mod math_funcs;
60mod nondetermenistic_funcs;
61
62pub use array_funcs::*;
63pub use bitwise_funcs::*;
64pub use conditional_funcs::*;
65pub use conversion_funcs::*;
66pub use nondetermenistic_funcs::*;
67
68pub use comet_scalar_funcs::{create_comet_physical_fun, register_all_comet_functions};
69pub use datetime_funcs::{
70 spark_date_add, spark_date_sub, SparkDateTrunc, SparkHour, SparkMinute, SparkSecond,
71 TimestampTruncExpr,
72};
73pub use error::{SparkError, SparkResult};
74pub use hash_funcs::*;
75pub use json_funcs::ToJson;
76pub use math_funcs::{
77 create_modulo_expr, create_negate_expr, spark_ceil, spark_decimal_div,
78 spark_decimal_integral_div, spark_floor, spark_hex, spark_make_decimal, spark_round,
79 spark_unhex, spark_unscaled_value, CheckOverflow, NegativeExpr, NormalizeNaNAndZero,
80};
81pub use string_funcs::*;
82
83#[derive(Debug, Hash, PartialEq, Eq, Clone, Copy)]
88pub enum EvalMode {
89 Legacy,
94 Ansi,
97 Try,
100}
101
102pub(crate) fn arithmetic_overflow_error(from_type: &str) -> SparkError {
103 SparkError::ArithmeticOverflow {
104 from_type: from_type.to_string(),
105 }
106}
107
108pub(crate) fn divide_by_zero_error() -> SparkError {
109 SparkError::DivideByZero
110}