add r2r for launcher and game assemblies
Some checks failed
Build / Compute Version (push) Successful in 7s
Build / Build Nuget package (SharedCringe) (push) Successful in 3m59s
Build / Build Nuget package (CringeBootstrap.Abstractions) (push) Successful in 4m12s
Build / Build Nuget package (NuGet) (push) Successful in 4m8s
Build / Build Nuget package (CringePlugins) (push) Successful in 4m33s
Build / Build Launcher (push) Failing after 4m38s

This commit is contained in:
zznty
2025-08-02 03:58:42 +07:00
parent 934b931d40
commit b2b9f0bf46
4 changed files with 290 additions and 6 deletions

View File

@@ -1,9 +1,9 @@
using System.Diagnostics;
using System.Reflection;
using System.Reflection.Metadata;
using System.Runtime.Loader;
using CringeBootstrap;
using CringeBootstrap.Abstractions;
using CringeBootstrap.CrossGen;
using Velopack;
#if DEBUG
@@ -41,15 +41,45 @@ AssemblyLoadContext.Default.Resolving += (loadContext, name) =>
#endif
var dir = Path.GetDirectoryName(args[0])!;
var context = new GameDirectoryAssemblyLoadContext(dir);
var gameDir = dir;
var customEntrypoint = Environment.GetEnvironmentVariable("DOTNET_BOOTSTRAP_ENTRYPOINT");
if (
#if !DEBUG // disable crossgen for plugins userdev, but leave for debug
customEntrypoint is null &&
#endif
!args.Contains("--skip-crossgen", StringComparer.OrdinalIgnoreCase))
{
var cacheDir = Directory.CreateDirectory(Path.Join(
Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData),
"CringeLauncher", "cache"));
var crossGenService = new CrossGenService(gameDir, cacheDir.FullName);
try
{
dir = crossGenService.RunCrossGen();
}
catch (Exception e)
{
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("Crossgen encountered a fatal error and will be skipped for this session.");
Console.ResetColor();
Console.WriteLine(e);
crossGenService.CleanCache();
}
}
var context = new GameDirectoryAssemblyLoadContext(dir, gameDir);
// a list of assemblies which are not in the game binaries but reference them
context.AddDependencyOverride("CringeLauncher");
context.AddDependencyOverride("CringePlugins");
context.AddDependencyOverride("EOSSDK");
var entrypoint = Environment.GetEnvironmentVariable("DOTNET_BOOTSTRAP_ENTRYPOINT") ??
"CringeLauncher.Launcher, CringeLauncher";
var entrypoint = customEntrypoint ?? "CringeLauncher.Launcher, CringeLauncher";
if (!TypeName.TryParse(entrypoint, out var entrypointName) ||
entrypointName.AssemblyName is null)
{