Merge remote-tracking branch 'origin/dev' into next

This commit is contained in:
Lucas Nogueira 2022-08-12 20:09:23 -03:00
commit 11d50e8474
No known key found for this signature in database
GPG Key ID: FFEA6C72E73482F1
3 changed files with 106 additions and 69 deletions

View File

@ -0,0 +1,5 @@
---
"tauri-codegen": patch
---
Use `TARGET` environment variable for code generation inside build scripts.

View File

@ -28,6 +28,7 @@ pub struct ContextData {
fn map_core_assets( fn map_core_assets(
options: &AssetOptions, options: &AssetOptions,
target: Target,
) -> impl Fn(&AssetKey, &Path, &mut Vec<u8>, &mut CspHashes) -> Result<(), EmbeddedAssetsError> { ) -> impl Fn(&AssetKey, &Path, &mut Vec<u8>, &mut CspHashes) -> Result<(), EmbeddedAssetsError> {
#[cfg(feature = "isolation")] #[cfg(feature = "isolation")]
let pattern = tauri_utils::html::PatternObject::from(&options.pattern); let pattern = tauri_utils::html::PatternObject::from(&options.pattern);
@ -40,8 +41,9 @@ fn map_core_assets(
#[allow(clippy::collapsible_if)] #[allow(clippy::collapsible_if)]
if csp { if csp {
#[cfg(target_os = "linux")] if target == Target::Linux {
::tauri_utils::html::inject_csp_token(&mut document); ::tauri_utils::html::inject_csp_token(&mut document);
}
inject_nonce_token(&mut document, &dangerous_disable_asset_csp_modification); inject_nonce_token(&mut document, &dangerous_disable_asset_csp_modification);
@ -106,6 +108,16 @@ fn map_isolation(
} }
} }
#[derive(PartialEq, Eq, Clone, Copy)]
enum Target {
Linux,
Windows,
Darwin,
Android,
// iOS.
Ios,
}
/// Build a `tauri::Context` for including in application code. /// Build a `tauri::Context` for including in application code.
pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsError> { pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsError> {
let ContextData { let ContextData {
@ -115,6 +127,34 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
root, root,
} = data; } = data;
let target = if let Ok(target) = std::env::var("TARGET") {
if target.contains("unknown-linux") {
Target::Linux
} else if target.contains("pc-windows") {
Target::Windows
} else if target.contains("apple-darwin") {
Target::Darwin
} else if target.contains("android") {
Target::Android
} else if target.contains("apple-ios") {
Target::Ios
} else {
panic!("unknown codegen target {}", target);
}
} else if cfg!(target_os = "linux") {
Target::Linux
} else if cfg!(windows) {
Target::Windows
} else if cfg!(target_os = "macos") {
Target::Darwin
} else if cfg!(target_os = "android") {
Target::Android
} else if cfg!(target_os = "ios") {
Target::Ios
} else {
panic!("unknown codegen target");
};
let mut options = AssetOptions::new(config.tauri.pattern.clone()) let mut options = AssetOptions::new(config.tauri.pattern.clone())
.freeze_prototype(config.tauri.security.freeze_prototype) .freeze_prototype(config.tauri.security.freeze_prototype)
.dangerous_disable_asset_csp_modification( .dangerous_disable_asset_csp_modification(
@ -162,7 +202,7 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
path path
) )
} }
EmbeddedAssets::new(assets_path, &options, map_core_assets(&options))? EmbeddedAssets::new(assets_path, &options, map_core_assets(&options, target))?
} }
_ => unimplemented!(), _ => unimplemented!(),
}, },
@ -172,7 +212,7 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
.map(|p| config_parent.join(p)) .map(|p| config_parent.join(p))
.collect::<Vec<_>>(), .collect::<Vec<_>>(),
&options, &options,
map_core_assets(&options), map_core_assets(&options, target),
)?, )?,
_ => unimplemented!(), _ => unimplemented!(),
}; };
@ -189,9 +229,9 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
out_dir out_dir
}; };
// handle default window icons for Windows targets
#[cfg(windows)]
let default_window_icon = { let default_window_icon = {
if target == Target::Windows {
// handle default window icons for Windows targets
let icon_path = find_icon( let icon_path = find_icon(
&config, &config,
&config_parent, &config_parent,
@ -209,9 +249,8 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
); );
png_icon(&root, &out_dir, icon_path)? png_icon(&root, &out_dir, icon_path)?
} }
}; } else if target == Target::Linux {
#[cfg(target_os = "linux")] // handle default window icons for Linux targets
let default_window_icon = {
let icon_path = find_icon( let icon_path = find_icon(
&config, &config,
&config_parent, &config_parent,
@ -219,12 +258,12 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
"icons/icon.png", "icons/icon.png",
); );
png_icon(&root, &out_dir, icon_path)? png_icon(&root, &out_dir, icon_path)?
} else {
quote!(None)
}
}; };
#[cfg(not(any(windows, target_os = "linux")))]
let default_window_icon = quote!(None);
#[cfg(target_os = "macos")] let app_icon = if target == Target::Darwin && dev {
let app_icon = if dev {
let mut icon_path = find_icon( let mut icon_path = find_icon(
&config, &config,
&config_parent, &config_parent,
@ -243,8 +282,6 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
} else { } else {
quote!(None) quote!(None)
}; };
#[cfg(not(target_os = "macos"))]
let app_icon = quote!(None);
let package_name = if let Some(product_name) = &config.package.product_name { let package_name = if let Some(product_name) = &config.package.product_name {
quote!(#product_name.to_string()) quote!(#product_name.to_string())
@ -283,8 +320,7 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
}; };
#[cfg(target_os = "macos")] #[cfg(target_os = "macos")]
let info_plist = { let info_plist = if target == Target::Darwin && dev {
if dev {
let info_plist_path = config_parent.join("Info.plist"); let info_plist_path = config_parent.join("Info.plist");
let mut info_plist = if info_plist_path.exists() { let mut info_plist = if info_plist_path.exists() {
plist::Value::from_file(&info_plist_path) plist::Value::from_file(&info_plist_path)
@ -314,12 +350,10 @@ pub fn context_codegen(data: ContextData) -> Result<TokenStream, EmbeddedAssetsE
let info_plist_path = out_path.display().to_string(); let info_plist_path = out_path.display().to_string();
quote!({ quote!({
#[cfg(desktop)]
tauri::embed_plist::embed_info_plist!(#info_plist_path); tauri::embed_plist::embed_info_plist!(#info_plist_path);
}) })
} else { } else {
quote!(()) quote!(())
}
}; };
#[cfg(not(target_os = "macos"))] #[cfg(not(target_os = "macos"))]
let info_plist = quote!(()); let info_plist = quote!(());
@ -443,7 +477,6 @@ fn ico_icon<P: AsRef<Path>>(
Ok(icon) Ok(icon)
} }
#[cfg(target_os = "macos")]
fn raw_icon<P: AsRef<Path>>(out_dir: &Path, path: P) -> Result<TokenStream, EmbeddedAssetsError> { fn raw_icon<P: AsRef<Path>>(out_dir: &Path, path: P) -> Result<TokenStream, EmbeddedAssetsError> {
let path = path.as_ref(); let path = path.as_ref();
let bytes = std::fs::read(&path) let bytes = std::fs::read(&path)
@ -508,7 +541,6 @@ fn write_if_changed(out_path: &Path, data: &[u8]) -> std::io::Result<()> {
out_file.write_all(data) out_file.write_all(data)
} }
#[cfg(any(windows, target_os = "macos", target_os = "linux"))]
fn find_icon<F: Fn(&&String) -> bool>( fn find_icon<F: Fn(&&String) -> bool>(
config: &Config, config: &Config,
config_parent: &Path, config_parent: &Path,