Export of internal Abseil changes.
-- ab1a58c85a462884413ec0022dc1fff19ccb8602 by Abseil Team <absl-team@google.com>: Clarified the documentation in str_format.h to say that use of absl::FormatSpec is ok for wrapper functions. Added tests that express this. PiperOrigin-RevId: 247657991 -- fef9481e58d579f1514babcb960ca60a51883fd8 by CJ Johnson <johnsoncj@google.com>: Adds exception safety tests for InlinedVector::InlinedVector() and InlinedVector::InlinedVector(const allocator_type&). PiperOrigin-RevId: 247617048 -- ef3217e1cd1e9a6ff5f2025e061b8ce3735af78f by Abseil Team <absl-team@google.com>: Internal change. PiperOrigin-RevId: 247614063 -- ed4c3345c4a04d8ec5c9e627058f17fce55925b1 by CJ Johnson <johnsoncj@google.com>: Update InlinedVector::clear() Introduces inlined_vector_exception_safety_test with the first test (clear), adds new benchmarks (for clear), and updates the implementation of clear. PiperOrigin-RevId: 247496049 -- 144a3a77c93bc8b2226da6f4b56166ee3d9868de by Derek Mauro <dmauro@google.com>: Internal change PiperOrigin-RevId: 247482532 -- 286bbb89e154d5424955b644edad5fe04be487f8 by Derek Mauro <dmauro@google.com>: Add scripts to run ASAN and TSAN on CI. PiperOrigin-RevId: 247479658 GitOrigin-RevId: ab1a58c85a462884413ec0022dc1fff19ccb8602 Change-Id: Ief4c5a62587d0c59d405735df469d498aa6bf101
This commit is contained in:
parent
27c2f6e2f3
commit
0cbdc774b9
18 changed files with 422 additions and 36 deletions
|
|
@ -784,16 +784,20 @@ class InlinedVector {
|
|||
// Destroys all elements in the inlined vector, sets the size of `0` and
|
||||
// deallocates the heap allocation if the inlined vector was allocated.
|
||||
void clear() noexcept {
|
||||
size_type s = size();
|
||||
if (storage_.GetIsAllocated()) {
|
||||
Destroy(storage_.GetAllocatedData(), storage_.GetAllocatedData() + s);
|
||||
AllocatorTraits::deallocate(storage_.GetAllocator(),
|
||||
storage_.GetAllocatedData(),
|
||||
const bool is_allocated = storage_.GetIsAllocated();
|
||||
|
||||
pointer the_data =
|
||||
is_allocated ? storage_.GetAllocatedData() : storage_.GetInlinedData();
|
||||
|
||||
inlined_vector_internal::DestroyElements(storage_.GetAllocator(), the_data,
|
||||
storage_.GetSize());
|
||||
|
||||
if (is_allocated) {
|
||||
AllocatorTraits::deallocate(storage_.GetAllocator(), the_data,
|
||||
storage_.GetAllocatedCapacity());
|
||||
} else if (s != 0) { // do nothing for empty vectors
|
||||
Destroy(storage_.GetInlinedData(), storage_.GetInlinedData() + s);
|
||||
}
|
||||
storage_.SetInlinedSize(0);
|
||||
|
||||
storage_.SetInlinedSize(/* size = */ 0);
|
||||
}
|
||||
|
||||
// `InlinedVector::reserve()`
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue