annotate pointpair.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
children cc2b97d020b1
rev   line source
mas01cr@496 1 #include "audioDB.h"
mas01cr@496 2 extern "C" {
mas01cr@496 3 #include "audioDB_API.h"
mas01cr@496 4 #include "audioDB-internals.h"
mas01cr@496 5 }
mas01cr@496 6
mas01cr@496 7 PointPair::PointPair(Uns32T a, Uns32T b, Uns32T c) :
mas01cr@496 8 trackID(a), qpos(b), spos(c) {
mas01cr@496 9 };
mas01cr@496 10
mas01cr@496 11 bool operator<(const PointPair& a, const PointPair& b) {
mas01cr@496 12 return ((a.trackID < b.trackID) ||
mas01cr@496 13 ((a.trackID == b.trackID) &&
mas01cr@496 14 ((a.spos < b.spos) || ((a.spos == b.spos) && (a.qpos < b.qpos)))));
mas01cr@496 15 }
mas01cr@496 16
mas01cr@496 17 bool operator>(const PointPair& a, const PointPair& b) {
mas01cr@496 18 return ((a.trackID > b.trackID) ||
mas01cr@496 19 ((a.trackID == b.trackID) &&
mas01cr@496 20 ((a.spos > b.spos) || ((a.spos == b.spos) && (a.qpos > b.qpos)))));
mas01cr@496 21 }
mas01cr@496 22
mas01cr@496 23 bool operator==(const PointPair& a, const PointPair& b) {
mas01cr@496 24 return ((a.trackID == b.trackID) &&
mas01cr@496 25 (a.qpos == b.qpos) &&
mas01cr@496 26 (a.spos == b.spos));
mas01cr@496 27 }