From 01dd358a18c5882690c53b40eba47b8e354c0b56 Mon Sep 17 00:00:00 2001 From: Jason Gedge Date: Sun, 8 Mar 2020 15:18:24 -0400 Subject: [PATCH] Don't emit a newline in autoview. (#1466) The extra newline character makes it hard to use nu as part of an external processing pipeline, since the extra character could taint the results. For example: ``` $ nu -c 'echo test | xxd' 00000000: 7465 7374 test ``` versus ``` nu -c 'echo test' | xxd 00000000: 7465 7374 0a test. ``` --- crates/nu-cli/src/commands/autoview.rs | 20 ++++++++++---------- crates/nu-cli/src/prelude.rs | 2 +- crates/nu-protocol/src/macros.rs | 9 +++++++++ 3 files changed, 20 insertions(+), 11 deletions(-) diff --git a/crates/nu-cli/src/commands/autoview.rs b/crates/nu-cli/src/commands/autoview.rs index ec8759a283..d9f72a0b97 100644 --- a/crates/nu-cli/src/commands/autoview.rs +++ b/crates/nu-cli/src/commands/autoview.rs @@ -112,14 +112,14 @@ pub fn autoview(context: RunnableContext) -> Result { let result = text.run(command_args, &context.commands); result.collect::>().await; } else { - outln!("{}", s); + out!("{}", s); } } Value { value: UntaggedValue::Primitive(Primitive::String(s)), .. } => { - outln!("{}", s); + out!("{}", s); } Value { value: UntaggedValue::Primitive(Primitive::Line(ref s)), @@ -132,32 +132,32 @@ pub fn autoview(context: RunnableContext) -> Result { let result = text.run(command_args, &context.commands); result.collect::>().await; } else { - outln!("{}\n", s); + out!("{}\n", s); } } Value { value: UntaggedValue::Primitive(Primitive::Line(s)), .. } => { - outln!("{}\n", s); + out!("{}\n", s); } Value { value: UntaggedValue::Primitive(Primitive::Path(s)), .. } => { - outln!("{}", s.display()); + out!("{}", s.display()); } Value { value: UntaggedValue::Primitive(Primitive::Int(n)), .. } => { - outln!("{}", n); + out!("{}", n); } Value { value: UntaggedValue::Primitive(Primitive::Decimal(n)), .. } => { - outln!("{}", n); + out!("{}", n); } Value { value: UntaggedValue::Primitive(Primitive::Binary(ref b)), .. } => { @@ -169,7 +169,7 @@ pub fn autoview(context: RunnableContext) -> Result { result.collect::>().await; } else { use pretty_hex::*; - outln!("{:?}", b.hex_dump()); + out!("{:?}", b.hex_dump()); } } @@ -184,7 +184,7 @@ pub fn autoview(context: RunnableContext) -> Result { let result = table.run(command_args, &context.commands); result.collect::>().await; } else { - outln!("{:?}", item); + out!("{:?}", item); } } } @@ -192,7 +192,7 @@ pub fn autoview(context: RunnableContext) -> Result { } } _ => { - //outln!(""); + //out!(""); } } diff --git a/crates/nu-cli/src/prelude.rs b/crates/nu-cli/src/prelude.rs index 953da31892..93d59aafe9 100644 --- a/crates/nu-cli/src/prelude.rs +++ b/crates/nu-cli/src/prelude.rs @@ -68,7 +68,7 @@ macro_rules! trace_out_stream { }}; } -pub(crate) use nu_protocol::{errln, outln}; +pub(crate) use nu_protocol::{errln, out, outln}; use nu_source::HasFallibleSpan; pub(crate) use crate::commands::command::{ diff --git a/crates/nu-protocol/src/macros.rs b/crates/nu-protocol/src/macros.rs index 0b04a0b695..cfc4cd43e7 100644 --- a/crates/nu-protocol/src/macros.rs +++ b/crates/nu-protocol/src/macros.rs @@ -3,6 +3,15 @@ /// Note: this exists to differentiate between intentional writing to stdout /// and stray printlns left by accident #[macro_export] +macro_rules! out { + ($($tokens:tt)*) => { print!($($tokens)*) } +} + +/// Outputs to standard out with a newline added +/// +/// Note: this exists to differentiate between intentional writing to stdout +/// and stray printlns left by accident +#[macro_export] macro_rules! outln { ($($tokens:tt)*) => { println!($($tokens)*) } }