added tostring callback
authorRalph Ronnquist <ralph.ronnquist@gmail.com>
Sat, 9 Jul 2022 09:30:55 +0000 (19:30 +1000)
committerRalph Ronnquist <ralph.ronnquist@gmail.com>
Sat, 9 Jul 2022 09:30:55 +0000 (19:30 +1000)
vector/integeritem.c
vector/itemkeyfun.h
vector/stringitem.c
vector/tupleitem.c

index 6e6ac04659966c73c62a07410a722603f592e623..ae4db929ae95c4bd358ac516e111864641bb38fe 100644 (file)
@@ -36,9 +36,18 @@ static void *integeritem_itemkey(void *this,void *item) {
 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
 };
index 1089a163fbb3876f5cbd3945c0c9a07abd418d1c..7bbe62579d4313045aa1591ee44a27b692834010 100644 (file)
@@ -1,6 +1,8 @@
 #ifndef itemkeyfun_H
 #define itemkeyfun_H
 
+#include <stdio.h>
+
 /**
  * \struct itemkeyfun
  *
@@ -48,6 +50,12 @@ typedef struct {
      */
     void (*releasekey)(SELF,void *key);
 
+    /**
+     * This callback function writes a representation of an item into
+     * a character buffer.
+     */
+    int (*tostring)(SELF,void *item,char *buffer,int limit);
+
 #undef SELF
 } itemkeyfun;
 
index db400cebc8f33c54b5a126277dd7971f17446a2a..d53576dd540f62ff6832af3b265de6271339af94 100644 (file)
@@ -38,9 +38,21 @@ static void *stringitem_itemkey(void *this,void *item) {
 static void stringitem_releasekey(void *this,void *key) {
 }
 
+/**
+ * This callback function writes a representation of an item into
+ * a character buffer.
+ */
+static int stringitem_tostring(void *this,void *item,char *buffer,int limit) {
+    if ( item ) {
+       return snprintf( buffer, limit, "\"%s\"", (char*) item );
+    }
+    return snprintf( buffer, limit, "(null)" );
+}
+
 itemkeyfun stringitem = {
     .hashcode = stringitem_hashcode,
     .haskey = stringitem_haskey,
     .itemkey = stringitem_itemkey,
-    .releasekey = stringitem_releasekey
+    .releasekey = stringitem_releasekey,
+    .tostring = stringitem_tostring
 };
index 55328c5446624abda6224bc07993acfcaacdc0c9..f3dfe2c70b0aff012c7b39397f3881817148bd81 100644 (file)
@@ -99,6 +99,28 @@ static void tupleitem_releasekey(void *this,void *key) {
     free( key );
 }
 
+#define OUT(X) a = X; if ( a > limit ) return 0; buffer += a; limit -= a
+
+/**
+ * This callback function writes a representation of an item into
+ * a character buffer.
+ */
+static int tupleitem_tostring(void *this,void *item,char *buffer,int limit) {
+    tupleschema *def = (tupleschema *) this;
+    tuple *t = (tuple*) item;
+    char *x = "<";
+    int a, i;
+    for ( i = 0; i < def->arity; i++ ) {
+       OUT( snprintf( buffer, limit, x ) );
+       x = ",";
+       OUT( def->columns[i]->tostring(
+                def->columns[i], (*t)[i], buffer, limit ) );
+    }
+    OUT( snprintf( buffer, limit, ">" ) );
+    return a;
+}
+
+
 // Allocate
 tuple *tuple_create(int arity,...) {
     va_list ap;
@@ -116,7 +138,8 @@ itemkeyfun tupleschema_callbacks = {
     .hashcode = tupleitem_hashcode,
     .haskey = tupleitem_haskey,
     .itemkey = tupleitem_itemkey,
-    .releasekey = tupleitem_releasekey
+    .releasekey = tupleitem_releasekey,
+    .tostring = tupleitem_tostring
 };
 
 tupleschema *tupleschema_create(int arity,tuple *columns) {
@@ -160,4 +183,3 @@ unsigned long tuple_mask(int arity,tuple *t) {
     }
     return mask;
 }
-