fix invalid mapping detection
[ardour.git] / libs / ardour / export_handler.cc
index 70c807b7de5d35f43251b80290889b5e88b80be4..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;
@@ -295,11 +304,12 @@ ExportHandler::command_output(std::string output, size_t size)
 void
 ExportHandler::finish_timespan ()
 {
+       graph_builder->get_analysis_results (export_status->result_map);
+
        while (config_map.begin() != timespan_bounds.second) {
 
                ExportFormatSpecPtr fmt = config_map.begin()->second.format;
                std::string filename = config_map.begin()->second.filename->get_path(fmt);
-
                if (fmt->with_cue()) {
                        export_cd_marker_file (current_timespan, fmt, filename, CDMarkerCUE);
                }
@@ -312,15 +322,19 @@ 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.
+                */
+               graph_builder->reset ();
+
                if (fmt->tag()) {
-                       /* close file first, otherwise TagLib enounters an ERROR_SHARING_VIOLATION
-                        * The process cannot access the file because it is being used.
-                        *
-                        * TODO: check Umlauts and encoding in filename.
+                       /* TODO: check Umlauts and encoding in filename.
                         * TagLib eventually calls CreateFileA(),
                         */
                        export_status->active_job = ExportStatus::Tagging;
-                       graph_builder->reset ();
                        AudiofileTagger::tag_file(filename, *SessionMetadata::Metadata());
                }
 
@@ -344,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);
                }
@@ -504,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());
        }
 }