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);
}