Mercurial > hg > audiodb
diff audioDB.cpp @ 496:8fb85fbcaba6 api-inversion
Mostly disentangle API from command-line binary.
Now audioDB.cpp doesn't need to be included in the library, because
nothing the library does creates an audioDB instance. Hooray. We can't
disentangle the other way, because there's still plenty in the
command-line binary that isn't implemented in terms of the API, so the
audioDB binary code needs to know naughty stuff about the library's
internals (e.g. what the file header looks like).
Remove liszt.o and sample.o from the library, even though they'll
probably make a reapparance soon (for scare-quoted values of "soon")
Remove cmdline.o and common.o from the library, not scheduled to make a
reapparence ever (hooray!). Separate out the bits that are used in the
library -- locks and PointPairs -- into their own files.
author | mas01cr |
---|---|
date | Sat, 10 Jan 2009 15:33:25 +0000 |
parents | d3afc91d205d |
children |
line wrap: on
line diff
--- a/audioDB.cpp Sat Jan 10 15:33:21 2009 +0000 +++ b/audioDB.cpp Sat Jan 10 15:33:25 2009 +0000 @@ -8,24 +8,6 @@ char* SERVER_ADB_ROOT; char* SERVER_ADB_FEATURE_ROOT; -PointPair::PointPair(Uns32T a, Uns32T b, Uns32T c):trackID(a),qpos(b),spos(c){}; - -bool operator<(const PointPair& a, const PointPair& b){ - return ( (a.trackID<b.trackID) || - ( (a.trackID==b.trackID) && - ( (a.spos<b.spos) || ( (a.spos==b.spos) && (a.qpos < b.qpos) )) ) ); -} - -bool operator>(const PointPair& a, const PointPair& b){ - return ( (a.trackID>b.trackID) || - ( (a.trackID==b.trackID) && - ( (a.spos>b.spos) || ( (a.spos==b.spos) && (a.qpos > b.qpos) )) ) ); -} - -bool operator==(const PointPair& a, const PointPair& b){ - return ( (a.trackID==b.trackID) && (a.qpos==b.qpos) && (a.spos==b.spos) ); -} - audioDB::audioDB(const unsigned argc, const char *argv[]): O2_AUDIODB_INITIALIZERS { if(processArgs(argc, argv)<0){ @@ -45,11 +27,7 @@ prefix_name((char** const)&dbName, adb_root); if(O2_ACTION(COM_SERVER)) -#ifdef LIBRARY - ; -#else startServer(); -#endif else if(O2_ACTION(COM_CREATE)) create(dbName); @@ -62,9 +40,6 @@ else if(O2_ACTION(COM_QUERY)) if(isClient){ -#ifdef LIBRARY - ; -#else if(query_from_key){ VERB_LOG(1, "Calling web services query %s on database %s, query=%s\n", radius>0?"(Radius)":"(NN)", dbName, (key&&strlen(key))?key:inFile); ws_query_by_key(dbName, key, inFile, (char*)hostport); @@ -73,18 +48,13 @@ VERB_LOG(1, "Calling web services query on database %s, query=%s\n", dbName, (key&&strlen(key))?key:inFile); ws_query(dbName, inFile, (char*)hostport); } -#endif } else query(dbName, inFile); else if(O2_ACTION(COM_STATUS)) if(isClient) -#ifdef LIBRARY - ; -#else ws_status(dbName,(char*)hostport); -#endif else status(dbName); @@ -102,11 +72,7 @@ else if(O2_ACTION(COM_LISZT)) if(isClient) -#ifdef LIBRARY - ; -#else ws_liszt(dbName, (char*) hostport); -#endif else liszt(dbName, lisztOffset, lisztLength); @@ -165,38 +131,6 @@ } } -//for API query -audioDB::audioDB(const unsigned argc, const char *argv[],adb__queryResponse *adbQueryResponse, int * apierror, adb_t *a): O2_AUDIODB_INITIALIZERS -{ - - try { - UseApiError=1; - adb = a; - - if(processArgs(argc, argv)<0){ - printf("No command found.\n"); - cmdline_parser_print_version (); - if (strlen(gengetopt_args_info_purpose) > 0) - printf("%s\n", gengetopt_args_info_purpose); - printf("%s\n", gengetopt_args_info_usage); - printf("%s\n", gengetopt_args_info_help[1]); - printf("%s\n", gengetopt_args_info_help[2]); - printf("%s\n", gengetopt_args_info_help[0]); - error("No command found"); - } - - query(dbName, inFile, adbQueryResponse); - - } catch(int a) { - *apierror=a; - return; - - } - *apierror=apierrortemp; - return; - -} - void audioDB::cleanup() { cmdline_parser_free(&args_info); if(fileTable) @@ -221,7 +155,7 @@ gsl_rng_free(rng); if(infid>0) close(infid); - if(adb && !UseApiError) { + if(adb) { audiodb_close(adb); adb = NULL; } @@ -1008,121 +942,3 @@ SERVER_ADB_FEATURE_ROOT = 0; // Server-side features root prefix audioDB(argc, argv); } - - -extern "C" { - -/* for API questions contact - * Christophe Rhodes c.rhodes@gold.ac.uk - * Ian Knopke mas01ik@gold.ac.uk, ian.knopke@gmail.com */ - - int audiodb_query(adb_ptr mydb, adb_query_ptr adbq, adb_queryresult_ptr adbqr){ - - const char *argv[32]; - int argvctr=0; - char tempstr1[200]; - char tempstr2[200]; - char tempstr3[200]; - int apierror=0; - - adb__queryResponse adbQueryResponse; - - /* TODO: may need error checking here */ - /* currently counting on audioDB binary to fail for me */ - argv[argvctr++]="audioDB"; - - if(adbq->querytype){ - argv[argvctr++]="-Q"; - argv[argvctr++]=adbq->querytype; - } - - if(mydb->path){ - argv[argvctr++]="-d"; - argv[argvctr++]=mydb->path; - } - - if (adbq->feature){ - argv[argvctr++]="-f"; - argv[argvctr++]=adbq->feature; - } - - if (adbq->power){ - argv[argvctr++]="-w"; - argv[argvctr++]=adbq->power; - } - - if (adbq->qpoint){ - argv[argvctr++]="-p"; - argv[argvctr++]=adbq->qpoint; - } - if (adbq->numpoints){ - argv[argvctr++]="-n"; - argv[argvctr++]=adbq->numpoints; - } - if (adbq->radius){ - argv[argvctr++]="-R"; - argv[argvctr++]=adbq->radius; - } - if(adbq->resultlength){ - argv[argvctr++]="-r"; - argv[argvctr++]=adbq->resultlength; - } - if(adbq->sequencelength){ - argv[argvctr++]="-l"; - argv[argvctr++]=adbq->sequencelength; - } - if(adbq->sequencehop){ - argv[argvctr++]="-h"; - argv[argvctr++]=adbq->sequencehop; - } - - if (adbq->absolute_threshold){ - argv[argvctr++]="--absolute-threshold"; - snprintf(tempstr1,sizeof(tempstr1),"%f",adbq->absolute_threshold); - argv[argvctr++]=tempstr1; - } - - if (adbq->relative_threshold){ - argv[argvctr++]="--relative-threshold"; - snprintf(tempstr2,sizeof(tempstr2),"%f",adbq->relative_threshold); - argv[argvctr++]=tempstr2; - } - - if (adbq->exhaustive){ - argv[argvctr++]="--exhaustive"; - } - - if (adbq->expandfactor){ - argv[argvctr++]="--expandfactor"; - snprintf(tempstr3,sizeof(tempstr3),"%f",adbq->expandfactor); - argv[argvctr++]=tempstr3; - } - - if (adbq->rotate){ - argv[argvctr++]="--rotate"; - } - - if (adbq->keylist){ - argv[argvctr++]="-K"; - argv[argvctr++]=adbq->keylist; - } - argv[argvctr]='\0'; - - /* debugging */ - - audioDB::audioDB(argvctr,argv, &adbQueryResponse, &apierror,mydb); - - //copy data over here from adbQueryResponse to adbqr - adbqr->sizeRlist=adbQueryResponse.result.__sizeRlist; - adbqr->sizeDist=adbQueryResponse.result.__sizeDist; - adbqr->sizeQpos=adbQueryResponse.result.__sizeQpos; - adbqr->sizeSpos=adbQueryResponse.result.__sizeSpos; - adbqr->Rlist=adbQueryResponse.result.Rlist; - adbqr->Dist=adbQueryResponse.result.Dist; - adbqr->Qpos=adbQueryResponse.result.Qpos; - adbqr->Spos=adbQueryResponse.result.Spos; - - return apierror; - } -} -