From cd76196335017f59c3066cf64ac6edab54db579f Mon Sep 17 00:00:00 2001 From: Nando Vieira Date: Wed, 4 Sep 2024 09:52:21 -0700 Subject: [PATCH] Handle emoji codepoint size for some not so great terminals. (#1582) --- cmd/soroban-cli/src/print.rs | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/cmd/soroban-cli/src/print.rs b/cmd/soroban-cli/src/print.rs index 2afa5ec03..f772eb649 100644 --- a/cmd/soroban-cli/src/print.rs +++ b/cmd/soroban-cli/src/print.rs @@ -1,4 +1,4 @@ -use std::fmt::Display; +use std::{env, fmt::Display}; use soroban_env_host::xdr::{Error as XdrError, Transaction}; @@ -7,6 +7,8 @@ use crate::{ utils::{explorer_url_for_transaction, transaction_hash}, }; +const TERMS: &[&str] = &["Apple_Terminal", "vscode"]; + pub struct Print { pub quiet: bool, } @@ -36,6 +38,19 @@ impl Print { } } + // Some terminals like vscode's and macOS' default terminal will not render + // the subsequent space if the emoji codepoints size is 2; in this case, + // we need an additional space. + pub fn compute_emoji(&self, emoji: T) -> String { + if let Ok(term_program) = env::var("TERM_PROGRAM") { + if TERMS.contains(&term_program.as_str()) && emoji.to_string().chars().count() == 2 { + return format!("{emoji} "); + } + } + + emoji.to_string() + } + /// # Errors /// /// Might return an error @@ -66,14 +81,14 @@ macro_rules! create_print_functions { #[allow(dead_code)] pub fn $name(&self, message: T) { if !self.quiet { - eprint!("{} {}", $icon, message); + eprint!("{} {}", self.compute_emoji($icon), message); } } #[allow(dead_code)] pub fn $nameln(&self, message: T) { if !self.quiet { - eprintln!("{} {}", $icon, message); + eprintln!("{} {}", self.compute_emoji($icon), message); } } }