[ardour-dev] new feature: export all ranges

Andre Raue dawng at raue.info
Tue Jan 3 06:18:18 PST 2006


Taybin Rutkin wrote:
> Could you resend your patch in unified diff format using 'diff -u'?   
> It's much easier to read.
> 

You'll find it below for 6), 7) and 8)...

Greetings

Andre


6) cvs diff against 0.99 for the current alpha-version
------------------------------------------------------

Index: gtk_ardour/SConscript
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/SConscript,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- gtk_ardour/SConscript	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/SConscript	2 Jan 2006 10:15:55 -0000	1.2
@@ -92,6 +92,7 @@
  editor_tempodisplay.cc
  editor_timefx.cc
  export_dialog.cc
+session_export_dialog.cc
  gain_automation_time_axis.cc
  gain_meter.cc
  ghostregion.cc
Index: gtk_ardour/ardour_ui_ed.cc
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/ardour_ui_ed.cc,v
retrieving revision 1.1
retrieving revision 1.3
diff -u -r1.1 -r1.3
--- gtk_ardour/ardour_ui_ed.cc	12 Dec 2005 21:15:42 -0000	1.1
+++ gtk_ardour/ardour_ui_ed.cc	16 Dec 2005 22:30:37 -0000	1.3
@@ -132,6 +132,7 @@
  	export_menu->set_name ("ArdourContextMenu");
  	export_items.push_back (MenuElem (_("Export session to 
audiofile..."), slot (*editor, &PublicEditor::export_session)));
  	export_items.push_back (MenuElem (_("Export range to audiofile..."), 
slot (*editor, &PublicEditor::export_selection)));
+	export_items.push_back (MenuElem (_("Export all ranges..."), slot 
(*editor, &PublicEditor::export_ranges)));
  	// export_items.back()->set_sensitive (false);

  	session_items.push_back (MenuElem (_("Export"), *export_menu));
@@ -312,4 +313,3 @@
  		break;
  	}
  }
-
Index: gtk_ardour/editor.h
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/editor.h,v
retrieving revision 1.1
retrieving revision 1.3
diff -u -r1.1 -r1.3
--- gtk_ardour/editor.h	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/editor.h	2 Jan 2006 10:15:56 -0000	1.3
@@ -91,6 +91,7 @@
  class AutomationLine;
  class UIExportSpecification;
  class ExportDialog;
+class SessionExportDialog;
  class Selection;
  class TimeSelection;
  class TrackSelection;
@@ -228,6 +229,7 @@
  	
  	void export_session();
  	void export_selection();
+	void export_ranges();

  	/* this is what actually does it */
  	
@@ -1594,6 +1596,7 @@
  	/* audio export */

  	ExportDialog *export_dialog;
+	SessionExportDialog *session_export_dialog;
  	void export_range (jack_nframes_t start, jack_nframes_t end);

  	int write_region_selection(AudioRegionSelection&);
Index: gtk_ardour/editor_export_audio.cc
===================================================================
RCS file: 
/home/andre/cvs_repository/Ardour/gtk_ardour/editor_export_audio.cc,v
retrieving revision 1.1
retrieving revision 1.4
diff -u -r1.1 -r1.4
--- gtk_ardour/editor_export_audio.cc	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/editor_export_audio.cc	2 Jan 2006 10:15:56 -0000	1.4
@@ -21,6 +21,7 @@
  #include <unistd.h>
  #include <climits>
  #include "export_dialog.h"
+#include "session_export_dialog.h"
  #include "editor.h"
  #include "public_editor.h"
  #include "selection.h"
@@ -67,6 +68,20 @@
  }

  void
