Skip to content

Conversation

@UlyssesWu
Copy link

public override void OnGUI()
{
EditorGUILayout.LabelField("Roslyn Analyzer", EditorStyles.boldLabel);
DrawAnalyzerReferences();
}
private void DrawAnalyzerReferences()
{
var settings = CsprojModifierSettings.Instance;
if (RoslynAnalyzerUnityEditorNativeSupport.HasRoslynAnalyzerIdeSupport)
{
EditorGUILayout.HelpBox("The current code editor has Roslyn Analyzer IDE support. Roslyn Analyzers are enabled by Unity Editor.", MessageType.Info);
return;
}
settings.EnableAddAnalyzerReferences = EditorGUILayout.ToggleLeft("Add Roslyn Analyzer references to .csproj", settings.EnableAddAnalyzerReferences);
if (settings.EnableAddAnalyzerReferences)
{
using (new EditorGUILayout.VerticalScope(GUI.skin.box))
{
var analyzers = GetAnalyzers();
foreach (var analyzer in analyzers)
{
EditorGUILayout.LabelField(analyzer, EditorStyles.label);
}
}

It's VERY slow to invoke GetAnalyzers() in every OnGUI call, when the project is large.

@github-actions
Copy link
Contributor

github-actions bot commented Nov 9, 2025

This PR is stale because it has been open 180 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the stale label Nov 9, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant