Mercurial > hg > audiodb
diff audioDB-internals.h @ 458:913a95f06998 api-inversion
Start using the query state structure.
Actually using it means moving it around in the source code a little
bit, thanks to entanglements. It'll all be alright on the night. Now
the accumulator, allowed_keys and exact_evaluation_queue are all part of
the query state, and can therefore be passed around with minimal effort
(and deleted in the appropriate place).
Now a whole bunch of static methods (the callbacks, basically) in
index.cpp can be rewritten as plain old C functions. The callbacks need
both an adb_t and a query state structure to function (the adb_t to get
at things like lsh_n_point_bits and the track->key table; the qstate to
get at the accumulator and allowed_keys list).
Rearrange audioDB::query a little bit, and mark the beginning and the
end of the putative audiodb_query_spec() API function implementation.
author | mas01cr |
---|---|
date | Sun, 28 Dec 2008 18:44:08 +0000 |
parents | 823bca1e10f5 |
children | 17003dff8127 |
line wrap: on
line diff
--- a/audioDB-internals.h Wed Dec 24 10:57:30 2008 +0000 +++ b/audioDB-internals.h Sun Dec 28 18:44:08 2008 +0000 @@ -24,12 +24,7 @@ * using adb->fd, but changing to use pread() might win us * threadsafety eventually. */ -typedef struct adb_qstate_internal { - Accumulator *accumulator; - adb_qpointers_internal_t *qpointers; - adb_qpointers_internal_t *dbpointers; - std::set<std::string> *allowed_keys; -} adb_qstate_internal_t; +// FIXME moved to audioDB.h for now struct adb { char *path; @@ -207,6 +202,24 @@ } } +/************************* LSH point index to audioDB conversion *****************/ +static inline uint32_t audiodb_index_to_track_id(uint32_t lshid, uint32_t n_point_bits) { + return (lshid >> n_point_bits); +} + +static inline uint32_t audiodb_index_to_track_pos(uint32_t lshid, uint32_t n_point_bits) { + return (lshid & ((1 << n_point_bits) - 1)); +} + +static inline uint32_t audiodb_index_from_trackinfo(uint32_t track_id, uint32_t track_pos, uint32_t n_point_bits) { + return ((track_id << n_point_bits) | track_pos); +} + +static inline uint32_t audiodb_lsh_n_point_bits(adb_t *adb) { + uint32_t nbits = adb->header->flags >> 28; + return (nbits ? nbits : O2_DEFAULT_LSH_N_POINT_BITS); +} + int audiodb_read_data(adb_t *, int, int, double **, size_t *); int audiodb_insert_create_datum(adb_insert_t *, adb_datum_t *); int audiodb_free_datum(adb_datum_t *);