+Editor::export_ranges()
+{
+	if (session) {
+		if (session_export_dialog == 0) {
+			session_export_dialog = new SessionExportDialog(*this);
+		}
+		
+		session_export_dialog->connect_to_session (session);
+		session_export_dialog->set_range (0, session->current_end_frame());
+		session_export_dialog->start_export();
+	}
+}
+
+void
  Editor::export_range (jack_nframes_t start, jack_nframes_t end)
  {
  	if (session) {
Index: gtk_ardour/editor_mouse.cc
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/editor_mouse.cc,v
retrieving revision 1.1
retrieving revision 1.3
diff -u -r1.1 -r1.3
--- gtk_ardour/editor_mouse.cc	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/editor_mouse.cc	16 Dec 2005 22:30:37 -0000	1.3
@@ -4202,7 +4202,7 @@
  		case CreateRangeMarker:
  			begin_reversible_command (_("new range marker"));
  			session->add_undo (session->locations()->get_memento());
-			newloc = new Location(temp_location->start(), temp_location->end(), 
"unnamed");
+			newloc = new Location(temp_location->start(), temp_location->end(), 
"unnamed", Location::IsRange);
  			session->locations()->add (newloc, true);
  			session->add_redo_no_execute (session->locations()->get_memento());
  			commit_reversible_command ();
Index: gtk_ardour/export_dialog.h
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/export_dialog.h,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- gtk_ardour/export_dialog.h	12 Dec 2005 21:15:42 -0000	1.1
+++ gtk_ardour/export_dialog.h	2 Jan 2006 10:15:56 -0000	1.2
@@ -112,7 +112,7 @@
        	void do_export_cd_markers (const string& path, const string& 
cuefile_type);
  	void export_cue_file (ARDOUR::Locations::LocationList& locations, 
const string& path);
  	void export_toc_file (ARDOUR::Locations::LocationList& locations, 
const string& path);
-	void do_export ();
+ 	void do_export ();
  	gint change_focus_policy (GdkEventAny *, bool);
  	gint window_closed (GdkEventAny *ignored);

@@ -129,4 +129,3 @@
  };

  #endif // __ardour_export_dialog_h__
-
Index: gtk_ardour/location_ui.cc
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/location_ui.cc,v
retrieving revision 1.1
retrieving revision 1.4
diff -u -r1.1 -r1.4
--- gtk_ardour/location_ui.cc	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/location_ui.cc	2 Jan 2006 13:35:14 -0000	1.4
@@ -810,7 +810,7 @@
  {
  	if (session) {
  		jack_nframes_t where = session->audible_frame();
-		Location *location = new Location (where, where, "unnamed");
+		Location *location = new Location (where, where, "unnamed", 
Location::IsRange);
  		session->begin_reversible_command (_("add range marker"));
  		session->add_undo (session->locations()->get_memento());
  		session->locations()->add (location, true);
@@ -883,4 +883,3 @@
  	
  	ArdourDialog::session_gone();
  }
-
Index: gtk_ardour/public_editor.h
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/gtk_ardour/public_editor.h,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- gtk_ardour/public_editor.h	12 Dec 2005 21:15:41 -0000	1.1
+++ gtk_ardour/public_editor.h	14 Dec 2005 21:50:12 -0000	1.2
@@ -80,6 +80,7 @@
  	virtual bool show_measures () const = 0;
  	virtual void export_session() = 0;
  	virtual void export_selection() = 0;
+	virtual void export_ranges() = 0;
  	virtual void add_toplevel_controls (Gtk::Container&) = 0;
  	virtual void      set_zoom_focus (Editing::ZoomFocus) = 0;
  	virtual Editing::ZoomFocus get_zoom_focus () const = 0;
Index: libs/ardour/ardour/location.h
===================================================================
RCS file: /home/andre/cvs_repository/Ardour/libs/ardour/ardour/location.h,v
retrieving revision 1.1
retrieving revision 1.3
diff -u -r1.1 -r1.3
--- libs/ardour/ardour/location.h	12 Dec 2005 21:15:42 -0000	1.1
+++ libs/ardour/ardour/location.h	16 Dec 2005 22:30:37 -0000	1.3
@@ -50,7 +50,8 @@
  		IsAutoLoop = 0x4,
  		IsHidden = 0x8,
  		IsCDMarker = 0x10,
-		IsEnd = 0x20
+		IsEnd = 0x20,
+		IsRange = 0x40
  	};

  	Location (jack_nframes_t sample_start,
@@ -95,6 +96,7 @@
  	bool is_hidden () { return _flags & IsHidden; }
  	bool is_cd_marker () { return _flags & IsCDMarker; }
  	bool is_end() { return _flags & IsEnd; }
+	bool is_range() { return _flags & IsRange; }

  	SigC::Signal1<void,Location*> name_changed;
  	SigC::Signal1<void,Location*> end_changed;


7) diff of new file session_export_dialog.cc against export_dialog.cc
---------------------------------------------------------------------

--- gtk_ardour/export_dialog.cc	2005-10-27 21:16:33.000000000 +0200
+++ gtk_ardour/session_export_dialog.cc	2006-01-02 11:02:40.000000000 +0100
@@ -37,7 +37,7 @@
  #include <ardour/gdither.h>
  #include <ardour/utils.h>

-#include "export_dialog.h"
+#include "session_export_dialog.h"
  #include "check_mark.h"
  #include "ardour_ui.h"
  #include "public_editor.h"
@@ -48,10 +48,12 @@
  #define FRAME_SHADOW_STYLE GTK_SHADOW_IN
  #define FRAME_NAME "BaseFrame"

-GdkPixmap* ExportDialog::check_pixmap = 0;
-GdkPixmap* ExportDialog::check_mask = 0;
-GdkPixmap* ExportDialog::empty_pixmap = 0;
-GdkPixmap* ExportDialog::empty_mask = 0;
+void frames_to_cd_frames_string (char*, jack_nframes_t, jack_nframes_t);
+
+GdkPixmap* SessionExportDialog::check_pixmap = 0;
+GdkPixmap* SessionExportDialog::check_mask = 0;
+GdkPixmap* SessionExportDialog::empty_pixmap = 0;
+GdkPixmap* SessionExportDialog::empty_mask = 0;

  using namespace std;

@@ -99,7 +101,7 @@
  	0
  };

