packaging tweaks for OS X
[ardour.git] / gtk2_ardour / sfdb_ui.h
index 24cb08cc1b1602f8a681f10191df0555c3a2f3d1..249ebf3535834d6d49662c4b8c0578abc6cc535f 100644 (file)
 #include <string>
 #include <vector>
 #include <map>
-#include <glibmm/ustring.h>
 
 #include <sigc++/signal.h>
 
+#include <gtkmm/stock.h>
 #include <gtkmm/box.h>
 #include <gtkmm/button.h>
 #include <gtkmm/checkbutton.h>
 #include <gtkmm/filechooserwidget.h>
 #include <gtkmm/frame.h>
 #include <gtkmm/label.h>
+#include <gtkmm/textview.h>
+#include <gtkmm/table.h>
+#include <gtkmm/liststore.h>
+#include <gtkmm/spinbutton.h>
+#include <gtkmm/notebook.h>
 
-#include <ardour/session.h>
-#include <ardour/audiofilesource.h>
+
+#include "ardour/audiofilesource.h"
+#include "ardour/session_handle.h"
 
 #include "ardour_dialog.h"
 #include "editing.h"
+#include "audio_clock.h"
 
 namespace ARDOUR {
        class Session;
 };
 
 class GainMeter;
+class Mootcher;
 
-class SoundFileBox : public Gtk::VBox
+class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr
 {
   public:
        SoundFileBox (bool persistent);
        virtual ~SoundFileBox () {};
-       
+
        void set_session (ARDOUR::Session* s);
-       bool setup_labels (const Glib::ustring& filename);
+       bool setup_labels (const std::string& filename);
 
        void audition();
        bool audition_oneshot();
        bool autoplay () const;
 
   protected:
-       ARDOUR::Session* _session;
-       Glib::ustring path;
-       
+       std::string path;
+
        ARDOUR::SoundFileInfo sf_info;
-       
+
        Gtk::Table table;
-       
+
        Gtk::Label length;
        Gtk::Label format;
        Gtk::Label channels;
@@ -78,7 +85,7 @@ class SoundFileBox : public Gtk::VBox
 
        Gtk::Label channels_value;
        Gtk::Label samplerate_value;
-       
+
        Gtk::Label format_text;
        AudioClock length_clock;
        AudioClock timecode_clock;
@@ -87,11 +94,11 @@ class SoundFileBox : public Gtk::VBox
        Gtk::Label preview_label;
 
        Gtk::TextView tags_entry;
-       
+
        Gtk::VBox main_box;
        Gtk::VBox path_box;
        Gtk::HBox bottom_box;
-       
+
        Gtk::Button play_btn;
        Gtk::Button stop_btn;
        Gtk::CheckButton autoplay_btn;
@@ -109,24 +116,42 @@ class SoundFileBrowser : public ArdourDialog
        class FoundTagColumns : public Gtk::TreeModel::ColumnRecord
        {
          public:
-               Gtk::TreeModelColumn<Glib::ustring> pathname;
-               
+               Gtk::TreeModelColumn<std::string> pathname;
+
                FoundTagColumns() { add(pathname); }
        };
-       
+
+       class FreesoundColumns : public Gtk::TreeModel::ColumnRecord
+       {
+         public:
+               Gtk::TreeModelColumn<std::string> id;
+               Gtk::TreeModelColumn<std::string> uri;
+               Gtk::TreeModelColumn<std::string> filename;
+               Gtk::TreeModelColumn<std::string> duration;
+
+               FreesoundColumns() {
+                       add(id); 
+                       add(filename); 
+                       add(uri);
+                       add(duration);
+               }
+       };
+
        FoundTagColumns found_list_columns;
        Glib::RefPtr<Gtk::ListStore> found_list;
 
-       FoundTagColumns freesound_list_columns;
+       FreesoundColumns freesound_list_columns;
        Glib::RefPtr<Gtk::ListStore> freesound_list;
 
+       Gtk::Button freesound_stop_btn;
+
   public:
        SoundFileBrowser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, bool persistent);
        virtual ~SoundFileBrowser ();
-       
+
        virtual void set_session (ARDOUR::Session*);
-       std::vector<Glib::ustring> get_paths ();
-       
+       std::vector<std::string> get_paths ();
+
        void clear_selection ();
 
        Gtk::FileChooserWidget chooser;
