From 98bbf05bcc698c629b7b003115ab6d73cdc9218e Mon Sep 17 00:00:00 2001 From: MikhailSuendukov <110986399+MikhailSuendukov@users.noreply.github.com> Date: Mon, 20 Nov 2023 12:18:28 +0100 Subject: [PATCH] Improve UWP type recognition (#1762) Co-authored-by: Dima --- CHANGELOG.md | 1 + .../Utils/WindowsHelper.cs | 42 +++++++------------ 2 files changed, 16 insertions(+), 27 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 4d12c674e..b20f4a0c6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ #### Windows +* **[Improvement]** Improve UWP and WinUI app type checking. * **[Improvement]** Update SQLitePCLRaw.bundle_green to version 2.1.6 ___ diff --git a/SDK/AppCenter/Microsoft.AppCenter.WindowsDesktop/Utils/WindowsHelper.cs b/SDK/AppCenter/Microsoft.AppCenter.WindowsDesktop/Utils/WindowsHelper.cs index c0be9fedc..d78d0de84 100644 --- a/SDK/AppCenter/Microsoft.AppCenter.WindowsDesktop/Utils/WindowsHelper.cs +++ b/SDK/AppCenter/Microsoft.AppCenter.WindowsDesktop/Utils/WindowsHelper.cs @@ -34,40 +34,28 @@ public static class WindowsHelper private static bool _IsRunningAsUwp() { - if (Environment.OSVersion.Version < new Version(6, 2)) + try { - return false; + return Assembly.GetEntryAssembly().GetReferencedAssemblies() + .Any(referencedAssembly => referencedAssembly.Name == "Windows.UI.Xaml"); + } + catch (Exception e) + { + AppCenterLog.Error(AppCenterLog.LogTag, "Failed to determine whether this application is UWP or not.", e); } - int length = 0; - var sb = new StringBuilder(0); - GetCurrentPackageFullName(ref length, sb); - - sb = new StringBuilder(length); - int result = GetCurrentPackageFullName(ref length, sb); - - return result != APPMODEL_ERROR_NO_PACKAGE; + return false; } - #endregion - private static bool _IsRunnigAsWinUI() + private static bool _IsRunningAsWinUI() { - try + try { - // Get the main assembly of the application - Assembly mainAssembly = Assembly.GetEntryAssembly(); - - // Check if the main assembly references the Microsoft.UI.Xaml or Microsoft.WinUI assembly, which is used by WinUI applications - foreach (AssemblyName referencedAssembly in mainAssembly.GetReferencedAssemblies()) - { - if (referencedAssembly.Name == "Microsoft.UI.Xaml" || referencedAssembly.Name == "Microsoft.WinUI") - { - return true; - } - } - } - catch (Exception e) + return Assembly.GetEntryAssembly().GetReferencedAssemblies() + .Any(referencedAssembly => referencedAssembly.Name == "Microsoft.UI.Xaml" || referencedAssembly.Name == "Microsoft.WinUI"); + } + catch (Exception e) { AppCenterLog.Error(AppCenterLog.LogTag, "Failed to determine whether this application is WinUI or not.", e); } @@ -150,7 +138,7 @@ static WindowsHelper() AppCenterLog.Warn(AppCenterLog.LogTag, "Unabled to determine whether this application is WPF or Windows Forms; proceeding as though it is Windows Forms."); } IsRunningAsUwp = _IsRunningAsUwp(); - IsRunningAsWinUI = IsRunningAsUwp || _IsRunnigAsWinUI(); + IsRunningAsWinUI = IsRunningAsUwp || _IsRunningAsWinUI(); } // Store the int corresponding to the "Minimized" state for WPF Windows