fix invalid mapping detection
[ardour.git] / libs / ardour / export_handler.cc
index 6b59afec89c8736285e47eb84b6ca9ea504b671f..5e3509167da50aee9ea27c8b8a3e4a0861d79ee0 100644 (file)
@@ -148,6 +148,14 @@ ExportHandler::do_export ()
        }
        export_status->total_timespans = timespan_set.size();
 
+       if (export_status->total_timespans > 1) {
+               // always include timespan if there's more than one.
+               for (ConfigMap::iterator it = config_map.begin(); it != config_map.end(); ++it) {
+                       FileSpec & spec = it->second;
+                       spec.filename->include_timespan = true;
+               }
+       }
+
        /* Start export */
 
        Glib::Threads::Mutex::Lock l (export_status->lock());
@@ -234,6 +242,7 @@ ExportHandler::process (framecnt_t frames)
 int
 ExportHandler::process_timespan (framecnt_t frames)
 {
+       export_status->active_job = ExportStatus::Exporting;
        /* update position */
 
        framecnt_t frames_to_read = 0;
@@ -313,6 +322,8 @@ ExportHandler::finish_timespan ()
                        export_cd_marker_file (current_timespan, fmt, filename, MP4Chaps);
                }
 
+               Session::Exported (current_timespan->name(), filename); /* EMIT SIGNAL */
+
                /* close file first, otherwise TagLib enounters an ERROR_SHARING_VIOLATION
                 * The process cannot access the file because it is being used.
                 * ditto for post-export and upload.
@@ -347,15 +358,17 @@ ExportHandler::finish_timespan ()
                        subs.insert (std::pair<char, std::string> ('n', session.name ()));
 
                        ARDOUR::SystemExec *se = new ARDOUR::SystemExec(fmt->command(), subs);
+                       info << "Post-export command line : {" << se->to_s () << "}" << endmsg;
                        se->ReadStdout.connect_same_thread(command_connection, boost::bind(&ExportHandler::command_output, this, _1, _2));
-                       if (se->start (2) == 0) {
+                       int ret = se->start (2);
+                       if (ret == 0) {
                                // successfully started
                                while (se->is_running ()) {
                                        // wait for system exec to terminate
                                        Glib::usleep (1000);
                                }
                        } else {
-                               error << "post-export hook failed! " << fmt->command() << endmsg;
+                               error << "Post-export command FAILED with Error: " << ret << endmsg;
                        }
                        delete (se);
                }
@@ -507,10 +520,10 @@ ExportHandler::export_cd_marker_file (ExportTimespanPtr timespan, ExportFormatSp
                }
 
        } catch (std::exception& e) {
-               error << string_compose (_("an error occured while writing a TOC/CUE file: %1"), e.what()) << endmsg;
+               error << string_compose (_("an error occurred while writing a TOC/CUE file: %1"), e.what()) << endmsg;
                ::g_unlink (filepath.c_str());
        } catch (Glib::Exception& e) {
-               error << string_compose (_("an error occured while writing a TOC/CUE file: %1"), e.what()) << endmsg;
+               error << string_compose (_("an error occurred while writing a TOC/CUE file: %1"), e.what()) << endmsg;
                ::g_unlink (filepath.c_str());
        }
 }