@@ -137,24 +162,34 @@ class SoundFileBrowser : public ArdourDialog
        Gtk::Button found_search_btn;
        Gtk::TreeView found_list_view;
 
-       Gtk::Entry freesound_name_entry;
-       Gtk::Entry freesound_pass_entry;
        Gtk::Entry freesound_entry;
+       Gtk::ComboBoxText freesound_sort;
+       Gtk::SpinButton freesound_page;
+       
        Gtk::Button freesound_search_btn;
        Gtk::TreeView freesound_list_view;
+       Gtk::ProgressBar freesound_progress_bar;
 
-       void freesound_search_thread();
+       bool freesound_search_cancel;
+       bool freesound_download_cancel;
+
+       void freesound_search();
+       
+#ifdef FREESOUND
+       Mootcher *mootcher;
+#endif
 
   protected:
        bool resetting_ourselves;
-       
+
+       Gtk::FileFilter audio_and_midi_filter;
        Gtk::FileFilter audio_filter;
        Gtk::FileFilter midi_filter;
        Gtk::FileFilter custom_filter;
        Gtk::FileFilter matchall_filter;
        Gtk::HBox hpacker;
 
-       static Glib::ustring persistent_folder;
+       static std::string persistent_folder;
 
        Gtk::Notebook notebook;
 
@@ -176,11 +211,13 @@ class SoundFileBrowser : public ArdourDialog
        void freesound_list_view_selected ();
        void freesound_list_view_activated (const Gtk::TreeModel::Path& path, Gtk::TreeViewColumn*);
        void freesound_search_clicked ();
+       void freesound_stop_clicked ();
        
        void chooser_file_activated ();
-       
+
        bool on_audio_filter (const Gtk::FileFilter::Info& filter_info);
        bool on_midi_filter (const Gtk::FileFilter::Info& filter_info);
+       bool on_audio_and_midi_filter (const Gtk::FileFilter::Info& filter_info);
 
        virtual bool reset_options() { return true; }
 
@@ -194,8 +231,8 @@ class SoundFileChooser : public SoundFileBrowser
   public:
        SoundFileChooser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s = 0);
        virtual ~SoundFileChooser () {};
-       
-       Glib::ustring get_filename ();
+
+       std::string get_filename ();
 
   protected:
        void on_hide();
@@ -205,11 +242,13 @@ class SoundFileOmega : public SoundFileBrowser
 {
 
   public:
-       SoundFileOmega (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, int selected_tracks, bool persistent, 
+       SoundFileOmega (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, 
+                       uint32_t selected_audio_tracks, uint32_t selected_midi_tracks,
+                       bool persistent,
                        Editing::ImportMode mode_hint = Editing::ImportAsTrack);
-       
-       void reset (int selected_tracks);
-       
+
+       void reset (uint32_t selected_audio_tracks, uint32_t selected_midi_tracks);
+
        Gtk::ComboBoxText action_combo;
        Gtk::ComboBoxText where_combo;
        Gtk::ComboBoxText channel_combo;
@@ -227,9 +266,10 @@ class SoundFileOmega : public SoundFileBrowser
        void on_hide();
 
   private:
-       uint32_t selected_track_cnt;
+       uint32_t selected_audio_track_cnt;
+       uint32_t selected_midi_track_cnt;
 
-       typedef std::map<Glib::ustring,Editing::ImportDisposition> DispositionMap;
+       typedef std::map<std::string,Editing::ImportDisposition> DispositionMap;
        DispositionMap disposition_map;
 
        Gtk::HBox options;
@@ -237,10 +277,10 @@ class SoundFileOmega : public SoundFileBrowser
        Gtk::VBox block_three;
        Gtk::VBox block_four;
 
-       bool check_info (const std::vector<Glib::ustring>& paths, 
+       bool check_info (const std::vector<std::string>& paths,
                         bool& same_size, bool& src_needed, bool& multichannel);
 
-       static bool check_link_status (const ARDOUR::Session&, const std::vector<Glib::ustring>& paths);
+       static bool check_link_status (const ARDOUR::Session*, const std::vector<std::string>& paths);
 
        void file_selection_changed ();
        bool reset_options ();