Skip to content

Commit

Permalink
Add alternative syntax function.
Browse files Browse the repository at this point in the history
  • Loading branch information
jonathanc-n committed Oct 27, 2024
1 parent 5db2740 commit 670ab6f
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 0 deletions.
7 changes: 7 additions & 0 deletions datafusion/core/src/bin/print_functions_docs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,13 @@ fn print_docs(
);
}

if let Some(alt_syntax) = &documentation.alternative_syntax {
let _ = writeln!(docs, "#### Alternative Syntax\n");
for syntax in alt_syntax {
let _ = writeln!(docs, "```sql\n{}\n```", syntax);
}
}

// next, aliases
if !f.get_aliases().is_empty() {
let _ = writeln!(docs, "#### Aliases");
Expand Down
16 changes: 16 additions & 0 deletions datafusion/expr/src/udf_docs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ pub struct Documentation {
/// Left member of a pair is the argument name, right is a
/// description for the argument
pub arguments: Option<Vec<(String, String)>>,
/// A list of alternative syntax examples for a function
pub alternative_syntax: Option<Vec<String>>,
/// Related functions if any. Values should match the related
/// udf's name exactly. Related udf's must be of the same
/// UDF type (scalar, aggregate or window) for proper linking to
Expand Down Expand Up @@ -96,6 +98,7 @@ pub struct DocumentationBuilder {
pub syntax_example: Option<String>,
pub sql_example: Option<String>,
pub arguments: Option<Vec<(String, String)>>,
pub alternative_syntax: Option<Vec<String>>,
pub related_udfs: Option<Vec<String>>,
}

Expand All @@ -107,6 +110,7 @@ impl DocumentationBuilder {
syntax_example: None,
sql_example: None,
arguments: None,
alternative_syntax: None,
related_udfs: None,
}
}
Expand Down Expand Up @@ -172,6 +176,16 @@ impl DocumentationBuilder {
self.with_argument(arg_name, description)
}

pub fn with_alternative_syntax(
mut self,
syntax_name: impl Into<String>,
) -> Self {
let mut alternative_syntax_array = self.alternative_syntax.unwrap_or_default();
alternative_syntax_array.push(syntax_name.into());
self.alternative_syntax = Some(alternative_syntax_array);
self
}

pub fn with_related_udf(mut self, related_udf: impl Into<String>) -> Self {
let mut related = self.related_udfs.unwrap_or_default();
related.push(related_udf.into());
Expand All @@ -186,6 +200,7 @@ impl DocumentationBuilder {
syntax_example,
sql_example,
arguments,
alternative_syntax,
related_udfs,
} = self;

Expand All @@ -205,6 +220,7 @@ impl DocumentationBuilder {
syntax_example: syntax_example.unwrap(),
sql_example,
arguments,
alternative_syntax,
related_udfs,
})
}
Expand Down
1 change: 1 addition & 0 deletions datafusion/functions/src/unicode/strpos.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ fn get_strpos_doc() -> &'static Documentation {
```"#)
.with_standard_argument("str", Some("String"))
.with_argument("substr", "Substring expression to search for.")
.with_alternative_syntax("position(substr in origstr)")
.build()
.unwrap()
})
Expand Down
6 changes: 6 additions & 0 deletions docs/source/user-guide/sql/scalar_functions_new.md
Original file line number Diff line number Diff line change
Expand Up @@ -1465,6 +1465,12 @@ strpos(str, substr)
+----------------------------------------+
```

#### Alternative Syntax

```sql
position(substr in origstr)
```

#### Aliases

- instr
Expand Down

0 comments on commit 670ab6f

Please sign in to comment.