imAttribTable Class Reference
[Utilities]
Detailed Description
- All the attributes have a name, a type, a count and the data.
Names are usually strings with less that 30 chars.
- Attributes are stored in a hash table for fast access.
We use the hash function described in "The Pratice of Programming" of Kernighan & Pike.
Public Member Functions | |
imAttribTable (int hash_size) | |
~imAttribTable () | |
int | Count () const |
void | RemoveAll () |
void | CopyFrom (const imAttribTable &table) |
void | Set (const char *name, int data_type, int count, const void *data) |
void | UnSet (const char *name) |
const void * | Get (const char *name, int *data_type=0, int *count=0) const |
void | ForEach (void *user_data, imAttribTableCallback attrib_func) const |
Constructor & Destructor Documentation
|
Creates an empty table. If size is zero the default size of 101 is used. Size must be a prime number. Other common values are 67, 599 and 1499. 00031 { ptable = imAttribTableCreate(hash_size); }
|
|
Destroys the table and all the attributes. 00035 { imAttribTableDestroy(ptable); ptable = 0; }
|
Member Function Documentation
|
Returns the number of elements in the table. 00039 { return imAttribTableCount(ptable); }
|
|
Removes all the attributes in the table 00043 { imAttribTableRemoveAll(ptable); }
|
|
Copies the contents of the given table into this table. 00047 { imAttribTableCopyFrom(ptable, table.ptable); }
|
|
Inserts an attribute into the table. 00052 { imAttribTableSet(ptable, name, data_type, count, data); }
|
|
Removes an attribute from the table given its name. 00056 { imAttribTableUnSet(ptable, name); }
|
|
Finds an attribute in the table. Returns the attribute if found, NULL otherwise. 00061 { return imAttribTableGet(ptable, name, data_type, count); }
|
|
For each attribute calls the user callback. If the callback returns 0 the function returns. 00065 { imAttribTableForEach(ptable, user_data, attrib_func); }
|
The documentation for this class was generated from the following file: