diff --git a/crates/nu-command/src/formats/to/md.rs b/crates/nu-command/src/formats/to/md.rs index 25b3237290..e80f3aae39 100644 --- a/crates/nu-command/src/formats/to/md.rs +++ b/crates/nu-command/src/formats/to/md.rs @@ -151,7 +151,21 @@ fn collect_headers(headers: &[String]) -> (Vec, Vec) { fn table(input: PipelineData, pretty: bool, config: &Config) -> String { let vec_of_values = input.into_iter().collect::>(); - let headers = merge_descriptors(&vec_of_values); + let mut headers = merge_descriptors(&vec_of_values); + + let mut empty_header_index = 0; + for value in &vec_of_values { + if let Value::Record { val, .. } = value { + for column in val.columns() { + if column.is_empty() && !headers.contains(&String::new()) { + headers.insert(empty_header_index, String::new()); + empty_header_index += 1; + break; + } + empty_header_index += 1; + } + } + } let (escaped_headers, mut column_widths) = collect_headers(&headers); @@ -416,4 +430,32 @@ mod tests { "#) ); } + + #[test] + fn test_empty_column_header() { + let value = Value::test_list(vec![ + Value::test_record(record! { + "" => Value::test_string("1"), + "foo" => Value::test_string("2"), + }), + Value::test_record(record! { + "" => Value::test_string("3"), + "foo" => Value::test_string("4"), + }), + ]); + + assert_eq!( + table( + value.clone().into_pipeline_data(), + false, + &Config::default() + ), + one(r#" + ||foo| + |-|-| + |1|2| + |3|4| + "#) + ); + } }