summaryrefslogtreecommitdiffstats
path: root/src/gui/LoadPatchWindow.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/LoadPatchWindow.cpp')
-rw-r--r--src/gui/LoadPatchWindow.cpp161
1 files changed, 123 insertions, 38 deletions
diff --git a/src/gui/LoadPatchWindow.cpp b/src/gui/LoadPatchWindow.cpp
index bba7c75d..4f724e6b 100644
--- a/src/gui/LoadPatchWindow.cpp
+++ b/src/gui/LoadPatchWindow.cpp
@@ -17,20 +17,23 @@
#include <sys/types.h>
#include <dirent.h>
-#include <boost/optional/optional.hpp>
+#include <cassert>
+#include <boost/optional.hpp>
+#include <glibmm/miscutils.h>
#include "interface/EngineInterface.hpp"
#include "shared/LV2URIMap.hpp"
-#include "shared/runtime_paths.hpp"
+#include "client/NodeModel.hpp"
#include "client/PatchModel.hpp"
+#include "client/ClientStore.hpp"
+#include "shared/runtime_paths.hpp"
#include "App.hpp"
-#include "Configuration.hpp"
#include "LoadPatchWindow.hpp"
+#include "PatchView.hpp"
+#include "Configuration.hpp"
#include "ThreadedLoader.hpp"
-using namespace Ingen::Serialisation;
using boost::optional;
using namespace std;
-using namespace std;
using namespace Raul;
namespace Ingen {
@@ -39,40 +42,45 @@ namespace GUI {
LoadPatchWindow::LoadPatchWindow(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& xml)
: Gtk::FileChooserDialog(cobject)
- , _merge_ports(true)
+ , _merge_ports(false)
{
+ xml->get_widget("load_patch_symbol_label", _symbol_label);
+ xml->get_widget("load_patch_symbol_entry", _symbol_entry);
+ xml->get_widget("load_patch_ports_label", _ports_label);
+ xml->get_widget("load_patch_merge_ports_radio", _merge_ports_radio);
+ xml->get_widget("load_patch_insert_ports_radio", _insert_ports_radio);
xml->get_widget("load_patch_poly_voices_radio", _poly_voices_radio);
xml->get_widget("load_patch_poly_from_file_radio", _poly_from_file_radio);
xml->get_widget("load_patch_poly_spinbutton", _poly_spinbutton);
- xml->get_widget("load_patch_merge_ports_radio", _merge_ports_radio);
- xml->get_widget("load_patch_insert_ports_radio", _insert_ports_radio);
xml->get_widget("load_patch_ok_button", _ok_button);
xml->get_widget("load_patch_cancel_button", _cancel_button);
- _poly_from_file_radio->signal_toggled().connect(
- sigc::mem_fun(this, &LoadPatchWindow::poly_from_file_selected));
_poly_voices_radio->signal_toggled().connect(
- sigc::mem_fun(this, &LoadPatchWindow::poly_voices_selected));
+ sigc::mem_fun(this, &LoadPatchWindow::enable_poly_spinner));
+ _cancel_button->signal_clicked().connect(
+ sigc::mem_fun(this, &LoadPatchWindow::cancel_clicked));
+ _ok_button->signal_clicked().connect(
+ sigc::mem_fun(this, &LoadPatchWindow::ok_clicked));
_merge_ports_radio->signal_toggled().connect(
sigc::mem_fun(this, &LoadPatchWindow::merge_ports_selected));
_insert_ports_radio->signal_toggled().connect(
sigc::mem_fun(this, &LoadPatchWindow::insert_ports_selected));
- _ok_button->signal_clicked().connect(
- sigc::mem_fun(this, &LoadPatchWindow::ok_clicked));
- _cancel_button->signal_clicked().connect(
- sigc::mem_fun(this, &LoadPatchWindow::cancel_clicked));
- _poly_voices_radio->set_active(true);
+ signal_selection_changed().connect(
+ sigc::mem_fun(this, &LoadPatchWindow::selection_changed));
Gtk::FileFilter filt;
- filt.add_pattern("*.om");
- filt.set_name("Om patch files (XML, DEPRECATED) (*.om)");
- filt.add_pattern("*.ingen.lv2");
- filt.set_name("Ingen bundles (*.ingen.lv2)");
filt.add_pattern("*.ingen.ttl");
filt.set_name("Ingen patch files (*.ingen.ttl)");
+ filt.add_pattern("*.ingen.lv2");
+ filt.set_name("Ingen bundles (*.ingen.lv2)");
+ filt.add_pattern("*.om");
+ filt.set_name("Om patch files (*.om)");
+
set_filter(filt);
+ property_select_multiple() = true;
+
// Add global examples directory to "shortcut folders" (bookmarks)
const string examples_dir = Shared::data_file_path("patches");
DIR* d = opendir(examples_dir.c_str());
@@ -84,9 +92,15 @@ LoadPatchWindow::LoadPatchWindow(BaseObjectType* cobject, const Glib::RefPtr<Gno
void
-LoadPatchWindow::present(SharedPtr<PatchModel> patch, GraphObject::Properties data)
+LoadPatchWindow::present(SharedPtr<PatchModel> patch, bool import, GraphObject::Properties data)
{
+ _import = import;
set_patch(patch);
+ _symbol_label->set_visible(!import);
+ _symbol_entry->set_visible(!import);
+ _ports_label->set_visible(_import);
+ _merge_ports_radio->set_visible(_import);
+ _insert_ports_radio->set_visible(_import);
_initial_data = data;
Gtk::Window::present();
}
@@ -99,7 +113,10 @@ LoadPatchWindow::present(SharedPtr<PatchModel> patch, GraphObject::Properties da
void
LoadPatchWindow::set_patch(SharedPtr<PatchModel> patch)
{
+ std::cout << "SET PATCH: " << patch->path() << endl;
_patch = patch;
+ _symbol_entry->set_text("");
+ _symbol_entry->set_sensitive(!_import);
_poly_spinbutton->set_value(patch->poly());
}
@@ -117,18 +134,19 @@ LoadPatchWindow::on_show()
void
-LoadPatchWindow::poly_from_file_selected()
+LoadPatchWindow::disable_poly_spinner()
{
_poly_spinbutton->property_sensitive() = false;
}
void
-LoadPatchWindow::poly_voices_selected()
+LoadPatchWindow::enable_poly_spinner()
{
_poly_spinbutton->property_sensitive() = true;
}
+
void
LoadPatchWindow::merge_ports_selected()
{
@@ -146,39 +164,106 @@ LoadPatchWindow::insert_ports_selected()
void
LoadPatchWindow::ok_clicked()
{
- if (!_patch)
+ if (!_patch) {
+ hide();
return;
+ }
- // If unset load_patch will load value
- optional<Path> parent;
- optional<Symbol> symbol;
+ const LV2URIMap& uris = App::instance().uris();
if (_poly_voices_radio->get_active())
_initial_data.insert(make_pair(
- App::instance().uris().ingen_polyphony,
- _poly_spinbutton->get_value_as_int()));
-
- if (!_patch->path().is_root()) {
- parent = _patch->path().parent();
- symbol = _patch->symbol();
+ uris.ingen_polyphony,
+ _poly_spinbutton->get_value_as_int()));
+
+ if (_import) {
+ // If unset load_patch will load value
+ optional<Path> parent;
+ optional<Symbol> symbol;
+ if (!_patch->path().is_root()) {
+ parent = _patch->path().parent();
+ symbol = _patch->symbol();
+ }
+
+ cout << "MERGE PORTS: " << _merge_ports << endl;
+
+ App::instance().loader()->load_patch(true, get_uri(), Path("/"),
+ parent, symbol, _initial_data);
+
+ } else {
+ std::list<Glib::ustring> uri_list = get_uris();
+ for (std::list<Glib::ustring>::iterator i = uri_list.begin(); i != uri_list.end(); ++i) {
+ // Cascade
+ Atom& x = _initial_data.find(uris.ingenui_canvas_x)->second;
+ x = Atom(x.get_float() + 20.0f);
+ Atom& y = _initial_data.find(uris.ingenui_canvas_y)->second;
+ y = Atom(y.get_float() + 20.0f);
+
+ Raul::Symbol symbol(symbol_from_filename(*i));
+ if (uri_list.size() == 1 && _symbol_entry->get_text() != "")
+ symbol = Symbol::symbolify(_symbol_entry->get_text());
+
+ symbol = avoid_symbol_clash(symbol);
+
+ App::instance().loader()->load_patch(false, *i, Path("/"),
+ _patch->path(), symbol, _initial_data);
+ }
}
- cout << "MERGE PORTS: " << _merge_ports << endl;
-
_patch.reset();
hide();
-
- App::instance().loader()->load_patch(true, get_uri(), Path("/"),
- parent, symbol, _initial_data);
}
void
LoadPatchWindow::cancel_clicked()
{
+ _patch.reset();
hide();
}
+Raul::Symbol
+LoadPatchWindow::symbol_from_filename(const Glib::ustring& filename)
+{
+ std::string symbol_str = Glib::path_get_basename(get_filename());
+ symbol_str = symbol_str.substr(0, symbol_str.find('.'));
+ return Raul::Symbol::symbolify(symbol_str);
+}
+
+
+Raul::Symbol
+LoadPatchWindow::avoid_symbol_clash(const Raul::Symbol& symbol)
+{
+ unsigned offset = App::instance().store()->child_name_offset(
+ _patch->path(), symbol);
+
+ if (offset != 0) {
+ std::stringstream ss;
+ ss << symbol << "_" << offset;
+ return ss.str();
+ } else {
+ return symbol;
+ }
+}
+
+
+void
+LoadPatchWindow::selection_changed()
+{
+ if (_import)
+ return;
+
+ if (get_filenames().size() != 1) {
+ _symbol_entry->set_text("");
+ _symbol_entry->set_sensitive(false);
+ } else {
+ _symbol_entry->set_text(avoid_symbol_clash(
+ symbol_from_filename(get_filename()).c_str()).c_str());
+ _symbol_entry->set_sensitive(true);
+ }
+}
+
+
} // namespace GUI
} // namespace Ingen