From 0ad6efd7ddcf386c6027f357df39ebe7c3d4c9e9 Mon Sep 17 00:00:00 2001 From: pointfeev Date: Tue, 8 Mar 2022 17:10:08 -0500 Subject: [PATCH] games use steamCMD fallback --- CreamInstaller/CreamInstaller.csproj | 2 +- CreamInstaller/SelectForm.cs | 15 ++++++++------- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/CreamInstaller/CreamInstaller.csproj b/CreamInstaller/CreamInstaller.csproj index 047f015..f645295 100644 --- a/CreamInstaller/CreamInstaller.csproj +++ b/CreamInstaller/CreamInstaller.csproj @@ -5,7 +5,7 @@ True Resources\ini.ico true - 3.2.1.2 + 3.2.2.0 Resources\ini.ico diff --git a/CreamInstaller/SelectForm.cs b/CreamInstaller/SelectForm.cs index 3ddb54f..9edae97 100644 --- a/CreamInstaller/SelectForm.cs +++ b/CreamInstaller/SelectForm.cs @@ -144,7 +144,7 @@ internal partial class SelectForm : CustomForm } AppData appData = await SteamStore.QueryStoreAPI(appId); VProperty appInfo = appInfo = await SteamCMD.GetAppInfo(appId, branch, buildId); - if (appInfo is null || appData is null) + if (appData is null && appInfo is null) { RemoveFromRemainingGames(name); return; @@ -152,8 +152,9 @@ internal partial class SelectForm : CustomForm if (Program.Canceled) return; ConcurrentDictionary dlc = new(); List dlcTasks = new(); - List dlcIds = await SteamStore.ParseDlcAppIds(appData); - dlcIds.AddRange(await SteamCMD.ParseDlcAppIds(appInfo)); + List dlcIds = new(); + if (appData is not null) dlcIds.AddRange(await SteamStore.ParseDlcAppIds(appData)); + if (appInfo is not null) dlcIds.AddRange(await SteamCMD.ParseDlcAppIds(appInfo)); if (dlcIds.Count > 0) { foreach (string dlcAppId in dlcIds) @@ -209,14 +210,14 @@ internal partial class SelectForm : CustomForm selection.Enabled = allCheckBox.Checked || selection.SelectedDlc.Any() || selection.ExtraDlc.Any(); selection.Usable = true; selection.Id = appId; - selection.Name = appData.name ?? name; + selection.Name = appData?.name ?? name; selection.RootDirectory = directory; selection.DllDirectories = dllDirectories; selection.IsSteam = true; selection.ProductUrl = "https://store.steampowered.com/app/" + appId; selection.IconUrl = IconGrabber.SteamAppImagesPath + @$"\{appId}\{appInfo?.Value?.GetChild("common")?.GetChild("icon")?.ToString()}.jpg"; - selection.SubIconUrl = appData.header_image ?? IconGrabber.SteamAppImagesPath + @$"\{appId}\{appInfo?.Value?.GetChild("common")?.GetChild("clienticon")?.ToString()}.ico"; - selection.Publisher = appData.publishers[0] ?? appInfo?.Value?.GetChild("extended")?.GetChild("publisher")?.ToString(); + selection.SubIconUrl = appData?.header_image ?? IconGrabber.SteamAppImagesPath + @$"\{appId}\{appInfo?.Value?.GetChild("common")?.GetChild("clienticon")?.ToString()}.ico"; + selection.Publisher = appData?.publishers[0] ?? appInfo?.Value?.GetChild("extended")?.GetChild("publisher")?.ToString(); if (Program.Canceled) return; Program.Invoke(selectionTreeView, delegate @@ -224,7 +225,7 @@ internal partial class SelectForm : CustomForm if (Program.Canceled) return; TreeNode programNode = TreeNodes.Find(s => s.Name == appId) ?? new(); programNode.Name = appId; - programNode.Text = appData.name ?? name; + programNode.Text = appData?.name ?? name; programNode.Checked = selection.Enabled; programNode.Remove(); selectionTreeView.Nodes.Add(programNode);