From 95795788535725e9840bd243f662d416e998023f Mon Sep 17 00:00:00 2001 From: Elizabeth Worstell Date: Wed, 10 Jul 2024 13:13:05 -0700 Subject: [PATCH] fix: transitive type loop --- go-runtime/schema/transitive/analyzer.go | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/go-runtime/schema/transitive/analyzer.go b/go-runtime/schema/transitive/analyzer.go index 030bba4e08..c7b44d0d0b 100644 --- a/go-runtime/schema/transitive/analyzer.go +++ b/go-runtime/schema/transitive/analyzer.go @@ -29,7 +29,12 @@ type Fact = common.DefaultFact[Tag] // common.NeedsExtraction. This allows us to identify objects for extraction that are not explicitly // annotated with an FTL directive. func Extract(pass *analysis.Pass) (interface{}, error) { - needsExtraction := getNeedsExtraction(pass, common.MergeAllFacts(pass)) + needsExtraction := sets.NewSet[types.Object]() + for obj, fact := range common.MergeAllFacts(pass) { + if _, ok := fact.Get().(*common.NeedsExtraction); ok { + needsExtraction.Add(obj) + } + } for !needsExtraction.IsEmpty() { extractTransitive(pass, needsExtraction) needsExtraction = refreshNeedsExtraction(pass) @@ -38,25 +43,17 @@ func Extract(pass *analysis.Pass) (interface{}, error) { } func refreshNeedsExtraction(pass *analysis.Pass) sets.Set[types.Object] { - facts := make(map[types.Object]common.SchemaFact) + facts := sets.NewSet[types.Object]() for _, fact := range pass.AllObjectFacts() { f, ok := fact.Fact.(common.SchemaFact) if !ok { continue } - facts[fact.Object] = f - } - return getNeedsExtraction(pass, facts) -} - -func getNeedsExtraction(pass *analysis.Pass, facts map[types.Object]common.SchemaFact) sets.Set[types.Object] { - needsExtraction := sets.NewSet[types.Object]() - for obj, fact := range facts { - if _, ok := fact.Get().(*common.NeedsExtraction); ok && obj.Pkg().Path() == pass.Pkg.Path() { - needsExtraction.Add(obj) + if _, ok := f.Get().(*common.NeedsExtraction); ok && fact.Object.Pkg().Path() == pass.Pkg.Path() { + facts.Add(fact.Object) } } - return needsExtraction + return facts } func extractTransitive(pass *analysis.Pass, needsExtraction sets.Set[types.Object]) {