================
@@ -48,22 +64,29 @@ namespace llvm {
     Temporary
   };
 
-  // Extends TrackingMDNodeRef to also store a DebugLocKind, allowing Debugify
-  // to ignore intentionally-empty DebugLocs.
-  class DILocAndCoverageTracking : public TrackingMDNodeRef {
+  // Extends TrackingMDNodeRef to also store a DebugLocKind and Origin,
+  // allowing Debugify to ignore intentionally-empty DebugLocs and display the
+  // code responsible for generating unintentionally-empty DebugLocs.
+  // Currently we only need to track the Origin of this DILoc when using a
+  // DebugLoc that is Normal and empty, so only collect the origin stacktrace 
in
----------------
SLTozer wrote:

I do actually mean "Normal and empty" in this case; it _is_ confusing wording 
that should be cleared up, but essentially a "Normal" DebugLoc type is one that 
hasn't been assigned an annotation; therefore, Normal DebugLocs can either have 
valid DILocations, or they can be empty, representing missing locations without 
an annotation. This could be changed so that we have an explicit Empty enum 
value that gets conditionally set in the DebugLoc constructor, I just didn't do 
that for simplicity (of implementation).

https://github.com/llvm/llvm-project/pull/107369
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to