diff options
| author | Carl Hetherington <cth@carlh.net> | 2025-10-14 23:34:36 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2026-02-03 21:37:04 +0100 |
| commit | 277037234b63be78aa5bf28fb90d6ba1c1ac6bee (patch) | |
| tree | 6c6f87ad79fd2bbb20eb6049d9a22161f7e7f7aa /src/wx/content_view.cc | |
| parent | e5112729b7a5193921d8a9c4c767aabad54137c7 (diff) | |
Move content store handling into ContentStore rather than it being done in the GUI.
Diffstat (limited to 'src/wx/content_view.cc')
| -rw-r--r-- | src/wx/content_view.cc | 106 |
1 files changed, 13 insertions, 93 deletions
diff --git a/src/wx/content_view.cc b/src/wx/content_view.cc index 438f53785..ce7e9693e 100644 --- a/src/wx/content_view.cc +++ b/src/wx/content_view.cc @@ -81,76 +81,27 @@ ContentView::selected () const void ContentView::update () { - using namespace boost::filesystem; - - DeleteAllItems (); - _content.clear (); auto dir = Config::instance()->player_content_directory(); if (!dir || !dcp::filesystem::is_directory(*dir)) { dir = home_directory (); } wxProgressDialog progress(variant::wx::dcpomatic(), _("Reading content directory")); - auto jm = JobManager::instance (); - - list<shared_ptr<ExamineContentJob>> jobs; - - for (auto i: directory_iterator(*dir)) { - try { - progress.Pulse (); - - shared_ptr<Content> content; - if (is_directory(i) && contains_assetmap(i)) { - content = make_shared<DCPContent>(i); - } else if (i.path().extension() == ".mp4") { - auto all_content = content_factory(i); - if (!all_content.empty()) { - content = all_content[0]; - } - } - - if (content) { - auto job = make_shared<ExamineContentJob>(vector<shared_ptr<Content>>{content}, false); - jm->add (job); - jobs.push_back (job); - } - } catch (boost::filesystem::filesystem_error& e) { - /* Never mind */ - } catch (dcp::ReadError& e) { - /* Never mind */ - } - } - while (jm->work_to_do()) { - if (!progress.Pulse()) { - /* user pressed cancel */ - for (auto i: jm->get()) { - i->cancel(); - } - return; - } - dcpomatic_sleep_seconds (1); + auto store = ContentStore::instance(); + + auto errors = store->update([&progress]() { + return progress.Pulse(); + }); + + DeleteAllItems(); + _content.clear(); + for (auto content: store->all()) { + add(content); } - /* Add content from successful jobs and report errors */ - for (auto i: jobs) { - if (i->finished_in_error()) { - error_dialog(this, std_to_wx(i->error_summary()) + char_to_wx(".\n"), std_to_wx(i->error_details())); - } else { - for (auto c: i->content()) { - if (auto dcp = dynamic_pointer_cast<DCPContent>(c)) { - for (auto cpl: dcp::find_and_resolve_cpls(dcp->directories(), true)) { - auto copy = dynamic_pointer_cast<DCPContent>(dcp->clone()); - copy->set_cpl(cpl->id()); - add(copy); - _content.push_back(copy); - } - } else { - add(c); - _content.push_back(c); - } - } - } + for (auto error: errors) { + error_dialog(this, std_to_wx(error.first), std_to_wx(error.second)); } } @@ -180,39 +131,8 @@ ContentView::add (shared_ptr<Content> content) it.SetColumn(2); it.SetText(std_to_wx(content->summary())); SetItem(it); -} - -shared_ptr<Content> -ContentView::get_by_digest(string digest) const -{ - auto iter = std::find_if(_content.begin(), _content.end(), [digest](shared_ptr<const Content> c) { return c->digest() == digest; }); - if (iter == _content.end()) { - return {}; - } - - return *iter; + _content.push_back(content); } -shared_ptr<Content> -ContentView::get_by_cpl_id(string cpl_id) const -{ - auto iter = std::find_if( - _content.begin(), - _content.end(), - [cpl_id](shared_ptr<const Content> c) { - if (auto dcp = dynamic_pointer_cast<const DCPContent>(c)) { - if (dcp->cpl() && *dcp->cpl() == cpl_id) { - return true; - } - } - return false; - }); - - if (iter == _content.end()) { - return {}; - } - - return *iter; -} |
