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