diff bindings/sb-alien/library.lisp @ 580:633614461994

API for retrieving a track's data. A new function, audiodb_retrieve_datum() fills a provided adb_datum_t structure with the data corresponding to a given database key; the companion audiodb_free_datum() function frees the data in a given datum appropriately. Just in case, I continue to require passing in the adb_t * as the first argument to audiodb_free_datum(), even though it's not currently used: I couldn't convince myself that _all_ possible implementations could free a datum without reference to the adb_t. This meant rewriting the internal code to use a new internal audiodb_really_free_datum() function, which audiodb_free_datum() also calls. Sanity-checked by implementing a binding in sb-alien to this function, lightly-tested. All this fixes ticket:20 in Trac.
author mas01cr
date Tue, 14 Jul 2009 15:35:36 +0000
parents 3141e51cb077
children 1b3b303957bd
line wrap: on
line diff
--- a/bindings/sb-alien/library.lisp	Mon Jul 06 17:13:49 2009 +0000
+++ b/bindings/sb-alien/library.lisp	Tue Jul 14 15:35:36 2009 +0000
@@ -51,6 +51,17 @@
   (datum (* adb-datum-t)))
 (define-int-checking-function %insert-datum (adb datum) %%insert-datum)
 
+(define-alien-routine ("audiodb_retrieve_datum" %%retrieve-datum) int
+  (adb (* adb-t))
+  (key c-string)
+  (datum (* adb-datum-t)))
+(define-int-checking-function %retrieve-datum (adb key datum) %%retrieve-datum)
+
+(define-alien-routine ("audiodb_free_datum" %%free-datum) int
+  (adb (* adb-t))
+  (datum (* adb-datum-t)))
+(define-int-checking-function %free-datum (adb datum) %%free-datum)
+
 (define-alien-type adb-status-t
   (struct adb-status
     (nfiles (unsigned 32))