Skip to content

Commit

Permalink
Ignore the 'Must set an output directory through SetCompileScriptsOut…
Browse files Browse the repository at this point in the history
…putDirectory before compiling' error when unity is starting
  • Loading branch information
JoC0de committed Jan 5, 2025
1 parent 1f26956 commit f31c8b3
Showing 1 changed file with 41 additions and 7 deletions.
48 changes: 41 additions & 7 deletions src/NuGetForUnity/Editor/UnityPreImportedLibraryResolver.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using System.Collections.Generic;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using JetBrains.Annotations;
Expand Down Expand Up @@ -82,8 +83,23 @@ private static HashSet<string> GetAlreadyImportedLibs()
#else
const AssembliesType assemblyType = AssembliesType.Player;
#endif
var projectAssemblies = CompilationPipeline.GetAssemblies(assemblyType)
.Where(playerAssembly => playerAssembly.flags != AssemblyFlags.EditorAssembly);
IEnumerable<Assembly> projectAssemblies;
var failedToGetAssembliesFromUnity = false;
try
{
projectAssemblies = CompilationPipeline.GetAssemblies(assemblyType)
.Where(playerAssembly => playerAssembly.flags != AssemblyFlags.EditorAssembly);
}
catch (Exception exception)
{
// ignore the 'Must set an output directory through SetCompileScriptsOutputDirectory before compiling'
// error that seems to happen if this method is called before unity is started completely
NugetLogger.LogVerbose(
"Failed to get assemblies from the compilation pipeline with error: {0}. We ignore the error and try it the next time.",
exception);
projectAssemblies = Array.Empty<Assembly>();
failedToGetAssembliesFromUnity = true;
}

// Collect all referenced assemblies but exclude all assemblies installed by NuGetForUnity.
var projectReferences = projectAssemblies.SelectMany(playerAssembly => playerAssembly.allReferences);
Expand All @@ -101,9 +117,20 @@ private static HashSet<string> GetAlreadyImportedLibs()
// the compiler / language is available by default
alreadyImportedLibs.Add("Microsoft.CSharp");

var editorOnlyAssemblies = CompilationPipeline.GetAssemblies(AssembliesType.Editor)
.Where(assembly => assembly.flags == AssemblyFlags.EditorAssembly)
.ToList();
IEnumerable<Assembly> editorOnlyAssemblies;
try
{
editorOnlyAssemblies = CompilationPipeline.GetAssemblies(AssembliesType.Editor)
.Where(assembly => assembly.flags == AssemblyFlags.EditorAssembly);
}
catch (Exception exception)
{
NugetLogger.LogVerbose(
"Failed to get assemblies from the compilation pipeline with error: {0}. We ignore the error and try it the next time.",
exception);
editorOnlyAssemblies = Array.Empty<Assembly>();
}

alreadyImportedEditorOnlyLibraries = new HashSet<string>();

// com.unity.visualscripting uses .net 4.8 so it implicitly has System.CodeDom
Expand All @@ -116,7 +143,14 @@ private static HashSet<string> GetAlreadyImportedLibs()
NugetLogger.LogVerbose("Already imported libs: {0}", string.Join(", ", alreadyImportedLibs));
NugetLogger.LogVerbose("Already imported editor only libraries: {0}", string.Join(", ", alreadyImportedEditorOnlyLibraries));

return alreadyImportedLibs;
var returnAlreadyImportedLibs = alreadyImportedLibs;
if (failedToGetAssembliesFromUnity)
{
// set to null so it is not cached -> we retry the next time this method is called
alreadyImportedLibs = null;
}

return returnAlreadyImportedLibs;
}
}
}

0 comments on commit f31c8b3

Please sign in to comment.