Skip to content

Commit

Permalink
support more args for udaf
Browse files Browse the repository at this point in the history
Signed-off-by: jayzhan211 <[email protected]>
  • Loading branch information
jayzhan211 committed Apr 20, 2024
1 parent 19356b2 commit 9f160e4
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 11 deletions.
1 change: 1 addition & 0 deletions datafusion/functions-aggregate/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -45,3 +45,4 @@ datafusion-expr = { workspace = true }
datafusion-physical-expr-common = { workspace = true }
log = { workspace = true }
paste = "1.0.14"
sqlparser = { workspace = true }
2 changes: 1 addition & 1 deletion datafusion/functions-aggregate/src/first_last.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,11 +39,11 @@ use datafusion_physical_expr_common::utils::reverse_order_bys;
use std::any::Any;
use std::fmt::Debug;
use std::sync::Arc;
use sqlparser::ast::NullTreatment;

make_udaf_function!(
FirstValue,
first_value,
value,
"Returns the first value in a group of values.",
first_value_udaf
);
Expand Down
23 changes: 14 additions & 9 deletions datafusion/functions-aggregate/src/macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,24 @@
// under the License.

macro_rules! make_udaf_function {
($UDAF:ty, $EXPR_FN:ident, $($arg:ident)*, $DOC:expr, $AGGREGATE_UDF_FN:ident) => {
($UDAF:ty, $EXPR_FN:ident, $DOC:expr, $AGGREGATE_UDF_FN:ident) => {
paste::paste! {
// "fluent expr_fn" style function
#[doc = $DOC]
pub fn $EXPR_FN($($arg: Expr),*) -> Expr {
pub fn $EXPR_FN(
args: Vec<Expr>,
distinct: bool,
filter: Option<Box<Expr>>,
order_by: Option<Vec<Expr>>,
null_treatment: Option<NullTreatment>
) -> Expr {
Expr::AggregateFunction(datafusion_expr::expr::AggregateFunction::new_udf(
$AGGREGATE_UDF_FN(),
vec![$($arg),*],
// TODO: Support arguments for `expr` API
false,
None,
None,
None,
args,
distinct,
filter,
order_by,
null_treatment,
))
}

Expand All @@ -50,4 +55,4 @@ macro_rules! make_udaf_function {
}
}
}
}
}
2 changes: 1 addition & 1 deletion datafusion/proto/tests/cases/roundtrip_logical_plan.rs
Original file line number Diff line number Diff line change
Expand Up @@ -613,7 +613,7 @@ async fn roundtrip_expr_api() -> Result<()> {
lit(1),
),
array_replace_all(make_array(vec![lit(1), lit(2), lit(3)]), lit(2), lit(4)),
first_value(lit(1)),
first_value(vec![lit(1)], false, None, None, None),
];

// ensure expressions created with the expr api can be round tripped
Expand Down

0 comments on commit 9f160e4

Please sign in to comment.