diff options
author | Kirill Chibisov <contact@kchibisov.com> | 2020-12-10 09:00:54 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-10 09:00:54 +0300 |
commit | 8e6a608b2d5affaa969174cf7a4e273b358b1509 (patch) | |
tree | 2d888d98859733cc64cfc2585d49fb3d0bf859e7 | |
parent | 5ececc310508c1cdc590d4b6dea9ec2e99475c38 (diff) | |
download | alacritty-8e6a608b2d5affaa969174cf7a4e273b358b1509.tar.gz alacritty-8e6a608b2d5affaa969174cf7a4e273b358b1509.zip |
Print multiline logs in one write call
Fixes potential split of multiline logs in the multithreaded context
by writing them all at once.
-rw-r--r-- | alacritty/src/config/mod.rs | 3 | ||||
-rw-r--r-- | alacritty/src/logging.rs | 32 | ||||
-rw-r--r-- | alacritty/src/main.rs | 15 |
3 files changed, 38 insertions, 12 deletions
diff --git a/alacritty/src/config/mod.rs b/alacritty/src/config/mod.rs index f9ee3528..6fe58537 100644 --- a/alacritty/src/config/mod.rs +++ b/alacritty/src/config/mod.rs @@ -228,8 +228,7 @@ fn load_imports(config: &Value, config_paths: &mut Vec<PathBuf>, recursion_limit } if !path.exists() { - info!(target: LOG_TARGET_CONFIG, "Skipping importing config; not found:"); - info!(target: LOG_TARGET_CONFIG, " {:?}", path.display()); + info!(target: LOG_TARGET_CONFIG, "Config import not found:\n {:?}", path.display()); continue; } diff --git a/alacritty/src/logging.rs b/alacritty/src/logging.rs index a7ca3ac7..2110d8e1 100644 --- a/alacritty/src/logging.rs +++ b/alacritty/src/logging.rs @@ -72,7 +72,7 @@ impl Logger { #[cfg(windows)] let env_var = format!("%{}%", ALACRITTY_LOG_ENV); - let msg = format!( + let message = format!( "[{}] See log at {} ({}):\n{}", record.level(), logfile_path, @@ -85,7 +85,7 @@ impl Logger { _ => unreachable!(), }; - let mut message = Message::new(msg, message_type); + let mut message = Message::new(message, message_type); message.set_target(record.target().to_owned()); let _ = event_proxy.send_event(Event::Message(message)); @@ -107,12 +107,12 @@ impl log::Log for Logger { return; } - let now = time::strftime("%F %T.%f", &time::now()).unwrap(); - let msg = format!("[{}] [{:<5}] [{}] {}\n", now, record.level(), target, record.args()); + // Create log message for the given `record` and `target`. + let message = create_log_message(record, &target); if let Ok(mut logfile) = self.logfile.lock() { // Write to logfile. - let _ = logfile.write_all(msg.as_ref()); + let _ = logfile.write_all(message.as_ref()); // Write to message bar. if record.level() <= Level::Warn { @@ -122,13 +122,33 @@ impl log::Log for Logger { // Write to stdout. if let Ok(mut stdout) = self.stdout.lock() { - let _ = stdout.write_all(msg.as_ref()); + let _ = stdout.write_all(message.as_ref()); } } fn flush(&self) {} } +fn create_log_message(record: &log::Record<'_>, target: &str) -> String { + let now = time::strftime("%F %T.%f", &time::now()).unwrap(); + let mut message = format!("[{}] [{:<5}] [{}] ", now, record.level(), target); + + // Alignment for the lines after the first new line character in the payload. We don't deal + // with fullwidth/unicode chars here, so just `message.len()` is sufficient. + let alignment = message.len(); + + // Push lines with added extra padding on the next line, which is trimmed later. + let lines = record.args().to_string(); + for line in lines.split('\n') { + let line = format!("{}\n{:width$}", line, "", width = alignment); + message.push_str(&line); + } + + // Drop extra trailing alignment. + message.truncate(message.len() - alignment); + message +} + struct OnDemandLogFile { file: Option<LineWriter<File>>, created: Arc<AtomicBool>, diff --git a/alacritty/src/main.rs b/alacritty/src/main.rs index 98fe2d05..3b517efc 100644 --- a/alacritty/src/main.rs +++ b/alacritty/src/main.rs @@ -130,10 +130,8 @@ fn run( ) -> Result<(), Box<dyn Error>> { info!("Welcome to Alacritty"); - info!("Configuration files loaded from:"); - for path in &config.ui_config.config_paths { - info!(" \"{}\"", path.display()); - } + // Log the configuration paths. + log_config_path(&config); // Set environment variables. tty::setup_env(&config); @@ -242,3 +240,12 @@ fn run( Ok(()) } + +fn log_config_path(config: &Config) { + let mut msg = String::from("Configuration files loaded from:"); + for path in &config.ui_config.config_paths { + msg.push_str(&format!("\n {:?}", path.display())); + } + + info!("{}", msg); +} |