summaryrefslogtreecommitdiffstats
path: root/src/gui/PatchWindow.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/PatchWindow.cpp')
-rw-r--r--src/gui/PatchWindow.cpp83
1 files changed, 49 insertions, 34 deletions
diff --git a/src/gui/PatchWindow.cpp b/src/gui/PatchWindow.cpp
index c4e7a39a..a9fe62d2 100644
--- a/src/gui/PatchWindow.cpp
+++ b/src/gui/PatchWindow.cpp
@@ -18,8 +18,9 @@
#include "PatchWindow.hpp"
#include <cassert>
#include <sstream>
-#include <fstream>
#include <boost/format.hpp>
+#include <glib/gstdio.h>
+#include <glibmm/fileutils.h>
#include "raul/AtomRDF.hpp"
#include "interface/EngineInterface.hpp"
#include "shared/LV2URIMap.hpp"
@@ -408,7 +409,8 @@ PatchWindow::event_save()
} else {
App::instance().loader()->save_patch(_patch, document.get_uri());
_status_bar->push(
- (boost::format("Wrote %1% to %2%") % _patch->path() % document.get_uri()).str(),
+ (boost::format("Saved %1% to %2%") % _patch->path().chop_scheme()
+ % document.get_uri()).str(),
STATUS_CONTEXT_PATCH);
}
}
@@ -426,8 +428,6 @@ PatchWindow::event_save_as()
save_button->property_has_default() = true;
Gtk::FileFilter filt;
- filt.add_pattern("*.ingen.ttl");
- filt.set_name("Ingen patches");
filt.add_pattern("*.ingen.lv2");
filt.set_name("Ingen bundles");
dialog.set_filter(filt);
@@ -442,50 +442,68 @@ PatchWindow::event_save_as()
if (dialog.run() != Gtk::RESPONSE_OK)
break;
- string filename = dialog.get_filename();
-
- string base = filename.substr(0, filename.find("."));
- if (base.find("/") != string::npos)
- base = base.substr(base.find_last_of("/") + 1);
+ std::string filename = dialog.get_filename();
+ std::string basename = Glib::path_get_basename(filename);
- if (!Symbol::is_valid(base)) {
+ if (basename.find('.') == string::npos) {
+ filename += ".ingen.lv2";
+ basename += ".ingen.lv2";
+ } else if (filename.substr(filename.length() - 10) != ".ingen.lv2") {
Gtk::MessageDialog error_dialog(*this,
- "<b>Ingen patch file names must be valid symbols</b>", true,
- Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
- error_dialog.set_secondary_text(
- "The first character must be _, a-z, or A-Z, and "
- "subsequent characters must be _, a-z, A-Z, or 0-9.");
+"<b>" "Ingen patches must be saved to Ingen bundles (*.ingen.lv2)." "</b>",
+ true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
error_dialog.run();
continue;
}
- const bool is_bundle = filename.find(".ingen.lv2") != string::npos;
- const bool is_patch = filename.find(".ingen.ttl") != string::npos;
+ const std::string symbol(basename.substr(0, basename.find('.')));
- // Save a bundle by default
- if (!is_bundle && !is_patch)
- filename += ".ingen.ttl";
+ if (!Symbol::is_valid(symbol)) {
+ Gtk::MessageDialog error_dialog(*this,
+ "<b>" "Ingen bundle names must be valid symbols." "</b>",
+ true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
+ error_dialog.set_secondary_text(
+"All characters must be _, a-z, A-Z, or 0-9, but the first may not be 0-9.");
+ error_dialog.run();
+ continue;
+ }
- _patch->set_property(uris.lv2_symbol, Atom(base.c_str()));
+ _patch->set_property(uris.lv2_symbol, Atom(symbol.c_str()));
bool confirm = true;
- std::fstream fin;
- fin.open(filename.c_str(), std::ios::in);
- if (fin.is_open()) { // File exists
- string msg = "File already exists! Are you sure you want to overwrite ";
- msg += filename + "?";
- Gtk::MessageDialog confirm_dialog(*this,
- msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_YES_NO, true);
+ if (Glib::file_test(filename, Glib::FILE_TEST_IS_DIR)) {
+ if (Glib::file_test(filename + "/manifest.ttl", Glib::FILE_TEST_EXISTS)) {
+ Gtk::MessageDialog confirm_dialog(*this, (boost::format("<b>"
+ "A bundle named \"%1%\" already exists. Replace it?"
+ "</b>") % basename).str(),
+ true, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_YES_NO, true);
+ confirm = (confirm_dialog.run() == Gtk::RESPONSE_YES);
+ } else {
+ Gtk::MessageDialog confirm_dialog(*this, (boost::format("<b>"
+"A directory named \"%1%\" already exists, but is not an Ingen bundle. \
+Save into it anyway?" "</b>") % basename).str(),
+ true, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_YES_NO, true);
+ confirm_dialog.set_secondary_text(
+"This will create at least 2 .ttl files in this directory, and possibly several \
+more files and/or directories, recursively. Existing files will be overwritten.");
+ confirm = (confirm_dialog.run() == Gtk::RESPONSE_YES);
+ }
+ } else if (Glib::file_test(filename, Glib::FILE_TEST_EXISTS)) {
+ Gtk::MessageDialog confirm_dialog(*this, (boost::format("<b>"
+"A file named \"%1%\" already exists. Replace it with an Ingen bundle?" "</b>") % basename).str(),
+ true, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_YES_NO, true);
confirm = (confirm_dialog.run() == Gtk::RESPONSE_YES);
+ if (confirm)
+ ::g_remove(filename.c_str());
}
- fin.close();
if (confirm) {
const Glib::ustring uri = Glib::filename_to_uri(filename);
App::instance().loader()->save_patch(_patch, uri);
_patch->set_property(uris.ingen_document, Atom(Atom::URI, uri.c_str()));
_status_bar->push(
- (boost::format("Wrote %1% to %2%") % _patch->path() % uri).str(),
+ (boost::format("Saved %1% to %2%") % _patch->path().chop_scheme()
+ % filename).str(),
STATUS_CONTEXT_PATCH);
}
@@ -519,16 +537,13 @@ PatchWindow::event_draw()
filename += ".dot";
bool confirm = true;
- std::fstream fin;
- fin.open(filename.c_str(), std::ios::in);
- if (fin.is_open()) { // File exists
+ if (Glib::file_test(filename, Glib::FILE_TEST_EXISTS)) {
const string msg = string("File exists!\n")
+ "Are you sure you want to overwrite " + filename + "?";
Gtk::MessageDialog confirm_dialog(*this,
msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_YES_NO, true);
confirm = (confirm_dialog.run() == Gtk::RESPONSE_YES);
}
- fin.close();
if (confirm) {
_view->canvas()->render_to_dot(filename);