forked from mia/Aegisub
Move autosave logic to SubsController
This commit is contained in:
parent
74028b9bcd
commit
a9467836f9
4 changed files with 33 additions and 32 deletions
|
@ -82,7 +82,6 @@
|
||||||
#include <wx/sysopt.h>
|
#include <wx/sysopt.h>
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
ID_APP_TIMER_AUTOSAVE = 12001,
|
|
||||||
ID_APP_TIMER_STATUSCLEAR = 12002
|
ID_APP_TIMER_STATUSCLEAR = 12002
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -92,8 +91,6 @@ enum {
|
||||||
#define StartupLog(a) LOG_I("frame_main/init") << a
|
#define StartupLog(a) LOG_I("frame_main/init") << a
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void autosave_timer_changed(wxTimer *timer);
|
|
||||||
|
|
||||||
wxDEFINE_EVENT(FILE_LIST_DROPPED, wxThreadEvent);
|
wxDEFINE_EVENT(FILE_LIST_DROPPED, wxThreadEvent);
|
||||||
|
|
||||||
static void get_files_to_load(wxArrayString const& list, std::string &subs, std::string &audio, std::string &video) {
|
static void get_files_to_load(wxArrayString const& list, std::string &subs, std::string &audio, std::string &video) {
|
||||||
|
@ -272,12 +269,6 @@ FrameMain::FrameMain (wxArrayString args)
|
||||||
StartupLog("Complete context initialization");
|
StartupLog("Complete context initialization");
|
||||||
context->videoController->SetContext(context.get());
|
context->videoController->SetContext(context.get());
|
||||||
|
|
||||||
StartupLog("Set up Auto Save");
|
|
||||||
AutoSave.SetOwner(this, ID_APP_TIMER_AUTOSAVE);
|
|
||||||
autosave_timer_changed(&AutoSave);
|
|
||||||
OPT_SUB("App/Auto/Save", autosave_timer_changed, &AutoSave);
|
|
||||||
OPT_SUB("App/Auto/Save Every Seconds", autosave_timer_changed, &AutoSave);
|
|
||||||
|
|
||||||
StartupLog("Set up drag/drop target");
|
StartupLog("Set up drag/drop target");
|
||||||
SetDropTarget(new AegisubFileDropTarget(this));
|
SetDropTarget(new AegisubFileDropTarget(this));
|
||||||
|
|
||||||
|
@ -550,15 +541,7 @@ bool FrameMain::LoadList(wxArrayString list) {
|
||||||
return loaded_any;
|
return loaded_any;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void autosave_timer_changed(wxTimer *timer) {
|
|
||||||
int freq = OPT_GET("App/Auto/Save Every Seconds")->GetInt();
|
|
||||||
if (freq > 0 && OPT_GET("App/Auto/Save")->GetBool())
|
|
||||||
timer->Start(freq * 1000);
|
|
||||||
else
|
|
||||||
timer->Stop();
|
|
||||||
}
|
|
||||||
BEGIN_EVENT_TABLE(FrameMain, wxFrame)
|
BEGIN_EVENT_TABLE(FrameMain, wxFrame)
|
||||||
EVT_TIMER(ID_APP_TIMER_AUTOSAVE, FrameMain::OnAutoSave)
|
|
||||||
EVT_TIMER(ID_APP_TIMER_STATUSCLEAR, FrameMain::OnStatusClear)
|
EVT_TIMER(ID_APP_TIMER_STATUSCLEAR, FrameMain::OnStatusClear)
|
||||||
|
|
||||||
EVT_CLOSE(FrameMain::OnCloseWindow)
|
EVT_CLOSE(FrameMain::OnCloseWindow)
|
||||||
|
@ -586,18 +569,6 @@ void FrameMain::OnCloseWindow(wxCloseEvent &event) {
|
||||||
Destroy();
|
Destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameMain::OnAutoSave(wxTimerEvent &) try {
|
|
||||||
auto fn = context->subsController->AutoSave();
|
|
||||||
if (!fn.empty())
|
|
||||||
StatusTimeout(wxString::Format(_("File backup saved as \"%s\"."), fn.wstring()));
|
|
||||||
}
|
|
||||||
catch (const agi::Exception& err) {
|
|
||||||
StatusTimeout(to_wx("Exception when attempting to autosave file: " + err.GetMessage()));
|
|
||||||
}
|
|
||||||
catch (...) {
|
|
||||||
StatusTimeout("Unhandled exception when attempting to autosave file.");
|
|
||||||
}
|
|
||||||
|
|
||||||
void FrameMain::OnStatusClear(wxTimerEvent &) {
|
void FrameMain::OnStatusClear(wxTimerEvent &) {
|
||||||
SetStatusText("",1);
|
SetStatusText("",1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,6 @@ class FrameMain: public wxFrame {
|
||||||
|
|
||||||
bool showVideo; ///< Is the video display shown?
|
bool showVideo; ///< Is the video display shown?
|
||||||
bool showAudio; ///< Is the audio display shown?
|
bool showAudio; ///< Is the audio display shown?
|
||||||
wxTimer AutoSave; ///< Autosave timer
|
|
||||||
wxTimer StatusClear; ///< Status bar timeout timer
|
wxTimer StatusClear; ///< Status bar timeout timer
|
||||||
/// Block video loading; used when both video and subtitles are opened at
|
/// Block video loading; used when both video and subtitles are opened at
|
||||||
/// the same time, so that the video associated with the subtitles (if any)
|
/// the same time, so that the video associated with the subtitles (if any)
|
||||||
|
@ -94,8 +93,6 @@ class FrameMain: public wxFrame {
|
||||||
void OnKeyDown(wxKeyEvent &event);
|
void OnKeyDown(wxKeyEvent &event);
|
||||||
void OnMouseWheel(wxMouseEvent &evt);
|
void OnMouseWheel(wxMouseEvent &evt);
|
||||||
|
|
||||||
/// @brief Autosave the currently open file, if any
|
|
||||||
void OnAutoSave(wxTimerEvent &event);
|
|
||||||
void OnStatusClear(wxTimerEvent &event);
|
void OnStatusClear(wxTimerEvent &event);
|
||||||
void OnCloseWindow (wxCloseEvent &event);
|
void OnCloseWindow (wxCloseEvent &event);
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,9 @@
|
||||||
#include "ass_style.h"
|
#include "ass_style.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "command/command.h"
|
#include "command/command.h"
|
||||||
|
#include "frame_main.h"
|
||||||
#include "include/aegisub/context.h"
|
#include "include/aegisub/context.h"
|
||||||
|
#include "main.h"
|
||||||
#include "options.h"
|
#include "options.h"
|
||||||
#include "subtitle_format.h"
|
#include "subtitle_format.h"
|
||||||
#include "text_file_reader.h"
|
#include "text_file_reader.h"
|
||||||
|
@ -37,6 +39,16 @@
|
||||||
#include <boost/format.hpp>
|
#include <boost/format.hpp>
|
||||||
#include <wx/msgdlg.h>
|
#include <wx/msgdlg.h>
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
void autosave_timer_changed(wxTimer *timer) {
|
||||||
|
int freq = OPT_GET("App/Auto/Save Every Seconds")->GetInt();
|
||||||
|
if (freq > 0 && OPT_GET("App/Auto/Save")->GetBool())
|
||||||
|
timer->Start(freq * 1000);
|
||||||
|
else
|
||||||
|
timer->Stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
struct SubsController::UndoInfo {
|
struct SubsController::UndoInfo {
|
||||||
AssFile file;
|
AssFile file;
|
||||||
wxString undo_description;
|
wxString undo_description;
|
||||||
|
@ -51,6 +63,23 @@ SubsController::SubsController(agi::Context *context)
|
||||||
, saved_commit_id(0)
|
, saved_commit_id(0)
|
||||||
, autosaved_commit_id(0)
|
, autosaved_commit_id(0)
|
||||||
{
|
{
|
||||||
|
autosave_timer_changed(&autosave_timer);
|
||||||
|
OPT_SUB("App/Auto/Save", autosave_timer_changed, &autosave_timer);
|
||||||
|
OPT_SUB("App/Auto/Save Every Seconds", autosave_timer_changed, &autosave_timer);
|
||||||
|
|
||||||
|
autosave_timer.Bind(wxEVT_TIMER, [=](wxTimerEvent&) {
|
||||||
|
try {
|
||||||
|
auto fn = AutoSave();
|
||||||
|
if (!fn.empty())
|
||||||
|
wxTheApp->frame->StatusTimeout(wxString::Format(_("File backup saved as \"%s\"."), fn.wstring()));
|
||||||
|
}
|
||||||
|
catch (const agi::Exception& err) {
|
||||||
|
wxTheApp->frame->StatusTimeout(to_wx("Exception when attempting to autosave file: " + err.GetMessage()));
|
||||||
|
}
|
||||||
|
catch (...) {
|
||||||
|
wxTheApp->frame->StatusTimeout("Unhandled exception when attempting to autosave file.");
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void SubsController::Load(agi::fs::path const& filename, std::string const& charset) {
|
void SubsController::Load(agi::fs::path const& filename, std::string const& charset) {
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include <boost/container/list.hpp>
|
#include <boost/container/list.hpp>
|
||||||
#include <boost/filesystem/path.hpp>
|
#include <boost/filesystem/path.hpp>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <wx/timer.h>
|
||||||
|
|
||||||
class AssEntry;
|
class AssEntry;
|
||||||
class AssFile;
|
class AssFile;
|
||||||
|
@ -42,6 +43,9 @@ class SubsController {
|
||||||
/// Last autosaved version of this file
|
/// Last autosaved version of this file
|
||||||
int autosaved_commit_id;
|
int autosaved_commit_id;
|
||||||
|
|
||||||
|
/// Timer for triggering autosaves
|
||||||
|
wxTimer autosave_timer;
|
||||||
|
|
||||||
/// A new file has been opened (filename)
|
/// A new file has been opened (filename)
|
||||||
agi::signal::Signal<agi::fs::path> FileOpen;
|
agi::signal::Signal<agi::fs::path> FileOpen;
|
||||||
/// The file is about to be saved
|
/// The file is about to be saved
|
||||||
|
|
Loading…
Reference in a new issue