2009-12-16 16:44:24 +08:00
|
|
|
//===- llvm/ADT/SmallVector.cpp - 'Normally small' vectors ----------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file implements the SmallVector class.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "llvm/ADT/SmallVector.h"
|
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
/// grow_pod - This is an implementation of the grow() method which only works
|
|
|
|
/// on POD-like datatypes and is out of line to reduce code duplication.
|
2012-08-22 08:11:07 +08:00
|
|
|
void SmallVectorBase::grow_pod(void *FirstEl, size_t MinSizeInBytes,
|
|
|
|
size_t TSize) {
|
2009-12-16 16:44:24 +08:00
|
|
|
size_t CurSizeBytes = size_in_bytes();
|
2010-09-03 05:55:03 +08:00
|
|
|
size_t NewCapacityInBytes = 2 * capacity_in_bytes() + TSize; // Always grow.
|
2009-12-16 16:44:24 +08:00
|
|
|
if (NewCapacityInBytes < MinSizeInBytes)
|
|
|
|
NewCapacityInBytes = MinSizeInBytes;
|
2010-06-08 19:44:30 +08:00
|
|
|
|
|
|
|
void *NewElts;
|
2012-08-22 08:11:07 +08:00
|
|
|
if (BeginX == FirstEl) {
|
2010-06-08 19:44:30 +08:00
|
|
|
NewElts = malloc(NewCapacityInBytes);
|
|
|
|
|
|
|
|
// Copy the elements over. No need to run dtors on PODs.
|
|
|
|
memcpy(NewElts, this->BeginX, CurSizeBytes);
|
|
|
|
} else {
|
|
|
|
// If this wasn't grown from the inline copy, grow the allocated space.
|
|
|
|
NewElts = realloc(this->BeginX, NewCapacityInBytes);
|
|
|
|
}
|
2015-06-09 17:47:46 +08:00
|
|
|
assert(NewElts && "Out of memory");
|
2010-06-08 19:44:30 +08:00
|
|
|
|
2009-12-16 16:44:24 +08:00
|
|
|
this->EndX = (char*)NewElts+CurSizeBytes;
|
|
|
|
this->BeginX = NewElts;
|
|
|
|
this->CapacityX = (char*)this->BeginX + NewCapacityInBytes;
|
|
|
|
}
|