* vector placement is made at the first empty or hole slot following
* the hashcode index.
*/
-static unsigned long integeritem_hashcode(itemkeyfun *this,void *key) {
+static unsigned long integeritem_hashcode(void *this,void *key) {
return (unsigned long) key;
}
* This callback function determines whether an item has a
* given key or not.
*/
-static int integeritem_haskey(itemkeyfun *this,void *item,void *key) {
+static int integeritem_haskey(void *this,void *item,void *key) {
return item == key;
}
* This callback function returns the key of an item by considering
* the arity and schema.
*/
-static void *integeritem_itemkey(itemkeyfun *this,void *item) {
+static void *integeritem_itemkey(void *this,void *item) {
return item;
}
* This callback function handles a key obtained from the itemkey
* callback function to reclaim temporary allocation.
*/
-static void integeritem_releasekey(itemkeyfun *this,void *key) {
+static void integeritem_releasekey(void *this,void *key) {
+}
+
+/**
+ * This callback function writes a representation of an item into
+ * a character buffer.
+ */
+static int integeritem_tostring(void *this,void *item,char *buffer,int limit) {
+ return snprintf( buffer, limit, "%lld", (long long) item );
}
itemkeyfun integeritem = {
.hashcode = integeritem_hashcode,
.haskey = integeritem_haskey,
.itemkey = integeritem_itemkey,
- .releasekey = integeritem_releasekey
+ .releasekey = integeritem_releasekey,
+ .tostring = integeritem_tostring
};