[Lldb-commits] [libcxx] [lldb] [libcxx] adds size-based `__split_buffer` representation to unstable ABI (PR #139632)
    Louis Dionne via lldb-commits 
    lldb-commits at lists.llvm.org
       
    Mon Aug 18 07:26:01 PDT 2025
    
    
  
================
@@ -65,6 +183,146 @@ public:
   using iterator                       = pointer;
   using const_iterator                 = const_pointer;
 
+public: // TODO: make private after vector becomes size-based
+  pointer __first_  = nullptr;
+  pointer __begin_  = nullptr;
+  size_type __size_ = 0;
+  size_type __cap_  = 0;
+  _LIBCPP_NO_UNIQUE_ADDRESS allocator_type __alloc_;
+
+public:
+  _LIBCPP_CONSTEXPR_SINCE_CXX20 _LIBCPP_HIDE_FROM_ABI __split_buffer_size_layout() = default;
+
+  _LIBCPP_CONSTEXPR_SINCE_CXX20 _LIBCPP_HIDE_FROM_ABI explicit __split_buffer_size_layout(const allocator_type& __alloc)
+      : __alloc_(__alloc) {}
+
+  _LIBCPP_CONSTEXPR_SINCE_CXX20 _LIBCPP_HIDE_FROM_ABI pointer __first() _NOEXCEPT { return __first_; }
+
+  _LIBCPP_CONSTEXPR_SINCE_CXX20 _LIBCPP_HIDE_FROM_ABI const_pointer __first() const _NOEXCEPT { return __first_; }
+
+  _LIBCPP_CONSTEXPR_SINCE_CXX20 _LIBCPP_HIDE_FROM_ABI pointer begin() _NOEXCEPT { return __begin_; }
----------------
ldionne wrote:
I know these names are pre-existing so you're not changing anything (and that's the right thing to do in this patch). But just for the record, we prefer private names for internal functions, so if this were written from scratch we'd prefer naming this `__begin()`.
No changes required, just recording the observation.
https://github.com/llvm/llvm-project/pull/139632
    
    
More information about the lldb-commits
mailing list