mirror of
https://github.com/YGGverse/xash3d-fwgs.git
synced 2025-01-17 18:40:02 +00:00
vgui_support: switch to free miniutl
This commit is contained in:
parent
6a02a571c1
commit
75643895ef
3
.gitmodules
vendored
3
.gitmodules
vendored
@ -1,3 +1,6 @@
|
|||||||
[submodule "mainui"]
|
[submodule "mainui"]
|
||||||
path = mainui
|
path = mainui
|
||||||
url = https://github.com/FWGS/mainui_cpp
|
url = https://github.com/FWGS/mainui_cpp
|
||||||
|
[submodule "vgui_support/miniutl"]
|
||||||
|
path = vgui_support/miniutl
|
||||||
|
url = https://github.com/FWGS/miniutl
|
||||||
|
1
vgui_support/miniutl
Submodule
1
vgui_support/miniutl
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit c4d1446a973acf80885ab5c0ca0207eb24beca32
|
@ -1,368 +0,0 @@
|
|||||||
//=========== (C) Copyright 1999 Valve, L.L.C. All rights reserved. ===========
|
|
||||||
//
|
|
||||||
// The copyright to the contents herein is the property of Valve, L.L.C.
|
|
||||||
// The contents may be used and/or copied only with the written permission of
|
|
||||||
// Valve, L.L.C., or in accordance with the terms and conditions stipulated in
|
|
||||||
// the agreement/contract under which the contents have been supplied.
|
|
||||||
//
|
|
||||||
// $Header: $
|
|
||||||
// $NoKeywords: $
|
|
||||||
//
|
|
||||||
// A growable memory class.
|
|
||||||
//=============================================================================
|
|
||||||
|
|
||||||
#ifndef UTLMEMORY_H
|
|
||||||
#define UTLMEMORY_H
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#pragma once
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "port.h"
|
|
||||||
#include <string.h>
|
|
||||||
#ifdef NO_STL
|
|
||||||
template <class T>
|
|
||||||
void *operator new(size_t count, T *ptr) {
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
#elif defined _WIN32
|
|
||||||
#include <new.h>
|
|
||||||
#else
|
|
||||||
#include <new>
|
|
||||||
#endif
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Methods to invoke the constructor, copy constructor, and destructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
inline void Construct( T* pMemory )
|
|
||||||
{
|
|
||||||
new( pMemory ) T;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
inline void CopyConstruct( T* pMemory, T const& src )
|
|
||||||
{
|
|
||||||
new( pMemory ) T(src);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
inline void Destruct( T* pMemory )
|
|
||||||
{
|
|
||||||
pMemory->~T();
|
|
||||||
|
|
||||||
#ifdef _DEBUG
|
|
||||||
memset( pMemory, 0xDD, sizeof(T) );
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#pragma warning (disable:4100)
|
|
||||||
#pragma warning (disable:4514)
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// The CUtlMemory class:
|
|
||||||
// A growable memory class which doubles in size by default.
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
class CUtlMemory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// constructor, destructor
|
|
||||||
CUtlMemory( int nGrowSize = 0, int nInitSize = 0 );
|
|
||||||
CUtlMemory( T* pMemory, int numElements );
|
|
||||||
~CUtlMemory();
|
|
||||||
|
|
||||||
// element access
|
|
||||||
T& operator[]( int i );
|
|
||||||
T const& operator[]( int i ) const;
|
|
||||||
T& Element( int i );
|
|
||||||
T const& Element( int i ) const;
|
|
||||||
|
|
||||||
// Can we use this index?
|
|
||||||
bool IsIdxValid( int i ) const;
|
|
||||||
|
|
||||||
// Gets the base address (can change when adding elements!)
|
|
||||||
T* Base();
|
|
||||||
T const* Base() const;
|
|
||||||
|
|
||||||
// Attaches the buffer to external memory....
|
|
||||||
void SetExternalBuffer( T* pMemory, int numElements );
|
|
||||||
|
|
||||||
// Size
|
|
||||||
int NumAllocated() const;
|
|
||||||
int Count() const;
|
|
||||||
|
|
||||||
// Grows the memory, so that at least allocated + num elements are allocated
|
|
||||||
void Grow( int num = 1 );
|
|
||||||
|
|
||||||
// Makes sure we've got at least this much memory
|
|
||||||
void EnsureCapacity( int num );
|
|
||||||
|
|
||||||
// Memory deallocation
|
|
||||||
void Purge();
|
|
||||||
|
|
||||||
// is the memory externally allocated?
|
|
||||||
bool IsExternallyAllocated() const;
|
|
||||||
|
|
||||||
// Set the size by which the memory grows
|
|
||||||
void SetGrowSize( int size );
|
|
||||||
|
|
||||||
private:
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
EXTERNAL_BUFFER_MARKER = -1
|
|
||||||
};
|
|
||||||
|
|
||||||
T* m_pMemory;
|
|
||||||
int m_nAllocationCount;
|
|
||||||
int m_nGrowSize;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// constructor, destructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
CUtlMemory<T>::CUtlMemory( int nGrowSize, int nInitAllocationCount ) : m_pMemory(0),
|
|
||||||
m_nAllocationCount( nInitAllocationCount ), m_nGrowSize( nGrowSize )
|
|
||||||
{
|
|
||||||
Assert( (nGrowSize >= 0) && (nGrowSize != EXTERNAL_BUFFER_MARKER) );
|
|
||||||
if (m_nAllocationCount)
|
|
||||||
{
|
|
||||||
m_pMemory = (T*)malloc( m_nAllocationCount * sizeof(T) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
CUtlMemory<T>::CUtlMemory( T* pMemory, int numElements ) : m_pMemory(pMemory),
|
|
||||||
m_nAllocationCount( numElements )
|
|
||||||
{
|
|
||||||
// Special marker indicating externally supplied memory
|
|
||||||
m_nGrowSize = EXTERNAL_BUFFER_MARKER;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
CUtlMemory<T>::~CUtlMemory()
|
|
||||||
{
|
|
||||||
Purge();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Attaches the buffer to external memory....
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlMemory<T>::SetExternalBuffer( T* pMemory, int numElements )
|
|
||||||
{
|
|
||||||
// Blow away any existing allocated memory
|
|
||||||
Purge();
|
|
||||||
|
|
||||||
m_pMemory = pMemory;
|
|
||||||
m_nAllocationCount = numElements;
|
|
||||||
|
|
||||||
// Indicate that we don't own the memory
|
|
||||||
m_nGrowSize = EXTERNAL_BUFFER_MARKER;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// element access
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline T& CUtlMemory<T>::operator[]( int i )
|
|
||||||
{
|
|
||||||
Assert( IsIdxValid(i) );
|
|
||||||
return m_pMemory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const& CUtlMemory<T>::operator[]( int i ) const
|
|
||||||
{
|
|
||||||
Assert( IsIdxValid(i) );
|
|
||||||
return m_pMemory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T& CUtlMemory<T>::Element( int i )
|
|
||||||
{
|
|
||||||
Assert( IsIdxValid(i) );
|
|
||||||
return m_pMemory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const& CUtlMemory<T>::Element( int i ) const
|
|
||||||
{
|
|
||||||
Assert( IsIdxValid(i) );
|
|
||||||
return m_pMemory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// is the memory externally allocated?
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
bool CUtlMemory<T>::IsExternallyAllocated() const
|
|
||||||
{
|
|
||||||
return m_nGrowSize == EXTERNAL_BUFFER_MARKER;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlMemory<T>::SetGrowSize( int nSize )
|
|
||||||
{
|
|
||||||
Assert( (nSize >= 0) && (nSize != EXTERNAL_BUFFER_MARKER) );
|
|
||||||
m_nGrowSize = nSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Gets the base address (can change when adding elements!)
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline T* CUtlMemory<T>::Base()
|
|
||||||
{
|
|
||||||
return m_pMemory;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const* CUtlMemory<T>::Base() const
|
|
||||||
{
|
|
||||||
return m_pMemory;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Size
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlMemory<T>::NumAllocated() const
|
|
||||||
{
|
|
||||||
return m_nAllocationCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlMemory<T>::Count() const
|
|
||||||
{
|
|
||||||
return m_nAllocationCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Is element index valid?
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline bool CUtlMemory<T>::IsIdxValid( int i ) const
|
|
||||||
{
|
|
||||||
return (i >= 0) && (i < m_nAllocationCount);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Grows the memory
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlMemory<T>::Grow( int num )
|
|
||||||
{
|
|
||||||
Assert( num > 0 );
|
|
||||||
|
|
||||||
if (IsExternallyAllocated())
|
|
||||||
{
|
|
||||||
// Can't grow a buffer whose memory was externally allocated
|
|
||||||
Assert(0);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Make sure we have at least numallocated + num allocations.
|
|
||||||
// Use the grow rules specified for this memory (in m_nGrowSize)
|
|
||||||
int nAllocationRequested = m_nAllocationCount + num;
|
|
||||||
while (m_nAllocationCount < nAllocationRequested)
|
|
||||||
{
|
|
||||||
if ( m_nAllocationCount != 0 )
|
|
||||||
{
|
|
||||||
if (m_nGrowSize)
|
|
||||||
{
|
|
||||||
m_nAllocationCount += m_nGrowSize;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_nAllocationCount += m_nAllocationCount;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Compute an allocation which is at least as big as a cache line...
|
|
||||||
m_nAllocationCount = (31 + sizeof(T)) / sizeof(T);
|
|
||||||
Assert(m_nAllocationCount != 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_pMemory)
|
|
||||||
{
|
|
||||||
T* pTempMemory = ( T* )realloc( m_pMemory, m_nAllocationCount * sizeof( T ) );
|
|
||||||
|
|
||||||
if( !pTempMemory )
|
|
||||||
return;
|
|
||||||
|
|
||||||
m_pMemory = pTempMemory;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_pMemory = (T*)malloc( m_nAllocationCount * sizeof(T) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Makes sure we've got at least this much memory
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline void CUtlMemory<T>::EnsureCapacity( int num )
|
|
||||||
{
|
|
||||||
if (m_nAllocationCount >= num)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (IsExternallyAllocated())
|
|
||||||
{
|
|
||||||
// Can't grow a buffer whose memory was externally allocated
|
|
||||||
Assert(0);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_nAllocationCount = num;
|
|
||||||
if (m_pMemory)
|
|
||||||
{
|
|
||||||
T* pTempMemory = ( T* )realloc( m_pMemory, m_nAllocationCount * sizeof( T ) );
|
|
||||||
|
|
||||||
if( !pTempMemory )
|
|
||||||
return;
|
|
||||||
|
|
||||||
m_pMemory = pTempMemory;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_pMemory = (T*)malloc( m_nAllocationCount * sizeof(T) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Memory deallocation
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlMemory<T>::Purge()
|
|
||||||
{
|
|
||||||
if (!IsExternallyAllocated())
|
|
||||||
{
|
|
||||||
if (m_pMemory)
|
|
||||||
{
|
|
||||||
free( (void*)m_pMemory );
|
|
||||||
m_pMemory = 0;
|
|
||||||
}
|
|
||||||
m_nAllocationCount = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif//UTLMEMORY_H
|
|
File diff suppressed because it is too large
Load Diff
@ -1,605 +0,0 @@
|
|||||||
//=========== (C) Copyright 1999 Valve, L.L.C. All rights reserved. ===========
|
|
||||||
//
|
|
||||||
// The copyright to the contents herein is the property of Valve, L.L.C.
|
|
||||||
// The contents may be used and/or copied only with the written permission of
|
|
||||||
// Valve, L.L.C., or in accordance with the terms and conditions stipulated in
|
|
||||||
// the agreement/contract under which the contents have been supplied.
|
|
||||||
//
|
|
||||||
// $Header: $
|
|
||||||
// $NoKeywords: $
|
|
||||||
//
|
|
||||||
// A growable array class that maintains a free list and keeps elements
|
|
||||||
// in the same location
|
|
||||||
//=============================================================================
|
|
||||||
|
|
||||||
#ifndef UTLVECTOR_H
|
|
||||||
#define UTLVECTOR_H
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#pragma once
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "port.h"
|
|
||||||
#include <string.h>
|
|
||||||
#include "utlmemory.h"
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// The CUtlVector class:
|
|
||||||
// A growable array class which doubles in size by default.
|
|
||||||
// It will always keep all elements consecutive in memory, and may move the
|
|
||||||
// elements around in memory (via a realloc) when elements are inserted or
|
|
||||||
// removed. Clients should therefore refer to the elements of the vector
|
|
||||||
// by index (they should *never* maintain pointers to elements in the vector).
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
class CUtlVector
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef T ElemType_t;
|
|
||||||
|
|
||||||
// constructor, destructor
|
|
||||||
CUtlVector( int growSize = 0, int initSize = 0 );
|
|
||||||
CUtlVector( T* pMemory, int numElements );
|
|
||||||
~CUtlVector();
|
|
||||||
|
|
||||||
// Copy the array.
|
|
||||||
CUtlVector<T>& operator=( const CUtlVector<T> &other );
|
|
||||||
|
|
||||||
// element access
|
|
||||||
T& operator[]( int i );
|
|
||||||
T const& operator[]( int i ) const;
|
|
||||||
T& Element( int i );
|
|
||||||
T const& Element( int i ) const;
|
|
||||||
|
|
||||||
// Gets the base address (can change when adding elements!)
|
|
||||||
T* Base();
|
|
||||||
T const* Base() const;
|
|
||||||
|
|
||||||
// Returns the number of elements in the vector
|
|
||||||
// SIZE IS DEPRECATED!
|
|
||||||
int Count() const;
|
|
||||||
int Size() const; // don't use me!
|
|
||||||
|
|
||||||
// Is element index valid?
|
|
||||||
bool IsValidIndex( int i ) const;
|
|
||||||
static int InvalidIndex( void );
|
|
||||||
|
|
||||||
// Adds an element, uses default constructor
|
|
||||||
int AddToHead();
|
|
||||||
int AddToTail();
|
|
||||||
int InsertBefore( int elem );
|
|
||||||
int InsertAfter( int elem );
|
|
||||||
|
|
||||||
// Adds an element, uses copy constructor
|
|
||||||
int AddToHead( T const& src );
|
|
||||||
int AddToTail( T const& src );
|
|
||||||
int InsertBefore( int elem, T const& src );
|
|
||||||
int InsertAfter( int elem, T const& src );
|
|
||||||
|
|
||||||
// Adds multiple elements, uses default constructor
|
|
||||||
int AddMultipleToHead( int num );
|
|
||||||
int AddMultipleToTail( int num, const T *pToCopy=NULL );
|
|
||||||
int InsertMultipleBefore( int elem, int num, const T *pToCopy=NULL ); // If pToCopy is set, then it's an array of length 'num' and
|
|
||||||
int InsertMultipleAfter( int elem, int num );
|
|
||||||
|
|
||||||
// Calls RemoveAll() then AddMultipleToTail.
|
|
||||||
void SetSize( int size );
|
|
||||||
void SetCount( int count );
|
|
||||||
|
|
||||||
// Calls SetSize and copies each element.
|
|
||||||
void CopyArray( T const *pArray, int size );
|
|
||||||
|
|
||||||
// Add the specified array to the tail.
|
|
||||||
int AddVectorToTail( CUtlVector<T> const &src );
|
|
||||||
|
|
||||||
// Finds an element (element needs operator== defined)
|
|
||||||
int Find( T const& src ) const;
|
|
||||||
|
|
||||||
bool HasElement( T const& src );
|
|
||||||
|
|
||||||
// Makes sure we have enough memory allocated to store a requested # of elements
|
|
||||||
void EnsureCapacity( int num );
|
|
||||||
|
|
||||||
// Makes sure we have at least this many elements
|
|
||||||
void EnsureCount( int num );
|
|
||||||
|
|
||||||
// Element removal
|
|
||||||
void FastRemove( int elem ); // doesn't preserve order
|
|
||||||
void Remove( int elem ); // preserves order, shifts elements
|
|
||||||
void FindAndRemove( T const& src ); // removes first occurrence of src, preserves order, shifts elements
|
|
||||||
void RemoveMultiple( int elem, int num ); // preserves order, shifts elements
|
|
||||||
void RemoveAll(); // doesn't deallocate memory
|
|
||||||
|
|
||||||
// Memory deallocation
|
|
||||||
void Purge();
|
|
||||||
|
|
||||||
// Purges the list and calls delete on each element in it.
|
|
||||||
void PurgeAndDeleteElements();
|
|
||||||
|
|
||||||
// Set the size by which it grows when it needs to allocate more memory.
|
|
||||||
void SetGrowSize( int size );
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// Can't copy this unless we explicitly do it!
|
|
||||||
CUtlVector( CUtlVector const& vec ) { Assert(0); }
|
|
||||||
|
|
||||||
// Grows the vector
|
|
||||||
void GrowVector( int num = 1 );
|
|
||||||
|
|
||||||
// Shifts elements....
|
|
||||||
void ShiftElementsRight( int elem, int num = 1 );
|
|
||||||
void ShiftElementsLeft( int elem, int num = 1 );
|
|
||||||
|
|
||||||
// For easier access to the elements through the debugger
|
|
||||||
void ResetDbgInfo();
|
|
||||||
|
|
||||||
CUtlMemory<T> m_Memory;
|
|
||||||
int m_Size;
|
|
||||||
|
|
||||||
// For easier access to the elements through the debugger
|
|
||||||
// it's in release builds so this can be used in libraries correctly
|
|
||||||
T *m_pElements;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// For easier access to the elements through the debugger
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline void CUtlVector<T>::ResetDbgInfo()
|
|
||||||
{
|
|
||||||
m_pElements = m_Memory.Base();
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// constructor, destructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline CUtlVector<T>::CUtlVector( int growSize, int initSize ) :
|
|
||||||
m_Memory(growSize, initSize), m_Size(0)
|
|
||||||
{
|
|
||||||
ResetDbgInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline CUtlVector<T>::CUtlVector( T* pMemory, int numElements ) :
|
|
||||||
m_Memory(pMemory, numElements), m_Size(0)
|
|
||||||
{
|
|
||||||
ResetDbgInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline CUtlVector<T>::~CUtlVector()
|
|
||||||
{
|
|
||||||
Purge();
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class T>
|
|
||||||
inline CUtlVector<T>& CUtlVector<T>::operator=( const CUtlVector<T> &other )
|
|
||||||
{
|
|
||||||
CopyArray( other.Base(), other.Count() );
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// element access
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T& CUtlVector<T>::operator[]( int i )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(i) );
|
|
||||||
return m_Memory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const& CUtlVector<T>::operator[]( int i ) const
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(i) );
|
|
||||||
return m_Memory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T& CUtlVector<T>::Element( int i )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(i) );
|
|
||||||
return m_Memory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const& CUtlVector<T>::Element( int i ) const
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(i) );
|
|
||||||
return m_Memory[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Gets the base address (can change when adding elements!)
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T* CUtlVector<T>::Base()
|
|
||||||
{
|
|
||||||
return m_Memory.Base();
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline T const* CUtlVector<T>::Base() const
|
|
||||||
{
|
|
||||||
return m_Memory.Base();
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Count
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::Size() const
|
|
||||||
{
|
|
||||||
return m_Size;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::Count() const
|
|
||||||
{
|
|
||||||
return m_Size;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Is element index valid?
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline bool CUtlVector<T>::IsValidIndex( int i ) const
|
|
||||||
{
|
|
||||||
return (i >= 0) && (i < m_Size);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Returns in invalid index
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::InvalidIndex( void )
|
|
||||||
{
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Grows the vector
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::GrowVector( int num )
|
|
||||||
{
|
|
||||||
if (m_Size + num - 1 >= m_Memory.NumAllocated())
|
|
||||||
{
|
|
||||||
m_Memory.Grow( m_Size + num - m_Memory.NumAllocated() );
|
|
||||||
}
|
|
||||||
|
|
||||||
m_Size += num;
|
|
||||||
ResetDbgInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Makes sure we have enough memory allocated to store a requested # of elements
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::EnsureCapacity( int num )
|
|
||||||
{
|
|
||||||
m_Memory.EnsureCapacity(num);
|
|
||||||
ResetDbgInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Makes sure we have at least this many elements
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::EnsureCount( int num )
|
|
||||||
{
|
|
||||||
if (Count() < num)
|
|
||||||
AddMultipleToTail( num - Count() );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Shifts elements
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::ShiftElementsRight( int elem, int num )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(elem) || ( m_Size == 0 ) || ( num == 0 ));
|
|
||||||
int numToMove = m_Size - elem - num;
|
|
||||||
if ((numToMove > 0) && (num > 0))
|
|
||||||
memmove( &Element(elem+num), &Element(elem), numToMove * sizeof(T) );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::ShiftElementsLeft( int elem, int num )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(elem) || ( m_Size == 0 ) || ( num == 0 ));
|
|
||||||
int numToMove = m_Size - elem - num;
|
|
||||||
if ((numToMove > 0) && (num > 0))
|
|
||||||
{
|
|
||||||
memmove( &Element(elem), &Element(elem+num), numToMove * sizeof(T) );
|
|
||||||
|
|
||||||
#ifdef _DEBUG
|
|
||||||
memset( &Element(m_Size-num), 0xDD, num * sizeof(T) );
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Adds an element, uses default constructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddToHead()
|
|
||||||
{
|
|
||||||
return InsertBefore(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddToTail()
|
|
||||||
{
|
|
||||||
return InsertBefore( m_Size );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::InsertAfter( int elem )
|
|
||||||
{
|
|
||||||
return InsertBefore( elem + 1 );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
int CUtlVector<T>::InsertBefore( int elem )
|
|
||||||
{
|
|
||||||
// Can insert at the end
|
|
||||||
Assert( (elem == Count()) || IsValidIndex(elem) );
|
|
||||||
|
|
||||||
GrowVector();
|
|
||||||
ShiftElementsRight(elem);
|
|
||||||
Construct( &Element(elem) );
|
|
||||||
return elem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Adds an element, uses copy constructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddToHead( T const& src )
|
|
||||||
{
|
|
||||||
return InsertBefore( 0, src );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddToTail( T const& src )
|
|
||||||
{
|
|
||||||
return InsertBefore( m_Size, src );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::InsertAfter( int elem, T const& src )
|
|
||||||
{
|
|
||||||
return InsertBefore( elem + 1, src );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
int CUtlVector<T>::InsertBefore( int elem, T const& src )
|
|
||||||
{
|
|
||||||
// Can insert at the end
|
|
||||||
Assert( (elem == Count()) || IsValidIndex(elem) );
|
|
||||||
|
|
||||||
GrowVector();
|
|
||||||
ShiftElementsRight(elem);
|
|
||||||
CopyConstruct( &Element(elem), src );
|
|
||||||
return elem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Adds multiple elements, uses default constructor
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddMultipleToHead( int num )
|
|
||||||
{
|
|
||||||
return InsertMultipleBefore( 0, num );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::AddMultipleToTail( int num, const T *pToCopy )
|
|
||||||
{
|
|
||||||
return InsertMultipleBefore( m_Size, num, pToCopy );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
int CUtlVector<T>::InsertMultipleAfter( int elem, int num )
|
|
||||||
{
|
|
||||||
return InsertMultipleBefore( elem + 1, num );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::SetCount( int count )
|
|
||||||
{
|
|
||||||
RemoveAll();
|
|
||||||
AddMultipleToTail( count );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline void CUtlVector<T>::SetSize( int size )
|
|
||||||
{
|
|
||||||
SetCount( size );
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::CopyArray( T const *pArray, int size )
|
|
||||||
{
|
|
||||||
SetSize( size );
|
|
||||||
for( int i=0; i < size; i++ )
|
|
||||||
(*this)[i] = pArray[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
int CUtlVector<T>::AddVectorToTail( CUtlVector const &src )
|
|
||||||
{
|
|
||||||
int base = Count();
|
|
||||||
|
|
||||||
// Make space.
|
|
||||||
AddMultipleToTail( src.Count() );
|
|
||||||
|
|
||||||
// Copy the elements.
|
|
||||||
for ( int i=0; i < src.Count(); i++ )
|
|
||||||
(*this)[base + i] = src[i];
|
|
||||||
|
|
||||||
return base;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
inline int CUtlVector<T>::InsertMultipleBefore( int elem, int num, const T *pToInsert )
|
|
||||||
{
|
|
||||||
if( num == 0 )
|
|
||||||
return elem;
|
|
||||||
|
|
||||||
// Can insert at the end
|
|
||||||
Assert( (elem == Count()) || IsValidIndex(elem) );
|
|
||||||
|
|
||||||
GrowVector(num);
|
|
||||||
ShiftElementsRight(elem, num);
|
|
||||||
|
|
||||||
// Invoke default constructors
|
|
||||||
for (int i = 0; i < num; ++i)
|
|
||||||
Construct( &Element(elem+i) );
|
|
||||||
|
|
||||||
// Copy stuff in?
|
|
||||||
if ( pToInsert )
|
|
||||||
{
|
|
||||||
for ( int i=0; i < num; i++ )
|
|
||||||
{
|
|
||||||
Element( elem+i ) = pToInsert[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return elem;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Finds an element (element needs operator== defined)
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
template< class T >
|
|
||||||
int CUtlVector<T>::Find( T const& src ) const
|
|
||||||
{
|
|
||||||
for ( int i = 0; i < Count(); ++i )
|
|
||||||
{
|
|
||||||
if (Element(i) == src)
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
bool CUtlVector<T>::HasElement( T const& src )
|
|
||||||
{
|
|
||||||
return ( Find(src) >= 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Element removal
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::FastRemove( int elem )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(elem) );
|
|
||||||
|
|
||||||
Destruct( &Element(elem) );
|
|
||||||
if (m_Size > 0)
|
|
||||||
{
|
|
||||||
memcpy( &Element(elem), &Element(m_Size-1), sizeof(T) );
|
|
||||||
--m_Size;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::Remove( int elem )
|
|
||||||
{
|
|
||||||
Destruct( &Element(elem) );
|
|
||||||
ShiftElementsLeft(elem);
|
|
||||||
--m_Size;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::FindAndRemove( T const& src )
|
|
||||||
{
|
|
||||||
int elem = Find( src );
|
|
||||||
if ( elem != -1 )
|
|
||||||
{
|
|
||||||
Remove( elem );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::RemoveMultiple( int elem, int num )
|
|
||||||
{
|
|
||||||
Assert( IsValidIndex(elem) );
|
|
||||||
Assert( elem + num <= Count() );
|
|
||||||
|
|
||||||
for (int i = elem + num; --i >= elem; )
|
|
||||||
Destruct(&Element(i));
|
|
||||||
|
|
||||||
ShiftElementsLeft(elem, num);
|
|
||||||
m_Size -= num;
|
|
||||||
}
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::RemoveAll()
|
|
||||||
{
|
|
||||||
for (int i = m_Size; --i >= 0; )
|
|
||||||
Destruct(&Element(i));
|
|
||||||
|
|
||||||
m_Size = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Memory deallocation
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::Purge()
|
|
||||||
{
|
|
||||||
RemoveAll();
|
|
||||||
m_Memory.Purge( );
|
|
||||||
ResetDbgInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<class T>
|
|
||||||
inline void CUtlVector<T>::PurgeAndDeleteElements()
|
|
||||||
{
|
|
||||||
for( int i=0; i < m_Size; i++ )
|
|
||||||
delete Element(i);
|
|
||||||
|
|
||||||
Purge();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template< class T >
|
|
||||||
void CUtlVector<T>::SetGrowSize( int size )
|
|
||||||
{
|
|
||||||
m_Memory.SetGrowSize( size );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif//UTLVECTOR_H
|
|
@ -25,8 +25,6 @@ from your version.
|
|||||||
#ifndef VGUI_MAIN_H
|
#ifndef VGUI_MAIN_H
|
||||||
#define VGUI_MAIN_H
|
#define VGUI_MAIN_H
|
||||||
|
|
||||||
#define Assert(x)
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#else
|
#else
|
||||||
|
@ -86,9 +86,9 @@ def build(bld):
|
|||||||
|
|
||||||
libs.append('VGUI')
|
libs.append('VGUI')
|
||||||
|
|
||||||
source = bld.path.ant_glob(['*.cpp'])
|
source = bld.path.ant_glob(['*.cpp', 'miniutl/utlvector.cpp', 'miniutl/utlmemory.cpp'])
|
||||||
|
|
||||||
includes = [ '.', '../common', '../engine' ]
|
includes = [ '.', 'miniutl/', '../common', '../engine' ]
|
||||||
|
|
||||||
bld.shlib(
|
bld.shlib(
|
||||||
source = source,
|
source = source,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user