diff options
| author | jacqueline <me@jacqueline.id.au> | 2023-07-12 10:36:06 +1000 |
|---|---|---|
| committer | jacqueline <me@jacqueline.id.au> | 2023-07-12 10:36:06 +1000 |
| commit | df22bed0724b3a0d04c9fefd0f5bb130945a6b4e (patch) | |
| tree | 919ad6d6dcb611aa5cb1710efd9425655caf8960 /src/database/database.cpp | |
| parent | 67ab8bf5153f9391b8b728bc932ea8414e18c511 (diff) | |
| download | tangara-fw-df22bed0724b3a0d04c9fefd0f5bb130945a6b4e.tar.gz | |
Include title in indexes to avoid a per-record disk read
GOTTA GO FAST
Diffstat (limited to 'src/database/database.cpp')
| -rw-r--r-- | src/database/database.cpp | 26 |
1 files changed, 9 insertions, 17 deletions
diff --git a/src/database/database.cpp b/src/database/database.cpp index 0d1c43e2..d0011abe 100644 --- a/src/database/database.cpp +++ b/src/database/database.cpp @@ -600,20 +600,12 @@ auto Database::ParseRecord<IndexRecord>(const leveldb::Slice& key, return {}; } - // If there was a track id included for this key, then this is a leaf record. - // Fetch the actual track data instead of relying on the information in the - // key. - std::optional<Track> track; - if (data->track) { - std::optional<TrackData> track_data = dbGetTrackData(*data->track); - TrackTags track_tags; - if (track_data && - tag_parser_->ReadAndParseTags(track_data->filepath(), &track_tags)) { - track.emplace(*track_data, track_tags); - } + std::optional<std::string> title; + if (!val.empty()) { + title = val.ToString(); } - return IndexRecord(*data, track); + return IndexRecord(*data, title, data->track); } template <> @@ -663,17 +655,17 @@ auto Database::ParseRecord<std::string>(const leveldb::Slice& key, return stream.str(); } -IndexRecord::IndexRecord(const IndexKey& key, std::optional<Track> track) - : key_(key), track_(track) {} +IndexRecord::IndexRecord(const IndexKey& key, std::optional<shared_string> title, std::optional<TrackId> track) + : key_(key), override_text_(title), track_(track) {} auto IndexRecord::text() const -> std::optional<shared_string> { - if (track_) { - return track_->TitleOrFilename(); + if (override_text_) { + return override_text_; } return key_.item; } -auto IndexRecord::track() const -> std::optional<Track> { +auto IndexRecord::track() const -> std::optional<TrackId> { return track_; } |
