annotate liszt.cpp @ 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 e18843dc0aea
children
rev   line source
mas01cr@548 1 extern "C" {
mas01cr@548 2 #include "audioDB_API.h"
mas01cr@548 3 }
mas01cr@548 4 #include "audioDB-internals.h"
mas01cr@498 5
mas01cr@548 6 adb_liszt_results_t *audiodb_liszt(adb_t *adb) {
mas01cr@548 7 uint32_t nfiles = adb->header->numFiles;
mas01cr@548 8 adb_liszt_results_t *results;
mas01cr@548 9 results = (adb_liszt_results_t *) calloc(sizeof(adb_liszt_results_t),1);
mas01cr@548 10 results->nresults = nfiles;
mas01cr@548 11 if(nfiles > 0) {
mas01cr@548 12 results->entries = (adb_track_entry_t *) malloc(nfiles * sizeof(adb_track_entry_t));
mas01cr@498 13 }
mas01cr@548 14 for(uint32_t k = 0; k < nfiles; k++) {
mas01cr@548 15 results->entries[k].nvectors = (*adb->track_lengths)[k];
mas01cr@548 16 results->entries[k].key = audiodb_index_key(adb, k);
mas01cr@548 17 }
mas01cr@548 18 return results;
mas01cr@548 19 }
mas01cr@498 20
mas01cr@548 21 int audiodb_liszt_free_results(adb_t *adb, adb_liszt_results_t *results) {
mas01cr@548 22 free(results->entries);
mas01cr@548 23 free(results);
mas01cr@548 24 return 0;
mas01cr@498 25 }