summaryrefslogtreecommitdiff
path: root/src/lua
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2023-12-05 11:36:34 +1100
committerjacqueline <me@jacqueline.id.au>2023-12-05 11:36:34 +1100
commit4f5422e906b1d17720592d97bc0d5e82a71b1e5f (patch)
tree4e8116510d57fb54c30fc18f1fe591a9aff4e3a0 /src/lua
parent67f2f2de8393951d2eabac26f9afab2dc9388713 (diff)
downloadtangara-fw-4f5422e906b1d17720592d97bc0d5e82a71b1e5f.tar.gz
Rewrite the track queue to work directly with database iterators
Diffstat (limited to 'src/lua')
-rw-r--r--src/lua/lua_queue.cpp22
1 files changed, 17 insertions, 5 deletions
diff --git a/src/lua/lua_queue.cpp b/src/lua/lua_queue.cpp
index 929a7159..fadcb51c 100644
--- a/src/lua/lua_queue.cpp
+++ b/src/lua/lua_queue.cpp
@@ -22,6 +22,8 @@
#include "property.hpp"
#include "service_locator.hpp"
#include "source.hpp"
+#include "track.hpp"
+#include "track_queue.hpp"
#include "ui_events.hpp"
namespace lua {
@@ -32,11 +34,19 @@ static auto queue_add(lua_State* state) -> int {
Bridge* instance = Bridge::Get(state);
if (lua_isinteger(state, 1)) {
- instance->services().track_queue().AddLast(luaL_checkinteger(state, 1));
+ database::TrackId id = luaL_checkinteger(state, 1);
+ instance->services().bg_worker().Dispatch<void>([=]() {
+ audio::TrackQueue& queue = instance->services().track_queue();
+ auto editor = queue.Edit();
+ queue.Append(editor, id);
+ });
} else {
- database::Iterator* it = db_check_iterator(state, 1);
- instance->services().track_queue().IncludeLast(
- std::make_shared<playlist::IteratorSource>(*it));
+ database::Iterator it = *db_check_iterator(state, 1);
+ instance->services().bg_worker().Dispatch<void>([=]() {
+ audio::TrackQueue& queue = instance->services().track_queue();
+ auto editor = queue.Edit();
+ queue.Append(editor, database::TrackIterator{it});
+ });
}
return 0;
@@ -44,7 +54,9 @@ static auto queue_add(lua_State* state) -> int {
static auto queue_clear(lua_State* state) -> int {
Bridge* instance = Bridge::Get(state);
- instance->services().track_queue().Clear();
+ audio::TrackQueue& queue = instance->services().track_queue();
+ auto editor = queue.Edit();
+ queue.Clear(editor);
return 0;
}