-ExportDialog::ExportDialog(PublicEditor& e, AudioRegion* r)
+SessionExportDialog::SessionExportDialog(PublicEditor& e, AudioRegion* r)
  	: ArdourDialog ("export dialog"),
  	  editor (e),
  	  format_table (9, 2),
@@ -156,7 +158,7 @@
  	master_selector.set_column_title (0, _("Output"));
  	master_selector.column_titles_show ();
  	master_selector.set_selection_mode (GTK_SELECTION_MULTIPLE);
-	master_selector.button_press_event.connect (slot (*this, 
&ExportDialog::master_selector_button_press_event));
+	master_selector.button_press_event.connect (slot (*this, 
&SessionExportDialog::master_selector_button_press_event));
  	
  	track_selector.set_name ("ExportTrackSelector");
  	track_selector.set_usize (-1, 130);
@@ -168,7 +170,7 @@
  	track_selector.set_column_title (0, _("Track"));
  	track_selector.column_titles_show ();
  	track_selector.set_selection_mode (GTK_SELECTION_MULTIPLE);
-	track_selector.button_press_event.connect (slot (*this, 
&ExportDialog::track_selector_button_press_event));
+	track_selector.button_press_event.connect (slot (*this, 
&SessionExportDialog::track_selector_button_press_event));

  	check_pixmap = gdk_pixmap_colormap_create_from_xpm_d (NULL,
  			gtk_widget_get_colormap(GTK_WIDGET(track_selector.gtkobj())),
@@ -214,7 +216,7 @@
  	vpacker.pack_start (hpacker, true, true);
  	
  	track_selector_button.set_name ("EditorGTKButton");
-	track_selector_button.clicked.connect (slot (*this, 
&ExportDialog::track_selector_button_click));
+	track_selector_button.clicked.connect (slot (*this, 
&SessionExportDialog::track_selector_button_click));

  	vpacker.pack_start (button_box, false, false);
  	vpacker.pack_start (progress_bar, false, false);
@@ -378,21 +380,21 @@
  	cancel_button.set_name ("EditorGTKButton");
  	file_entry.set_name ("ExportFileDisplay");

-	delete_event.connect (slot (*this, &ExportDialog::window_closed));
-	ok_button.clicked.connect (slot (*this, &ExportDialog::do_export));
-	cancel_button.clicked.connect (slot (*this, &ExportDialog::end_dialog));
+	delete_event.connect (slot (*this, &SessionExportDialog::window_closed));
+	ok_button.clicked.connect (slot (*this, &SessionExportDialog::do_export));
+	cancel_button.clicked.connect (slot (*this, 
&SessionExportDialog::end_dialog));
  	
  	file_browse_button.set_name ("EditorGTKButton");
-	file_browse_button.clicked.connect (slot (*this, 
&ExportDialog::initiate_browse));
+	file_browse_button.clicked.connect (slot (*this, 
&SessionExportDialog::initiate_browse));

-	channel_count_combo.get_popwin()->unmap_event.connect (slot (*this, 
&ExportDialog::channels_chosen));
-	bitdepth_format_combo.get_popwin()->unmap_event.connect (slot (*this, 
&ExportDialog::bitdepth_chosen));
-	header_format_combo.get_popwin()->unmap_event.connect (slot (*this, 
&ExportDialog::header_chosen));
-	sample_rate_combo.get_popwin()->unmap_event.connect (slot (*this, 
&ExportDialog::sample_rate_chosen));
-	cue_file_combo.get_popwin()->unmap_event.connect (slot (*this, 
&ExportDialog::cue_file_type_chosen));
+	channel_count_combo.get_popwin()->unmap_event.connect (slot (*this, 
&SessionExportDialog::channels_chosen));
+	bitdepth_format_combo.get_popwin()->unmap_event.connect (slot (*this, 
&SessionExportDialog::bitdepth_chosen));
+	header_format_combo.get_popwin()->unmap_event.connect (slot (*this, 
&SessionExportDialog::header_chosen));
+	sample_rate_combo.get_popwin()->unmap_event.connect (slot (*this, 
&SessionExportDialog::sample_rate_chosen));
+	cue_file_combo.get_popwin()->unmap_event.connect (slot (*this, 
&SessionExportDialog::cue_file_type_chosen));
  }

