#include "lib/dcp_content.h"
#include "lib/job.h"
#include "lib/examine_content_job.h"
+#include "lib/content_factory.h"
#include "lib/cross.h"
#include <dcp/dcp.h>
#include <dcp/cpl.h>
film_changed ();
setup_sensitivity ();
- update_dcp_directory ();
+ update_content_directory ();
JobManager::instance()->ActiveJobsChanged.connect (
bind (&Controls::active_jobs_changed, this, _2)
Controls::config_changed (int property)
{
if (property == Config::PLAYER_CONTENT_DIRECTORY) {
- update_dcp_directory ();
+ update_content_directory ();
} else {
setup_sensitivity ();
}
{
_content_view->Show (s);
if (s) {
- update_dcp_directory ();
+ update_content_directory ();
}
_spl_view->Show (s);
_log->Show (s);
}
void
-Controls::update_dcp_directory ()
+Controls::update_content_directory ()
{
if (!_content_view->IsShown()) {
return;
return;
}
- wxProgressDialog progress (_("DCP-o-matic"), _("Reading DCP directory"));
+ wxProgressDialog progress (_("DCP-o-matic"), _("Reading content directory"));
JobManager* jm = JobManager::instance ();
for (directory_iterator i = directory_iterator(*dir); i != directory_iterator(); ++i) {
try {
+ shared_ptr<Content> content;
if (is_directory(*i) && (is_regular_file(*i / "ASSETMAP") || is_regular_file(*i / "ASSETMAP.xml"))) {
- shared_ptr<DCPContent> content (new DCPContent(_film, *i));
+ content.reset (new DCPContent(_film, *i));
+ } else if (i->path().extension() == ".mp4") {
+ content = content_factory(_film, *i).front();
+ }
+
+ if (content) {
jm->add (shared_ptr<Job>(new ExamineContentJob(_film, content)));
while (jm->work_to_do()) {
if (!progress.Pulse()) {