diff options
Diffstat (limited to 'tools/MakeDef/tnsrtcol.cpp')
-rw-r--r-- | tools/MakeDef/tnsrtcol.cpp | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/tools/MakeDef/tnsrtcol.cpp b/tools/MakeDef/tnsrtcol.cpp new file mode 100644 index 0000000000..b614f8388b --- /dev/null +++ b/tools/MakeDef/tnsrtcol.cpp @@ -0,0 +1,78 @@ +#include <stdio.h>
+#include <string.h>
+
+#include "h_collection.h"
+
+HSortedCollection::HSortedCollection( ccIndex aLimit, ccIndex aDelta ) :
+ HCollection( aLimit, aDelta ),
+ duplicates( false )
+{
+}
+
+int HSortedCollection::compare( const void *key1, const void *key2 ) const
+{
+ return strcmp(( const char* )key1, ( const char* )key2 );
+}
+
+ccIndex HSortedCollection::indexOf( const void *item )
+{
+ ccIndex i;
+
+ if ( search( keyOf( item ), i ) == false )
+ return ccNotFound;
+
+ if ( duplicates )
+ while( i < count && item != items[i] )
+ i++;
+
+ return ( i < count ) ? i : ccNotFound;
+}
+
+bool HSortedCollection::insert( void* item )
+{
+ ccIndex i;
+ if ( search( keyOf( item ), i ) == 0 || duplicates )
+ return atInsert( i, item );
+
+ return false;
+}
+
+const void* HSortedCollection::keyOf( const void* item ) const
+{
+ return item;
+}
+
+void* HSortedCollection::search( const void* key )
+{
+ ccIndex temp;
+
+ if ( search( key, temp ) == false )
+ return 0;
+
+ return items[ temp ];
+}
+
+bool HSortedCollection::search( const void* key, ccIndex& index )
+{
+ ccIndex l = 0;
+ ccIndex h = count - 1;
+ bool res = false;
+
+ while( l <= h )
+ { ccIndex i = ( l+h )/2;
+
+ int c = compare( keyOf( items[ i ] ), key );
+ if ( c < 0 )
+ l = i + 1;
+ else
+ { h = i - 1;
+ if ( c == 0 )
+ { res = true;
+ lastItem = i;
+ if ( !duplicates )
+ l = i;
+ } } }
+
+ index = l;
+ return res;
+}
|