Mercurial > hg > audiodb
view libtests/0002/prog1.c @ 404:1fb8bee777e5 api-inversion
Begin working towards inverting audioDB::insert() / audiodb_insert().
New data type audiodb_datum_t, roughly corresponding to a "track" in
current audioDB parlance; it contains exactly the feature information
and metadata to record.
New function audiodb_insert_datum() to insert one of these
audiodb_datum_t objects into the database; the intention is that not
only can insertion of feature files be implemented in terms of this
function, but that it will be a useful function in its own right,
callable perhaps from PD, Max/MSP, and/or a VAMP plugin. This function
is complicated enough that it actually gets a comment.
Implement audioDB::insert() in terms of audiodb_insert_datum(), via a
wrapper which handles the slightly wacky error/non-error case of
attempting to insert features with a key that already exists in the
database.
Delete whole rafts of code. We can't quite delete everything because
there's batchinsert / batchinsert_large_adb to sort out; the good news
is that the batchinsert operation can simply be implemented as a loop
around audiodb_insert_datum() without loss of efficiency.
(There's also a stray extra audiodb_insert() in libtests/0027/, found
through an earlier iteration of this patch.)
author | mas01cr |
---|---|
date | Fri, 05 Dec 2008 22:32:43 +0000 |
parents | 94c18f128ce8 |
children | e072aa1611f5 342822c2d49a |
line wrap: on
line source
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <sysexits.h> #include <fcntl.h> #include <dirent.h> #include <unistd.h> #include <sys/stat.h> /* * * #define NDEBUG * * */ #include <assert.h> #include "../../audioDB_API.h" #include "../test_utils_lib.h" int main(int argc, char **argv){ int returnval=0; adb_ptr mydbp={0}; adb_status_t mystatus={0}; char * databasename="testdb"; //. ../test-utils.sh // //if [ -f testdb ]; then rm -f testdb; fi // /* remove old directory */ clean_remove_db(databasename); /* create new db */ //${AUDIODB} -N -d testdb // mydbp=audiodb_create(databasename,0,0,0); //# FIXME: at some point we will want to test that some relevant //# information is being printed //${AUDIODB} -S -d testdb //${AUDIODB} -d testdb -S if(audiodb_status(mydbp,&mystatus)){ returnval=-1; } /* not relevent, caught by API */ //# should fail (no db given) //expect_clean_error_exit ${AUDIODB} -S audiodb_close(mydbp); return(returnval); }