[llvm] [CodeLayout][NFC] Using MergedVector to avoid extra vector allocations (PR #68724)

via llvm-commits llvm-commits at lists.llvm.org
Wed Oct 11 13:26:36 PDT 2023


================
@@ -516,34 +518,62 @@ struct MergedChain {
   NodeIter End3;
 };
 
+/// A wrapper around two concatenated vectors (chains) of jumps.
+struct MergedJumpsT {
+  using JumpIter = std::vector<JumpT *>::const_iterator;
+
+  MergedJumpsT(JumpIter Begin, JumpIter End) : Begin1(Begin), End1(End) {}
+
+  template <typename F> void forEach(const F &Func) const {
+    for (auto It = Begin1; It != End1; It++)
+      Func(*It);
+    for (auto It = Begin2; It != End2; It++)
+      Func(*It);
+  }
+
+  bool empty() const { return Begin1 == End1; }
+
+  void append(JumpIter Begin, JumpIter End) {
+    assert(Begin2 == End2 && "cannot extend MergedJumpsT");
+    Begin2 = Begin;
+    End2 = End;
+  }
+
+private:
+  JumpIter Begin1;
----------------
spupyrev wrote:

Wouldn't `std::array<std::vector<JumpT *>, 2>` instantiate the vector during construction? That's exactly what I want to avoid. Or did you mean `std::array<std::pair<JumpIter, JumpIter>, 2>`?

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


More information about the llvm-commits mailing list