forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
| //===- 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.
 | |
| void SmallVectorBase::grow_pod(void *FirstEl, size_t MinSizeInBytes,
 | |
|                                size_t TSize) {
 | |
|   size_t CurSizeBytes = size_in_bytes();
 | |
|   size_t NewCapacityInBytes = 2 * capacity_in_bytes() + TSize; // Always grow.
 | |
|   if (NewCapacityInBytes < MinSizeInBytes)
 | |
|     NewCapacityInBytes = MinSizeInBytes;
 | |
| 
 | |
|   void *NewElts;
 | |
|   if (BeginX == FirstEl) {
 | |
|     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);
 | |
|   }
 | |
| 
 | |
|   this->EndX = (char*)NewElts+CurSizeBytes;
 | |
|   this->BeginX = NewElts;
 | |
|   this->CapacityX = (char*)this->BeginX + NewCapacityInBytes;
 | |
| }
 |