projects
/
ardour.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
son't try to select non-existent notes after editing (and thus crash).
[ardour.git]
/
gtk2_ardour
/
editor_snapshots.cc
diff --git
a/gtk2_ardour/editor_snapshots.cc
b/gtk2_ardour/editor_snapshots.cc
index 140e04d09ffa7f9a91270d9ee71494dce408db53..b90737cd08dd28b8ba5952fbb885407e215b28c8 100644
(file)
--- a/
gtk2_ardour/editor_snapshots.cc
+++ b/
gtk2_ardour/editor_snapshots.cc
@@
-17,15
+17,25
@@
*/
*/
+
+#include <glib.h>
+#include "pbd/gstdio_compat.h"
+
+#include <glibmm.h>
+#include <glibmm/datetime.h>
+
#include <gtkmm/liststore.h>
#include <gtkmm/liststore.h>
+
#include "gtkmm2ext/choice.h"
#include "gtkmm2ext/choice.h"
+
+#include "ardour/filename_extensions.h"
#include "ardour/session.h"
#include "ardour/session_state_utils.h"
#include "ardour/session_directory.h"
#include "ardour/session.h"
#include "ardour/session_state_utils.h"
#include "ardour/session_directory.h"
+
#include "editor_snapshots.h"
#include "ardour_ui.h"
#include "editor_snapshots.h"
#include "ardour_ui.h"
-#include "i18n.h"
-#include "editor.h"
+#include "pbd/i18n.h"
#include "utils.h"
#include "prompter.h"
#include "utils.h"
#include "prompter.h"
@@
-33,6
+43,7
@@
using namespace std;
using namespace PBD;
using namespace Gtk;
using namespace ARDOUR;
using namespace PBD;
using namespace Gtk;
using namespace ARDOUR;
+using namespace ARDOUR_UI_UTILS;
EditorSnapshots::EditorSnapshots (Editor* e)
: EditorComponent (e)
EditorSnapshots::EditorSnapshots (Editor* e)
: EditorComponent (e)
@@
-40,7
+51,7
@@
EditorSnapshots::EditorSnapshots (Editor* e)
_model = ListStore::create (_columns);
_display.set_model (_model);
_display.append_column (X_("snapshot"), _columns.visible_name);
_model = ListStore::create (_columns);
_display.set_model (_model);
_display.append_column (X_("snapshot"), _columns.visible_name);
- _display.
set_name ("SnapshotDisplay"
);
+ _display.
append_column (X_("lastmod"), _columns.time_formatted
);
_display.set_size_request (75, -1);
_display.set_headers_visible (false);
_display.set_reorderable (false);
_display.set_size_request (75, -1);
_display.set_headers_visible (false);
_display.set_reorderable (false);
@@
-122,7
+133,7
@@
EditorSnapshots::popup_context_menu (int button, int32_t time, std::string snaps
add_item_with_sensitivity (items, MenuElem (_("Remove"), sigc::bind (sigc::mem_fun (*this, &EditorSnapshots::remove), snapshot_name)), modification_allowed);
add_item_with_sensitivity (items, MenuElem (_("Remove"), sigc::bind (sigc::mem_fun (*this, &EditorSnapshots::remove), snapshot_name)), modification_allowed);
- add_item_with_sensitivity (items, MenuElem (_("Rename"), sigc::bind (sigc::mem_fun (*this, &EditorSnapshots::rename), snapshot_name)), modification_allowed);
+ add_item_with_sensitivity (items, MenuElem (_("Rename
...
"), sigc::bind (sigc::mem_fun (*this, &EditorSnapshots::rename), snapshot_name)), modification_allowed);
_menu.popup (button, time);
}
_menu.popup (button, time);
}
@@
-135,6
+146,7
@@
EditorSnapshots::rename (std::string old_name)
string new_name;
prompter.set_name ("Prompter");
string new_name;
prompter.set_name ("Prompter");
+ prompter.set_title (_("Rename Snapshot"));
prompter.add_button (Gtk::Stock::SAVE, Gtk::RESPONSE_ACCEPT);
prompter.set_prompt (_("New name of snapshot"));
prompter.set_initial_text (old_name);
prompter.add_button (Gtk::Stock::SAVE, Gtk::RESPONSE_ACCEPT);
prompter.set_prompt (_("New name of snapshot"));
prompter.set_initial_text (old_name);
@@
-174,7
+186,7
@@
EditorSnapshots::redisplay ()
return;
}
return;
}
- vector<s
ys::path
> state_file_paths;
+ vector<s
td::string
> state_file_paths;
get_state_files_in_directory (_session->session_directory().root_path(),
state_file_paths);
get_state_files_in_directory (_session->session_directory().root_path(),
state_file_paths);
@@
-203,8
+215,15
@@
EditorSnapshots::redisplay ()
_display.get_selection()->select(row);
}
_display.get_selection()->select(row);
}
+ std::string s = Glib::build_filename (_session->path(), statename + ARDOUR::statefile_suffix);
+
+ GStatBuf gsb;
+ g_stat (s.c_str(), &gsb);
+ Glib::DateTime gdt(Glib::DateTime::create_now_local (gsb.st_mtime));
+
row[_columns.visible_name] = display_name;
row[_columns.real_name] = statename;
row[_columns.visible_name] = display_name;
row[_columns.real_name] = statename;
+ row[_columns.time_formatted] = gdt.format ("%F %H:%M");
}
}
}
}