mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
Documentation and error handling around polars with-column --name
(#14527)
The `--name` flag of `polars with-column` only works when used with an eager dataframe. I will not work with lazy dataframes and it will not work when used with expressions (which forces a conversion to a lazyframe). This pull request adds better documentation to the flags and errors messages when used in cases where it will not work.
This commit is contained in:
parent
4c9078cccc
commit
81d68cd478
1 changed files with 22 additions and 3 deletions
|
@ -6,8 +6,8 @@ use crate::{
|
||||||
};
|
};
|
||||||
use nu_plugin::{EngineInterface, EvaluatedCall, PluginCommand};
|
use nu_plugin::{EngineInterface, EvaluatedCall, PluginCommand};
|
||||||
use nu_protocol::{
|
use nu_protocol::{
|
||||||
Category, Example, LabeledError, PipelineData, ShellError, Signature, Span, SyntaxShape, Type,
|
Category, Example, LabeledError, PipelineData, ShellError, Signature, Span, Spanned,
|
||||||
Value,
|
SyntaxShape, Type, Value,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
@ -26,7 +26,7 @@ impl PluginCommand for WithColumn {
|
||||||
|
|
||||||
fn signature(&self) -> Signature {
|
fn signature(&self) -> Signature {
|
||||||
Signature::build(self.name())
|
Signature::build(self.name())
|
||||||
.named("name", SyntaxShape::String, "new column name", Some('n'))
|
.named("name", SyntaxShape::String, "New column name. For lazy dataframes and expressions syntax, use a `polars as` expression to name a column.", Some('n'))
|
||||||
.rest(
|
.rest(
|
||||||
"series or expressions",
|
"series or expressions",
|
||||||
SyntaxShape::Any,
|
SyntaxShape::Any,
|
||||||
|
@ -138,6 +138,15 @@ fn command_eager(
|
||||||
let column_span = new_column.span();
|
let column_span = new_column.span();
|
||||||
|
|
||||||
if NuExpression::can_downcast(&new_column) {
|
if NuExpression::can_downcast(&new_column) {
|
||||||
|
if let Some(name) = call.get_flag::<Spanned<String>>("name")? {
|
||||||
|
return Err(ShellError::GenericError {
|
||||||
|
error: "Flag 'name' is unsuppored when used with expressions. Please use the `polars as` expression to name a column".into(),
|
||||||
|
msg: "".into(),
|
||||||
|
span: Some(name.span),
|
||||||
|
help: Some("Use a `polars as` expression to name a column".into()),
|
||||||
|
inner: vec![],
|
||||||
|
});
|
||||||
|
}
|
||||||
let vals: Vec<Value> = call.rest(0)?;
|
let vals: Vec<Value> = call.rest(0)?;
|
||||||
let value = Value::list(vals, call.head);
|
let value = Value::list(vals, call.head);
|
||||||
let expressions = NuExpression::extract_exprs(plugin, value)?;
|
let expressions = NuExpression::extract_exprs(plugin, value)?;
|
||||||
|
@ -177,6 +186,16 @@ fn command_lazy(
|
||||||
call: &EvaluatedCall,
|
call: &EvaluatedCall,
|
||||||
lazy: NuLazyFrame,
|
lazy: NuLazyFrame,
|
||||||
) -> Result<PipelineData, ShellError> {
|
) -> Result<PipelineData, ShellError> {
|
||||||
|
if let Some(name) = call.get_flag::<Spanned<String>>("name")? {
|
||||||
|
return Err(ShellError::GenericError {
|
||||||
|
error: "Flag 'name' is unsuppored for lazy dataframes. Please use the `polars as` expression to name a column".into(),
|
||||||
|
msg: "".into(),
|
||||||
|
span: Some(name.span),
|
||||||
|
help: Some("Use a `polars as` expression to name a column".into()),
|
||||||
|
inner: vec![],
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
let vals: Vec<Value> = call.rest(0)?;
|
let vals: Vec<Value> = call.rest(0)?;
|
||||||
let value = Value::list(vals, call.head);
|
let value = Value::list(vals, call.head);
|
||||||
let expressions = NuExpression::extract_exprs(plugin, value)?;
|
let expressions = NuExpression::extract_exprs(plugin, value)?;
|
||||||
|
|
Loading…
Reference in a new issue