mirror of
https://github.com/libretro/RetroArch
synced 2025-01-07 13:10:20 +00:00
88 lines
2.1 KiB
C++
88 lines
2.1 KiB
C++
|
#ifndef _BASE_H_
|
||
|
#define _BASE_H_
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
#include <string.h>
|
||
|
#include <new>
|
||
|
|
||
|
namespace RGL
|
||
|
{
|
||
|
class Base
|
||
|
{
|
||
|
public:
|
||
|
void * operator new( size_t size ) { return malloc( size ); }
|
||
|
void * operator new( size_t /*size*/, void *p ) { return p; }
|
||
|
void operator delete( void *ptr ) { return free( ptr ); }
|
||
|
void operator delete( void * /*ptr*/, void * /*p*/ ) { }};
|
||
|
|
||
|
template<class T> class Vector: public Base
|
||
|
{
|
||
|
T* array;
|
||
|
unsigned int count;
|
||
|
unsigned int capacity;
|
||
|
unsigned int increment;
|
||
|
public:
|
||
|
Vector(): array( 0 ), count( 0 ), capacity( 0 ), increment( 4 ) {}
|
||
|
~Vector() { clear(); reallocArray( 0 ); }
|
||
|
|
||
|
inline unsigned int getCount() { return count; }
|
||
|
|
||
|
inline void reallocArray( unsigned int newCapacity )
|
||
|
{
|
||
|
if ( newCapacity == capacity ) return;
|
||
|
if ( newCapacity > capacity ) newCapacity = ( newCapacity > capacity + increment ) ? newCapacity : ( capacity + increment );
|
||
|
if ( newCapacity == 0 )
|
||
|
{
|
||
|
free( array );
|
||
|
array = 0;
|
||
|
}
|
||
|
else array = static_cast<T*>( realloc( static_cast<void *>( array ), sizeof( T ) * newCapacity ) );
|
||
|
capacity = newCapacity;
|
||
|
}
|
||
|
|
||
|
inline void clear()
|
||
|
{
|
||
|
if ( !array ) return;
|
||
|
for ( unsigned int i = 0;i < count;++i )( array + i )->~T();
|
||
|
count = 0;
|
||
|
}
|
||
|
|
||
|
inline unsigned int pushBack( const T &element )
|
||
|
{
|
||
|
if ( count + 1 > capacity )
|
||
|
reallocArray( count + 1 );
|
||
|
new(( void * )( array + count ) ) T( element );
|
||
|
return ++count;
|
||
|
}
|
||
|
|
||
|
inline unsigned int appendUnique( const T &element )
|
||
|
{
|
||
|
for ( unsigned int i = 0;i < count;++i ) if ( array[i] == element ) return i;
|
||
|
return pushBack( element );
|
||
|
}
|
||
|
|
||
|
inline void removeElement( const T &element )
|
||
|
{
|
||
|
for ( unsigned int i = count; i > 0; --i )
|
||
|
{
|
||
|
if ( array[i-1] == element )
|
||
|
{
|
||
|
remove( i - 1 );
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
inline void remove( unsigned int index )
|
||
|
{
|
||
|
( array + index )->~T();
|
||
|
--count;
|
||
|
if ( count > index ) memmove( array + index, array + index + 1, ( count - index )*sizeof( T ) );
|
||
|
}
|
||
|
|
||
|
inline T& operator []( int i ) const { return array[i]; }
|
||
|
};
|
||
|
}
|
||
|
|
||
|
#endif
|