Flatten should flatten embedded table (#534)

This commit is contained in:
JT 2021-12-21 06:03:18 +11:00 committed by GitHub
parent caf73c36f2
commit 152467a858
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 52 additions and 14 deletions

View file

@ -84,12 +84,12 @@ enum TableInside<'a> {
Entries(&'a str, &'a Span, Vec<&'a Value>), Entries(&'a str, &'a Span, Vec<&'a Value>),
} }
fn is_table(value: &Value) -> bool { // fn is_table(value: &Value) -> bool {
match value { // match value {
Value::List { vals, span: _ } => vals.iter().all(|f| f.as_record().is_ok()), // Value::List { vals, span: _ } => vals.iter().all(|f| f.as_record().is_ok()),
_ => false, // _ => false,
} // }
} // }
fn flat_value(columns: &[CellPath], item: &Value, _name_tag: Span) -> Vec<Value> { fn flat_value(columns: &[CellPath], item: &Value, _name_tag: Span) -> Vec<Value> {
let tag = match item.span() { let tag = match item.span() {
@ -233,7 +233,7 @@ fn flat_value(columns: &[CellPath], item: &Value, _name_tag: Span) -> Vec<Value>
expanded.push(r); expanded.push(r);
} }
expanded expanded
} else if !is_table(item) { } else if item.as_list().is_ok() {
if let Value::List { vals, span: _ } = item { if let Value::List { vals, span: _ } = item {
vals.to_vec() vals.to_vec()
} else { } else {

View file

@ -195,6 +195,17 @@ impl Value {
} }
} }
pub fn as_list(&self) -> Result<&[Value], ShellError> {
match self {
Value::List { vals, .. } => Ok(vals),
x => Err(ShellError::CantConvert(
"list".into(),
x.get_type().to_string(),
self.span()?,
)),
}
}
pub fn as_bool(&self) -> Result<bool, ShellError> { pub fn as_bool(&self) -> Result<bool, ShellError> {
match self { match self {
Value::Bool { val, .. } => Ok(*val), Value::Bool { val, .. } => Ok(*val),

View file

@ -15,7 +15,10 @@ use nu_protocol::{
engine::{EngineState, Stack, StateWorkingSet}, engine::{EngineState, Stack, StateWorkingSet},
Config, PipelineData, ShellError, Span, Value, CONFIG_VARIABLE_ID, Config, PipelineData, ShellError, Span, Value, CONFIG_VARIABLE_ID,
}; };
use reedline::{Completer, CompletionActionHandler, DefaultPrompt, LineBuffer, Prompt}; use reedline::{
Completer, CompletionActionHandler, DefaultCompleter, DefaultHinter, DefaultPrompt, LineBuffer,
Prompt,
};
use std::{ use std::{
io::Write, io::Write,
sync::{ sync::{
@ -353,12 +356,28 @@ fn main() -> Result<()> {
// turn off the hinter but I don't see any way to do that yet. // turn off the hinter but I don't see any way to do that yet.
let mut line_editor = if let Some(history_path) = history_path.clone() { let mut line_editor = if let Some(history_path) = history_path.clone() {
line_editor let history = std::fs::read_to_string(&history_path);
.with_history(Box::new( if let Ok(history) = history {
FileBackedHistory::with_file(1000, history_path.clone()) let history_lines = history.lines().map(|x| x.to_string()).collect::<Vec<_>>();
.into_diagnostic()?, line_editor
)) .with_hinter(Box::new(
.into_diagnostic()? DefaultHinter::default()
.with_completer(Box::new(DefaultCompleter::new(history_lines))) // or .with_history()
// .with_inside_line()
.with_style(
nu_ansi_term::Style::new()
.italic()
.fg(nu_ansi_term::Color::LightGray),
),
))
.with_history(Box::new(
FileBackedHistory::with_file(1000, history_path.clone())
.into_diagnostic()?,
))
.into_diagnostic()?
} else {
line_editor
}
} else { } else {
line_editor line_editor
}; };

View file

@ -1308,3 +1308,11 @@ fn allow_missing_optional_params() -> TestResult {
"5", "5",
) )
} }
#[test]
fn flatten_should_flatten_inner_table() -> TestResult {
run_test(
"[[[name, value]; [abc, 123]]] | flatten | get value.0",
"123",
)
}