From 554de6445a20f30eb1b6658db9c2b3f989426008 Mon Sep 17 00:00:00 2001 From: Darrell Roberts Date: Tue, 12 Nov 2024 17:02:45 -0500 Subject: [PATCH 1/4] set default log level when not using RUST_LOG --- cli/src/main.rs | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/cli/src/main.rs b/cli/src/main.rs index 3a108c48..919b27f1 100644 --- a/cli/src/main.rs +++ b/cli/src/main.rs @@ -16,8 +16,9 @@ use std::{ use anyhow::{anyhow, Context}; use clap::{CommandFactory, Parser}; use clap_complete::Generator; +use flexi_logger::detailed_format; use ignore::{overrides::OverrideBuilder, types::TypesBuilder, WalkBuilder}; -use log::error; +use log::{error, info}; use rayon::iter::ParallelBridge; #[cfg(feature = "go")] use typeshare_core::language::Go; @@ -37,13 +38,15 @@ use crate::{ }; fn main() -> anyhow::Result<()> { - flexi_logger::Logger::try_with_env() - .unwrap() - .start() - .unwrap(); + flexi_logger::Logger::try_with_env_or_str("info")? + .format_for_stdout(detailed_format) + .format_for_stderr(detailed_format) + .start()?; let options = Args::parse(); + info!("typeshare started generating types"); + if let Some(options) = options.subcommand { match options { Command::Completions { shell } => { @@ -153,6 +156,7 @@ fn main() -> anyhow::Result<()> { }; check_parse_errors(&crate_parsed_data)?; + write_generated( destination, lang.as_mut(), @@ -160,6 +164,7 @@ fn main() -> anyhow::Result<()> { import_candidates, )?; + info!("typeshare finished generating types"); Ok(()) } @@ -269,6 +274,7 @@ fn check_parse_errors(parsed_crates: &BTreeMap) -> anyhow } if errors_encountered { + error!("Errors encountered during parsing."); Err(anyhow!("Errors encountered during parsing.")) } else { Ok(()) From 57166cab2ee37f637e7aff69cd1343dfc9ebe2c9 Mon Sep 17 00:00:00 2001 From: Darrell Roberts Date: Tue, 12 Nov 2024 17:38:18 -0500 Subject: [PATCH 2/4] update error output for parsing failures --- cli/src/main.rs | 4 ++-- core/src/parser.rs | 2 -- core/src/visitors.rs | 3 +-- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/cli/src/main.rs b/cli/src/main.rs index 919b27f1..d1f63d4b 100644 --- a/cli/src/main.rs +++ b/cli/src/main.rs @@ -267,8 +267,8 @@ fn check_parse_errors(parsed_crates: &BTreeMap) -> anyhow errors_encountered = true; for error in &data.errors { error!( - "Parsing error: \"{}\" in crate \"{}\" for file \"{}\"", - error.error, error.crate_name, error.file_name + "Parsing error: \"{}\" in file \"{}\"", + error.error, error.file_name ); } } diff --git a/core/src/parser.rs b/core/src/parser.rs index c6dac11f..3f2f2159 100644 --- a/core/src/parser.rs +++ b/core/src/parser.rs @@ -80,8 +80,6 @@ pub enum ParseError { /// Error with it's related data. #[derive(Debug)] pub struct ErrorInfo { - /// The crate where this error occurred. - pub crate_name: CrateName, /// The file name being parsed. pub file_name: String, /// The parse error. diff --git a/core/src/visitors.rs b/core/src/visitors.rs index 8a566060..cf4b5c41 100644 --- a/core/src/visitors.rs +++ b/core/src/visitors.rs @@ -92,8 +92,7 @@ impl<'a> TypeShareVisitor<'a> { match result { Ok(data) => self.parsed_data.push(data), Err(error) => self.parsed_data.errors.push(ErrorInfo { - crate_name: self.parsed_data.crate_name.clone(), - file_name: self.parsed_data.file_name.clone(), + file_name: self.file_path.to_string_lossy().into_owned(), error, }), } From 024875159cea5a7d2830269060d8933b7aee91c5 Mon Sep 17 00:00:00 2001 From: Darrell Roberts Date: Tue, 12 Nov 2024 19:54:36 -0500 Subject: [PATCH 3/4] Use adaptive format for coloring when possible --- cli/src/main.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cli/src/main.rs b/cli/src/main.rs index d1f63d4b..59589dc4 100644 --- a/cli/src/main.rs +++ b/cli/src/main.rs @@ -16,7 +16,7 @@ use std::{ use anyhow::{anyhow, Context}; use clap::{CommandFactory, Parser}; use clap_complete::Generator; -use flexi_logger::detailed_format; +use flexi_logger::AdaptiveFormat; use ignore::{overrides::OverrideBuilder, types::TypesBuilder, WalkBuilder}; use log::{error, info}; use rayon::iter::ParallelBridge; @@ -39,8 +39,8 @@ use crate::{ fn main() -> anyhow::Result<()> { flexi_logger::Logger::try_with_env_or_str("info")? - .format_for_stdout(detailed_format) - .format_for_stderr(detailed_format) + .adaptive_format_for_stderr(AdaptiveFormat::Detailed) + .adaptive_format_for_stdout(AdaptiveFormat::Detailed) .start()?; let options = Args::parse(); From 39229394aa96872b73b33475fe702feebbade69e Mon Sep 17 00:00:00 2001 From: Darrell Roberts Date: Tue, 12 Nov 2024 22:49:26 -0500 Subject: [PATCH 4/4] remove dead_code attribute --- core/src/visitors.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/core/src/visitors.rs b/core/src/visitors.rs index cf4b5c41..8ac113e4 100644 --- a/core/src/visitors.rs +++ b/core/src/visitors.rs @@ -49,7 +49,6 @@ const IGNORED_TYPES: &[&str] = &["Option", "String", "Vec", "HashMap", "T", "I54 #[derive(Default)] pub struct TypeShareVisitor<'a> { parsed_data: ParsedData, - #[allow(dead_code)] file_path: PathBuf, ignored_types: &'a [&'a str], target_os: &'a [String],