-ExportDialog::~ExportDialog()
+SessionExportDialog::~SessionExportDialog()
  {
  	if (file_selector) {
  		delete file_selector;
@@ -400,7 +402,7 @@
  }

  void
-ExportDialog::connect_to_session (Session *s)
+SessionExportDialog::connect_to_session (Session *s)
  {
  	session = s;
  	session->going_away.connect (slot (*this, &Window::hide_all));
@@ -435,7 +437,7 @@
  }

  void
-ExportDialog::set_state()
+SessionExportDialog::set_state()
  {
  	XMLNode* node = session->instant_xml(X_("ExportDialog"), 
session->path());
  	XMLProperty* prop;
@@ -551,7 +553,7 @@
  	}

  void
-ExportDialog::save_state()
+SessionExportDialog::save_state()
  {
  	if (!session) {
  		return;
@@ -589,7 +591,7 @@
  }

  void
-ExportDialog::set_range (jack_nframes_t start, jack_nframes_t end)
+SessionExportDialog::set_range (jack_nframes_t start, jack_nframes_t end)
  {
  	spec.start_frame = start;
  	spec.end_frame = end;
@@ -601,42 +603,27 @@
  }

  gint
-ExportDialog::progress_timeout ()
+SessionExportDialog::progress_timeout ()
  {
  	progress_bar.set_percentage (spec.progress);
  	return TRUE;
  }

  void*
-ExportDialog::_export_region_thread (void *arg)
+SessionExportDialog::_export_region_thread (void *arg)
  {
  	PBD::ThreadCreated (pthread_self(), X_("Export Region"));

-	static_cast<ExportDialog*>(arg)->export_region ();
+	static_cast<SessionExportDialog*>(arg)->export_region ();
  	return 0;
  }

  void
-ExportDialog::export_region ()
+SessionExportDialog::export_region ()
  {
  	audio_region->exportme (*session, spec);
  }

-void
-frames_to_cd_frames_string (char* buf, jack_nframes_t when, 
jack_nframes_t fr)
-{
-
-  long unsigned int remainder;
-  int mins, secs, frames;
-
-	mins = when / (60 * fr);
-	remainder = when - (mins * 60 * fr);
-	secs = remainder / fr;
-	remainder -= secs * fr;
-	frames = remainder / (fr / 75);
-	sprintf (buf, " %02d:%02d:%02d", mins, secs, frames);
-
-}

  struct LocationSortByStart {
      bool operator() (Location *a, Location *b) {
@@ -645,7 +632,7 @@
  };

  void
-ExportDialog::export_toc_file (Locations::LocationList& locations, 
const string& path)
+SessionExportDialog::export_toc_file (Locations::LocationList& 
locations, const string& path)
  {
  	
          string filepath = path + ".toc";
@@ -768,7 +755,7 @@
  }

  void
-ExportDialog::export_cue_file (Locations::LocationList& locations, 
const string& path)
+SessionExportDialog::export_cue_file (Locations::LocationList& 
locations, const string& path)
  {
          string filepath = path + ".cue";
  	ofstream out (filepath.c_str());
@@ -891,36 +878,22 @@
  }

  void
-ExportDialog::do_export_cd_markers (const string& path,const string& 
cuefile_type)
+SessionExportDialog::do_export_cd_markers (const string& path,const 
string& cuefile_type)
  {
  	if (cuefile_type == "TOC") {
-		session->locations()->apply (*this, &ExportDialog::export_toc_file, 
path);	
+		session->locations()->apply (*this, 
&SessionExportDialog::export_toc_file, path);	
  	} else {
-		session->locations()->apply (*this, &ExportDialog::export_cue_file, 
path);
+		session->locations()->apply (*this, 
&SessionExportDialog::export_cue_file, path);
  	}
  }


-void
-ExportDialog::do_export ()
-{
+/*
+	initializes spec, so that the export of a range can start
+*/
+void SessionExportDialog::initSpec(AudioExportSpecification &spec){
  	using namespace CList_Helpers;
-
-	ok_button.set_sensitive(false);
-	save_state();
-
-	if (cue_file_combo.get_entry()->get_text () != _("None")) {
-		do_export_cd_markers (file_entry.get_text(), 
cue_file_combo.get_entry()->get_text ());
-	}
-
-	if (cuefile_only_checkbox.get_active()) {
-		end_dialog ();
-		return;
-	}
-
-	set_modal (true);
  	
-	spec.path = file_entry.get_text();
  	spec.progress = 0;
  	spec.running = true;
  	spec.stop = false;
@@ -1046,25 +1019,39 @@
  			++chan;
  		}
  	}
+}

-	progress_connection = Main::timeout.connect (slot (*this, 
&ExportDialog::progress_timeout), 100);
-	cancel_label.set_text (_("Stop Export"));
+void
+SessionExportDialog::do_export ()
+{
+	ok_button.set_sensitive(false);
+	save_state();

-	if (!audio_region) {
-		if (session->start_audio_export (spec)) {
-			goto out;
-		}
-	} else {
-		pthread_t thr;
-		pthread_create_and_store ("region export", &thr, 0, 
ExportDialog::_export_region_thread, this);
+	if (cue_file_combo.get_entry()->get_text () != _("None")) {
+		do_export_cd_markers (file_entry.get_text(), 
cue_file_combo.get_entry()->get_text ());
  	}

-	gtk_main_iteration ();
-	while (spec.running) {
-		if (gtk_events_pending()) {
-			gtk_main_iteration ();
-		} else {
-			usleep (10000);
+	if (cuefile_only_checkbox.get_active()) {
+		end_dialog ();
+		return;
+	}
+
+	set_modal (true);
+	
+	progress_connection = Main::timeout.connect (slot (*this, 
&SessionExportDialog::progress_timeout), 100);
+	cancel_label.set_text (_("Stop Export"));
+
+	session->locations()->apply(*this, 
&SessionExportDialog::process_audioranges_export, spec);
+#if 0
+	goto out;
+#endif	
+	
+	gtk_main_iteration();
+	while(spec.running){
+		if(gtk_events_pending()){
+			gtk_main_iteration();
+		}else {
+			usleep(10000);
  		}
  	}
  	
@@ -1074,10 +1061,49 @@
  }
  	

-void
-ExportDialog::end_dialog ()
+void
+SessionExportDialog::process_audioranges_export(Locations::LocationList& 
locations, ARDOUR::AudioExportSpecification& spec)
  {
+	Locations::LocationList::iterator locationIter;
+
+	//XXX: ToDo: check somewhere if the given destination path is existing
+	// and if it is a path
+	
+	for (locationIter = locations.begin(); locationIter != 
locations.end(); ++locationIter) {
+		Location *currentLocation = (*locationIter);
+		
+		if(currentLocation->is_range()){
+			//XXX: ToDo: check if file_entry has "/" at the end
+			initSpec(spec);
+			spec.path = file_entry.get_text() + '/' + currentLocation->name() + 
".wav";
+			spec.start_frame = currentLocation->start();
+			spec.end_frame = currentLocation->end();
+
+			session->request_locate(spec.start_frame, false);
+
+			//XXX: ToDo: what to do when start_audio_export fails? before it was
+			// goto out; in method do_export
+			session->start_audio_export(spec);
+
+			// wait until export of this range finished
+			gtk_main_iteration();
+			while(spec.running){
+				if(gtk_events_pending()){
+					gtk_main_iteration();
+				}else {
+					usleep(10000);
+				}
+			}
+			
+			session->engine().freewheel (false);
+		}
+	}
+}

+
+void
+SessionExportDialog::end_dialog ()
+{
  	if (spec.running) {
  		spec.stop = true;

@@ -1103,7 +1129,7 @@
  }

  void
-ExportDialog::start_export ()
+SessionExportDialog::start_export ()
  {
  	if (session == 0) {
  		return;
@@ -1139,7 +1165,7 @@
  }

  gint
-ExportDialog::header_chosen (GdkEventAny* ignored)
+SessionExportDialog::header_chosen (GdkEventAny* ignored)
  {
  	if (sndfile_header_format_from_string 
(header_format_combo.get_entry()->get_text ()) == SF_FORMAT_WAV) {
  		endian_format_combo.set_sensitive (false);
@@ -1150,7 +1176,7 @@
  }

  gint
-ExportDialog::bitdepth_chosen (GdkEventAny* ignored)
+SessionExportDialog::bitdepth_chosen (GdkEventAny* ignored)
  {
  	int format = sndfile_bitdepth_format_from_string 
(bitdepth_format_combo.get_entry()->get_text ());	
  	switch (format) {
@@ -1169,7 +1195,7 @@
  }

  gint
-ExportDialog::cue_file_type_chosen (GdkEventAny* ignored)
+SessionExportDialog::cue_file_type_chosen (GdkEventAny* ignored)
  {
  	if (cue_file_combo.get_entry()->get_text () != "None") {
  		cuefile_only_checkbox.set_sensitive (true);
@@ -1181,7 +1207,7 @@
  }

  gint
-ExportDialog::sample_rate_chosen (GdkEventAny* ignored)
+SessionExportDialog::sample_rate_chosen (GdkEventAny* ignored)
  {
  	string sr_str = sample_rate_combo.get_entry()->get_text();
  	jack_nframes_t rate;
@@ -1212,7 +1238,7 @@
  }

  gint
-ExportDialog::channels_chosen (GdkEventAny* ignored)
+SessionExportDialog::channels_chosen (GdkEventAny* ignored)
  {
  	bool mono;

@@ -1290,7 +1316,7 @@
  }

  gint
-ExportDialog::track_selector_button_press_event (GdkEventButton* ev)
+SessionExportDialog::track_selector_button_press_event (GdkEventButton* ev)
  {
  	gint row, col;

@@ -1314,7 +1340,7 @@
  }

  gint
-ExportDialog::master_selector_button_press_event (GdkEventButton* ev)
+SessionExportDialog::master_selector_button_press_event 
(GdkEventButton* ev)
  {
  	gint row, col;

@@ -1338,35 +1364,35 @@
  }

  gint
-ExportDialog::window_closed (GdkEventAny *ignored)
+SessionExportDialog::window_closed (GdkEventAny *ignored)
  {
  	end_dialog ();
  	return TRUE;
  }
  void
-ExportDialog::initiate_browse ()
+SessionExportDialog::initiate_browse ()
  {
  	if (file_selector == 0) {
  		file_selector = new FileSelection;
  		file_selector->set_modal (true);

-		file_selector->get_cancel_button()->clicked.connect (bind (slot 
(*this, &ExportDialog::finish_browse), -1));
-		file_selector->get_ok_button()->clicked.connect (bind (slot (*this, 
&ExportDialog::finish_browse), 1));
-		file_selector->map_event.connect (bind (slot (*this, 
&ExportDialog::change_focus_policy), true));
-		file_selector->unmap_event.connect (bind (slot (*this, 
&ExportDialog::change_focus_policy), false));
+		file_selector->get_cancel_button()->clicked.connect (bind (slot 
(*this, &SessionExportDialog::finish_browse), -1));
+		file_selector->get_ok_button()->clicked.connect (bind (slot (*this, 
&SessionExportDialog::finish_browse), 1));
+		file_selector->map_event.connect (bind (slot (*this, 
&SessionExportDialog::change_focus_policy), true));
+		file_selector->unmap_event.connect (bind (slot (*this, 
&SessionExportDialog::change_focus_policy), false));
  	}
  	file_selector->show_all ();
  }

  gint
-ExportDialog::change_focus_policy (GdkEventAny *ev, bool yn)
+SessionExportDialog::change_focus_policy (GdkEventAny *ev, bool yn)
  {
  	Keyboard::the_keyboard().allow_focus (yn);
  	return FALSE;
  }

  void
-ExportDialog::finish_browse (int status)
+SessionExportDialog::finish_browse (int status)
  {
  	if (file_selector) {
  		if (status > 0) {
@@ -1381,7 +1407,7 @@
  }

  void
-ExportDialog::track_selector_button_click ()
+SessionExportDialog::track_selector_button_click ()
  {
  	if (track_scroll.is_visible ()) {
  		track_scroll.hide ();


8) diff of new file session_export_dialog.h against export_dialog.h
-------------------------------------------------------------------
--- gtk_ardour/export_dialog.h	2005-12-17 21:55:56.000000000 +0100
+++ gtk_ardour/session_export_dialog.h	2006-01-02 10:40:24.000000000 +0100
@@ -17,8 +17,8 @@

  */

-#ifndef __ardour_export_dialog_h__
-#define __ardour_export_dialog_h__
+#ifndef __ardour_session_export_dialog_h__
+#define __ardour_session_export_dialog_h__

  #include <gtk--.h>

@@ -34,11 +34,11 @@
  	class AudioRegion;
  }

-class ExportDialog : public ArdourDialog
+class SessionExportDialog : public ArdourDialog
  {
    public:
-	ExportDialog (PublicEditor&, ARDOUR::AudioRegion* r = 0);
-	~ExportDialog ();
+	SessionExportDialog (PublicEditor&, ARDOUR::AudioRegion* r = 0);
+	~SessionExportDialog ();

  	void connect_to_session (ARDOUR::Session*);
  	void set_range (jack_nframes_t start, jack_nframes_t end);
@@ -109,10 +109,13 @@
  	gint track_selector_button_press_event (GdkEventButton *ev);
  	gint master_selector_button_press_event (GdkEventButton *ev);

-      	void do_export_cd_markers (const string& path, const string& 
cuefile_type);
+    void do_export_cd_markers (const string& path, const string& 
cuefile_type);
+	void initSpec(ARDOUR::AudioExportSpecification &spec);
  	void export_cue_file (ARDOUR::Locations::LocationList& locations, 
const string& path);
  	void export_toc_file (ARDOUR::Locations::LocationList& locations, 
const string& path);
   	void do_export ();
+	void process_audioranges_export(ARDOUR::Locations::LocationList& 
locations, ARDOUR::AudioExportSpecification& spec);
+
  	gint change_focus_policy (GdkEventAny *, bool);
  	gint window_closed (GdkEventAny *ignored);

@@ -128,4 +131,4 @@
  	void export_region ();
  };

-#endif // __ardour_export_dialog_h__
+#endif // __ardour_session_export_dialog_h__



More information about the Ardour-Dev mailing list