From e66010f867f6ad4f4830fdb20a846a0ef474c1b7 Mon Sep 17 00:00:00 2001 From: Lucas Fernandes Nogueira Date: Thu, 3 Oct 2024 10:57:49 -0300 Subject: [PATCH] refactor: remove package and lib name validation (#398) those values are not used as the identifier anymore so we do not need to validate them, deferring to the Cargo name validation is enough --- .changes/remove-name-validation.md | 5 ++++ src/android/aab.rs | 3 +-- src/android/apk.rs | 3 +-- src/android/device.rs | 2 +- src/apple/device/simctl/run.rs | 2 +- src/config/app/mod.rs | 7 ++--- src/config/app/raw.rs | 42 +++++------------------------- src/templating/init.rs | 4 +-- 8 files changed, 19 insertions(+), 49 deletions(-) create mode 100644 .changes/remove-name-validation.md diff --git a/.changes/remove-name-validation.md b/.changes/remove-name-validation.md new file mode 100644 index 00000000..99563512 --- /dev/null +++ b/.changes/remove-name-validation.md @@ -0,0 +1,5 @@ +--- +"cargo-mobile2": patch +--- + +Removed name and lib name validation as they are not used as the package identifier anymore. diff --git a/src/android/aab.rs b/src/android/aab.rs index 6a206e47..e6d18d85 100644 --- a/src/android/aab.rs +++ b/src/android/aab.rs @@ -79,11 +79,10 @@ pub fn build( Ok(()) }) .start() - .map_err(|err| { + .inspect_err(|err| { if err.kind() == std::io::ErrorKind::NotFound { log::error!("`gradlew` not found. Make sure you have the Android SDK installed and added to your PATH"); } - err })? .wait()?; diff --git a/src/android/apk.rs b/src/android/apk.rs index 63e0b020..d9b1cbba 100644 --- a/src/android/apk.rs +++ b/src/android/apk.rs @@ -106,11 +106,10 @@ pub fn build( Ok(()) }) .start() - .map_err(|err| { + .inspect_err(|err| { if err.kind() == std::io::ErrorKind::NotFound { log::error!("`gradlew` not found. Make sure you have the Android SDK installed and added to your PATH"); } - err })? .wait()?; diff --git a/src/android/device.rs b/src/android/device.rs index 4c7b7210..1c7edffd 100644 --- a/src/android/device.rs +++ b/src/android/device.rs @@ -390,7 +390,7 @@ impl<'a> Device<'a> { let stdout = loop { let cmd = duct::cmd( env.platform_tools_path().join("adb"), - ["shell", "pidof", "-s", &config.app().identifier()], + ["shell", "pidof", "-s", config.app().identifier()], ) .vars(env.explicit_env()) .stderr_capture() diff --git a/src/apple/device/simctl/run.rs b/src/apple/device/simctl/run.rs index 158cd887..4e0743ef 100644 --- a/src/apple/device/simctl/run.rs +++ b/src/apple/device/simctl/run.rs @@ -48,7 +48,7 @@ pub fn run( handle.wait().map_err(RunError::DeployFailed)?; let app_id = config.app().identifier(); - let mut launcher_cmd = duct::cmd("xcrun", ["simctl", "launch", id, &app_id]) + let mut launcher_cmd = duct::cmd("xcrun", ["simctl", "launch", id, app_id]) .vars(env.explicit_env()) .dup_stdio(); diff --git a/src/config/app/mod.rs b/src/config/app/mod.rs index c68a5c96..18d1186c 100644 --- a/src/config/app/mod.rs +++ b/src/config/app/mod.rs @@ -93,12 +93,9 @@ impl App { pub fn from_raw(root_dir: PathBuf, raw: Raw) -> Result { assert!(root_dir.is_absolute(), "root must be absolute"); - let name = name::validate(raw.name).map_err(Error::NameInvalid)?; + let name = raw.name; - let lib_name = raw - .lib_name - .map(|n| lib_name::validate(n).map_err(Error::LibNameInvalid)) - .transpose()?; + let lib_name = raw.lib_name; let stylized_name = raw.stylized_name.unwrap_or_else(|| name.clone()); diff --git a/src/config/app/raw.rs b/src/config/app/raw.rs index 2fa621fe..46382092 100644 --- a/src/config/app/raw.rs +++ b/src/config/app/raw.rs @@ -176,7 +176,7 @@ impl Raw { pub fn prompt(wrapper: &TextWrapper) -> Result { let defaults = Defaults::new(wrapper).map_err(PromptError::DefaultsFailed)?; - let (name, default_stylized) = Self::prompt_name(wrapper, &defaults)?; + let (name, default_stylized) = Self::prompt_name(&defaults)?; let stylized_name = Self::prompt_stylized_name(&name, default_stylized)?; let identifier = Self::prompt_identifier(wrapper, &defaults)?; let template_pack = Some(Self::prompt_template_pack(wrapper)?) @@ -193,41 +193,11 @@ impl Raw { } impl Raw { - fn prompt_name( - wrapper: &TextWrapper, - defaults: &Defaults, - ) -> Result<(String, Option), PromptError> { - let mut default_name = defaults.name.clone(); - let mut rejected = None; - let mut default_stylized = None; - let name = loop { - let response = prompt::default("Project name", default_name.as_deref(), None) - .map_err(PromptError::NamePromptFailed)?; - match name::validate(response.clone()) { - Ok(response) => { - if default_name == Some(response.clone()) { - if rejected.is_some() { - default_stylized = rejected.take(); - } else { - default_stylized = Some(defaults.stylized_name.clone()); - } - } - break response; - } - Err(err) => { - rejected = Some(response); - println!( - "{}", - wrapper - .fill(&format!("Gosh, that's not a valid project name! {}", err)) - .bright_magenta() - ); - if let Some(suggested) = err.suggested() { - default_name = Some(suggested.to_owned()); - } - } - } - }; + fn prompt_name(defaults: &Defaults) -> Result<(String, Option), PromptError> { + let default_name = defaults.name.clone(); + let name = prompt::default("Project name", default_name.as_deref(), None) + .map_err(PromptError::NamePromptFailed)?; + let default_stylized = Some(defaults.stylized_name.clone()); Ok((name, default_stylized)) } diff --git a/src/templating/init.rs b/src/templating/init.rs index 6f52f471..d139ee92 100644 --- a/src/templating/init.rs +++ b/src/templating/init.rs @@ -107,8 +107,8 @@ fn ident_last_part( _: &mut RenderContext, out: &mut dyn Output, ) -> HelperResult { - let last = get_str(helper).split('.').rev().next().unwrap_or_default(); - out.write(&last).map_err(Into::into) + let last = get_str(helper).split('.').next_back().unwrap_or_default(); + out.write(last).map_err(Into::into) } fn ident_no_last_part(