void
Film::examine_and_add_content (shared_ptr<Content> c)
{
- if (dynamic_pointer_cast<FFmpegContent> (c)) {
+ if (dynamic_pointer_cast<FFmpegContent> (c) && !_directory.empty ()) {
run_ffprobe (c->path(0), file ("ffprobe.log"), _log);
}
}
set_error (e.what(), m);
- set_progress (1);
- set_state (FINISHED_ERROR);
} catch (OpenFileError& e) {
String::compose (_("DCP-o-matic could not open the file %1. Perhaps it does not exist or is in an unexpected format."), e.file().string())
);
- set_progress (1);
- set_state (FINISHED_ERROR);
+ } catch (boost::filesystem::filesystem_error& e) {
+
+ if (e.code() == boost::system::errc::no_such_file_or_directory) {
+ set_error (
+ String::compose (_("Could not open %1"), e.path1().string ()),
+ String::compose (_("DCP-o-matic could not open the file %1. Perhaps it does not exist or is in an unexpected format."), e.path1().string())
+ );
+ } else {
+ set_error (
+ e.what (),
+ string (_("It is not known what caused this error.")) + " " + REPORT_PROBLEM
+ );
+ }
} catch (boost::thread_interrupted &) {
set_state (FINISHED_CANCELLED);
+ /* This is the only one that is not FINISHED_ERROR; need to return */
+ return;
} catch (std::bad_alloc& e) {
set_error (_("Out of memory"), _("There was not enough memory to do this."));
- set_progress (1);
- set_state (FINISHED_ERROR);
} catch (std::exception& e) {
string (_("It is not known what caused this error.")) + " " + REPORT_PROBLEM
);
- set_progress (1);
- set_state (FINISHED_ERROR);
-
} catch (...) {
set_error (
_("Unknown error"),
string (_("It is not known what caused this error.")) + " " + REPORT_PROBLEM
);
-
- set_progress (1);
- set_state (FINISHED_ERROR);
}
+
+ set_progress (1);
+ set_state (FINISHED_ERROR);
}
/** @return true if this job is new (ie has not started running) */