Skip to content

Commit e990130

Browse files
committed
C#: Rename GeneratedLocation to EmptyLocation and make sure that we always create one such location.
1 parent 5843fdb commit e990130

File tree

3 files changed

+17
-9
lines changed

3 files changed

+17
-9
lines changed

csharp/extractor/Semmle.Extraction.CSharp/Entities/Locations/GeneratedLocation.cs renamed to csharp/extractor/Semmle.Extraction.CSharp/Entities/Locations/EmptyLocation.cs

Lines changed: 8 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -2,11 +2,11 @@
22

33
namespace Semmle.Extraction.CSharp.Entities
44
{
5-
public class GeneratedLocation : SourceLocation
5+
public class EmptyLocation : SourceLocation
66
{
77
private readonly File generatedFile;
88

9-
private GeneratedLocation(Context cx)
9+
private EmptyLocation(Context cx)
1010
: base(cx, null)
1111
{
1212
generatedFile = GeneratedFile.Create(cx);
@@ -26,15 +26,16 @@ public override void WriteId(EscapingTextWriter trapFile)
2626

2727
public override int GetHashCode() => 98732567;
2828

29-
public override bool Equals(object? obj) => obj is not null && obj.GetType() == typeof(GeneratedLocation);
29+
public override bool Equals(object? obj) => obj is not null && obj.GetType() == typeof(EmptyLocation);
3030

31-
public static GeneratedLocation Create(Context cx) => GeneratedLocationFactory.Instance.CreateEntity(cx, typeof(GeneratedLocation), null);
31+
public static EmptyLocation Create(Context cx)
32+
=> EmptyLocationFactory.Instance.CreateEntity(cx, typeof(EmptyLocation), null);
3233

33-
private class GeneratedLocationFactory : CachedEntityFactory<string?, GeneratedLocation>
34+
private class EmptyLocationFactory : CachedEntityFactory<string?, EmptyLocation>
3435
{
35-
public static GeneratedLocationFactory Instance { get; } = new GeneratedLocationFactory();
36+
public static EmptyLocationFactory Instance { get; } = new EmptyLocationFactory();
3637

37-
public override GeneratedLocation Create(Context cx, string? init) => new GeneratedLocation(cx);
38+
public override EmptyLocation Create(Context cx, string? init) => new EmptyLocation(cx);
3839
}
3940
}
4041
}

csharp/extractor/Semmle.Extraction.CSharp/Extractor/Analyser.cs

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -238,6 +238,9 @@ private void DoAnalyseCompilation()
238238

239239
compilationEntity = Entities.Compilation.Create(cx);
240240

241+
// Ensure that the empty location is always created.
242+
Entities.EmptyLocation.Create(cx);
243+
241244
ExtractionContext.CompilationInfos.ForEach(ci => trapWriter.Writer.compilation_info(compilationEntity, ci.key, ci.value));
242245

243246
ReportProgressTaskDone(currentTaskId, assemblyPath, trapWriter.TrapFile, stopwatch.Elapsed, AnalysisAction.Extracted);

csharp/extractor/Semmle.Extraction.CSharp/Extractor/Context.cs

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -550,6 +550,10 @@ public bool Defines(ISymbol symbol) =>
550550
!SymbolEqualityComparer.Default.Equals(symbol, symbol.OriginalDefinition) ||
551551
scope.InScope(symbol);
552552

553+
public bool ExtractLocation(ISymbol symbol) =>
554+
SymbolEqualityComparer.Default.Equals(symbol, symbol.OriginalDefinition) &&
555+
scope.InScope(symbol);
556+
553557
/// <summary>
554558
/// Runs the given action <paramref name="a"/>, guarding for trap duplication
555559
/// based on key <paramref name="key"/>.
@@ -582,14 +586,14 @@ public void WithDuplicationGuard(Key key, Action a)
582586
public Entities.Location CreateLocation()
583587
{
584588
return SourceTree is null
585-
? Entities.GeneratedLocation.Create(this)
589+
? Entities.EmptyLocation.Create(this)
586590
: CreateLocation(Microsoft.CodeAnalysis.Location.Create(SourceTree, Microsoft.CodeAnalysis.Text.TextSpan.FromBounds(0, 0)));
587591
}
588592

589593
public Entities.Location CreateLocation(Microsoft.CodeAnalysis.Location? location)
590594
{
591595
return (location is null || location.Kind == LocationKind.None)
592-
? Entities.GeneratedLocation.Create(this)
596+
? Entities.EmptyLocation.Create(this)
593597
: location.IsInSource
594598
? Entities.NonGeneratedSourceLocation.Create(this, location)
595599
: Entities.Assembly.Create(this, location);

0 commit comments

Comments
 (0)