From ebe3ec9ab02c8e61dd55e24323c5ec74d9b05113 Mon Sep 17 00:00:00 2001 From: Pink <62712899+ModdingPink@users.noreply.github.com> Date: Mon, 16 Dec 2024 04:37:33 +0000 Subject: [PATCH 1/2] Re-Implement -vrmode within OpenXR --- IPA.Injector/Injector.cs | 57 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) diff --git a/IPA.Injector/Injector.cs b/IPA.Injector/Injector.cs index 6a2ba7c4..0500e6a8 100644 --- a/IPA.Injector/Injector.cs +++ b/IPA.Injector/Injector.cs @@ -5,6 +5,7 @@ using IPA.Loader; using IPA.Logging; using IPA.Utilities; +using Microsoft.Win32; using Mono.Cecil; using Mono.Cecil.Cil; using System; @@ -15,6 +16,7 @@ using System.Threading.Tasks; using UnityEngine; using static IPA.Logging.Logger; +using static UnityEngine.Scripting.GarbageCollector; using MethodAttributes = Mono.Cecil.MethodAttributes; #if NET3 using Net3_Proxy; @@ -84,6 +86,8 @@ internal static void Main(string[] args) GameVersionEarly.Load(); SelfConfig.Instance.CheckVersionBoundary(); + SetOpenXRRuntime(arguments); + // updates backup InstallBootstrapPatch(); @@ -102,6 +106,59 @@ internal static void Main(string[] args) } } + public static void SetOpenXRRuntime(string[] arguments) + { + if (arguments == null) + return; + + string targetRuntime = string.Empty; + + for (int i = 0; i < arguments.Length; i++) + { + if (arguments[i] == "-vrmode" && i + 1 < arguments.Length) + { + targetRuntime = arguments[i + 1]; + break; + } + } + + if (string.IsNullOrEmpty(targetRuntime)) + return; + + targetRuntime = targetRuntime.ToLower(System.Globalization.CultureInfo.CurrentCulture); + + //This forces the OpenXRLoader to error as there is no OpenXR Runtime found, which is intentional as a mod can then select it + switch (targetRuntime) + { + case "none": + case "fpfc": + case "controllable": + Environment.SetEnvironmentVariable("XR_RUNTIME_JSON", targetRuntime); //By checking the env variable you can see what caused the override while still causing the fail + return; + } + + string registryPath = @"SOFTWARE\Khronos\OpenXR\1\AvailableRuntimes"; + RegistryKey baseKey = Registry.LocalMachine.OpenSubKey(registryPath); + string foundRuntime = string.Empty; + if (baseKey != null) + { + foreach (string valueName in baseKey.GetValueNames()) + { + if (Path.GetFileNameWithoutExtension(valueName).ToLower().Contains(targetRuntime)) + { + foundRuntime = valueName; + break; + } + } + baseKey.Close(); + } + + if(!string.IsNullOrEmpty(foundRuntime)) + Environment.SetEnvironmentVariable("XR_RUNTIME_JSON", foundRuntime); + + //This is not stored within CommandLineValues.Debug as you can check the environment variable + } + private static void MaybeInitializeConsole(string[] arguments) { var i = 0; From a30f709ae682903c0efc6f55812f10b99615c724 Mon Sep 17 00:00:00 2001 From: Pink <62712899+ModdingPink@users.noreply.github.com> Date: Mon, 16 Dec 2024 04:38:15 +0000 Subject: [PATCH 2/2] Unneeded GC include --- IPA.Injector/Injector.cs | 1 - 1 file changed, 1 deletion(-) diff --git a/IPA.Injector/Injector.cs b/IPA.Injector/Injector.cs index 0500e6a8..cd53af30 100644 --- a/IPA.Injector/Injector.cs +++ b/IPA.Injector/Injector.cs @@ -16,7 +16,6 @@ using System.Threading.Tasks; using UnityEngine; using static IPA.Logging.Logger; -using static UnityEngine.Scripting.GarbageCollector; using MethodAttributes = Mono.Cecil.MethodAttributes; #if NET3 using Net3_Proxy;