[clang] [clang-tools-extra] [Clang] [C2y] Implement N3355 ‘NamedLoops’ (PR #152870)

Erich Keane via cfe-commits cfe-commits at lists.llvm.org
Tue Sep 2 07:40:35 PDT 2025


================
@@ -3056,26 +3045,51 @@ class IndirectGotoStmt : public Stmt {
   }
 };
 
-/// ContinueStmt - This represents a continue.
-class ContinueStmt : public Stmt {
-public:
-  ContinueStmt(SourceLocation CL) : Stmt(ContinueStmtClass) {
-    setContinueLoc(CL);
+/// Base class for BreakStmt and ContinueStmt.
+class LoopControlStmt : public Stmt {
+  /// If this is a labeled break/continue, the label whose statement we're
+  /// targeting.
+  LabelDecl *TargetLabel = nullptr;
+
+  /// Location of the label, if any.
+  SourceLocation Label;
+
+protected:
+  LoopControlStmt(StmtClass Class, SourceLocation Loc) : Stmt(Class) {
+    setKwLoc(Loc);
   }
 
-  /// Build an empty continue statement.
-  explicit ContinueStmt(EmptyShell Empty) : Stmt(ContinueStmtClass, Empty) {}
+  LoopControlStmt(StmtClass Class, SourceLocation Loc, SourceLocation LabelLoc,
+                  LabelDecl *Target)
+      : LoopControlStmt(Class, Loc) {
+    setLabelLoc(LabelLoc);
----------------
erichkeane wrote:

Ah, right.  In that case, I'd suggest reversing the delegation (which is USUALLY how it works for readability, you want the one with the most arguments doing all the initialization).

https://github.com/llvm/llvm-project/pull/152870


More information about the cfe-commits mailing list