* loading TAS Editor projects by drag-n-drop
* Tasedit: File->Save Compact dialog
This commit is contained in:
parent
840528d52a
commit
a5ee28a447
|
@ -68,6 +68,7 @@ extern bool SingleInstanceOnly;
|
||||||
extern bool oldInputDisplay;
|
extern bool oldInputDisplay;
|
||||||
extern bool fullSaveStateLoads;
|
extern bool fullSaveStateLoads;
|
||||||
extern int frameSkipAmt;
|
extern int frameSkipAmt;
|
||||||
|
|
||||||
extern bool TASEdit_follow_playback;
|
extern bool TASEdit_follow_playback;
|
||||||
extern bool TASEdit_turbo_seek;
|
extern bool TASEdit_turbo_seek;
|
||||||
extern bool TASEdit_show_lag_frames;
|
extern bool TASEdit_show_lag_frames;
|
||||||
|
@ -89,6 +90,13 @@ extern int TasEdit_undo_levels;
|
||||||
extern int TASEdit_autosave_period;
|
extern int TASEdit_autosave_period;
|
||||||
extern bool TASEdit_jump_to_undo;
|
extern bool TASEdit_jump_to_undo;
|
||||||
extern int TASEdit_last_export_type;
|
extern int TASEdit_last_export_type;
|
||||||
|
extern bool TASEdit_savecompact_binary;
|
||||||
|
extern bool TASEdit_savecompact_markers;
|
||||||
|
extern bool TASEdit_savecompact_bookmarks;
|
||||||
|
extern bool TASEdit_savecompact_greenzone;
|
||||||
|
extern bool TASEdit_savecompact_history;
|
||||||
|
extern bool TASEdit_savecompact_selection;
|
||||||
|
extern bool TASEdit_savecompact_list;
|
||||||
extern char* recent_projects[];
|
extern char* recent_projects[];
|
||||||
|
|
||||||
//window positions and sizes:
|
//window positions and sizes:
|
||||||
|
@ -339,6 +347,13 @@ static CFGSTRUCT fceuconfig[] = {
|
||||||
AC(TASEdit_autosave_period),
|
AC(TASEdit_autosave_period),
|
||||||
AC(TASEdit_jump_to_undo),
|
AC(TASEdit_jump_to_undo),
|
||||||
AC(TASEdit_last_export_type),
|
AC(TASEdit_last_export_type),
|
||||||
|
AC(TASEdit_savecompact_binary),
|
||||||
|
AC(TASEdit_savecompact_markers),
|
||||||
|
AC(TASEdit_savecompact_bookmarks),
|
||||||
|
AC(TASEdit_savecompact_greenzone),
|
||||||
|
AC(TASEdit_savecompact_history),
|
||||||
|
AC(TASEdit_savecompact_selection),
|
||||||
|
AC(TASEdit_savecompact_list),
|
||||||
AC(lagCounterDisplay),
|
AC(lagCounterDisplay),
|
||||||
AC(oldInputDisplay),
|
AC(oldInputDisplay),
|
||||||
AC(movieSubtitles),
|
AC(movieSubtitles),
|
||||||
|
|
|
@ -222,7 +222,7 @@ BEGIN
|
||||||
MENUITEM "&Open", ID_FILE_OPENPROJECT
|
MENUITEM "&Open", ID_FILE_OPENPROJECT
|
||||||
MENUITEM "&Save\tCtrl+S", ID_FILE_SAVEPROJECT
|
MENUITEM "&Save\tCtrl+S", ID_FILE_SAVEPROJECT
|
||||||
MENUITEM "S&ave As", ID_FILE_SAVEPROJECTAS
|
MENUITEM "S&ave As", ID_FILE_SAVEPROJECTAS
|
||||||
MENUITEM "Save &Compact", ID_FILE_SAVECOMPACT, INACTIVE
|
MENUITEM "Save &Compact", ID_FILE_SAVECOMPACT
|
||||||
MENUITEM "&Recent", ID_TASEDIT_FILE_RECENT
|
MENUITEM "&Recent", ID_TASEDIT_FILE_RECENT
|
||||||
MENUITEM SEPARATOR
|
MENUITEM SEPARATOR
|
||||||
MENUITEM "&Import", ID_FILE_IMPORT
|
MENUITEM "&Import", ID_FILE_IMPORT
|
||||||
|
@ -1423,7 +1423,23 @@ BEGIN
|
||||||
PUSHBUTTON "Cancel",IDCANCEL,65,52,50,14
|
PUSHBUTTON "Cancel",IDCANCEL,65,52,50,14
|
||||||
CONTROL " 1 player",IDC_RADIO_1PLAYER,"Button",BS_AUTORADIOBUTTON,36,8,49,10
|
CONTROL " 1 player",IDC_RADIO_1PLAYER,"Button",BS_AUTORADIOBUTTON,36,8,49,10
|
||||||
CONTROL " 2 players",IDC_RADIO_2PLAYERS,"Button",BS_AUTORADIOBUTTON,36,21,49,10
|
CONTROL " 2 players",IDC_RADIO_2PLAYERS,"Button",BS_AUTORADIOBUTTON,36,21,49,10
|
||||||
CONTROL " Fourscore",IDC_RADIO_FOURSCORE,"Button",BS_AUTORADIOBUTTON,37,35,47,10
|
CONTROL " Fourscore",IDC_RADIO_FOURSCORE,"Button",BS_AUTORADIOBUTTON,36,35,47,10
|
||||||
|
END
|
||||||
|
|
||||||
|
IDD_TASEDIT_SAVECOMPACT DIALOGEX 0, 0, 122, 134
|
||||||
|
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
|
CAPTION "Dialog"
|
||||||
|
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||||
|
BEGIN
|
||||||
|
DEFPUSHBUTTON "Save",IDOK,7,114,50,14
|
||||||
|
PUSHBUTTON "Cancel",IDCANCEL,65,114,50,14
|
||||||
|
CONTROL " Binary Format of Input",IDC_CHECK_BINARY,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,18,8,87,10
|
||||||
|
CONTROL " Markers",IDC_CHECK_MARKERS,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,22,67,10
|
||||||
|
CONTROL " Bookmarks",IDC_CHECK_BOOKMARKS,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,36,67,10
|
||||||
|
CONTROL " Greenzone",IDC_CHECK_GREENZONE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,51,67,10
|
||||||
|
CONTROL " History",IDC_CHECK_HISTORY,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,66,67,10
|
||||||
|
CONTROL " Selection",IDC_CHECK_SELECTION,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,81,67,10
|
||||||
|
CONTROL " List data",IDC_CHECK_LIST,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,35,96,67,10
|
||||||
END
|
END
|
||||||
|
|
||||||
ASSEMBLER DIALOGEX 0, 0, 202, 135
|
ASSEMBLER DIALOGEX 0, 0, 202, 135
|
||||||
|
@ -1900,6 +1916,16 @@ BEGIN
|
||||||
BEGIN
|
BEGIN
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_TASEDIT_EXPORT, DIALOG
|
||||||
|
BEGIN
|
||||||
|
END
|
||||||
|
|
||||||
|
IDD_TASEDIT_SAVECOMPACT, DIALOG
|
||||||
|
BEGIN
|
||||||
|
RIGHTMARGIN, 121
|
||||||
|
BOTTOMMARGIN, 131
|
||||||
|
END
|
||||||
|
|
||||||
"ASSEMBLER", DIALOG
|
"ASSEMBLER", DIALOG
|
||||||
BEGIN
|
BEGIN
|
||||||
LEFTMARGIN, 7
|
LEFTMARGIN, 7
|
||||||
|
|
|
@ -181,6 +181,7 @@
|
||||||
#define IDB_BITMAP19 182
|
#define IDB_BITMAP19 182
|
||||||
#define IDB_BRANCH_SPRITESHEET 184
|
#define IDB_BRANCH_SPRITESHEET 184
|
||||||
#define IDD_TASEDIT_EXPORT 185
|
#define IDD_TASEDIT_EXPORT 185
|
||||||
|
#define IDD_TASEDIT_SAVECOMPACT 186
|
||||||
#define MENU_RESET 200
|
#define MENU_RESET 200
|
||||||
#define BUTTON_ROMS 200
|
#define BUTTON_ROMS 200
|
||||||
#define TXT_PAD1 200
|
#define TXT_PAD1 200
|
||||||
|
@ -464,13 +465,26 @@
|
||||||
#define IDC_CHEAT_PAUSEWHENACTIVE 1203
|
#define IDC_CHEAT_PAUSEWHENACTIVE 1203
|
||||||
#define IDC_FULLSAVESTATES 1203
|
#define IDC_FULLSAVESTATES 1203
|
||||||
#define IDC_SUPERIMPOSE 1203
|
#define IDC_SUPERIMPOSE 1203
|
||||||
|
#define IDC_CHECK_BINARY 1203
|
||||||
#define IDC_VOLUMEGROUP 1204
|
#define IDC_VOLUMEGROUP 1204
|
||||||
#define IDC_OMITBLANK 1204
|
#define IDC_OMITBLANK 1204
|
||||||
|
#define IDC_CHECK3 1204
|
||||||
|
#define IDC_CHECK_MARKERS 1204
|
||||||
#define IDC_RAMLIST 1205
|
#define IDC_RAMLIST 1205
|
||||||
|
#define IDC_CHECK4 1205
|
||||||
|
#define IDC_CHECK_BOOKMARKS 1205
|
||||||
#define IDC_C_SEARCH 1206
|
#define IDC_C_SEARCH 1206
|
||||||
|
#define IDC_CHECK5 1206
|
||||||
|
#define IDC_CHECK_GREENZONE 1206
|
||||||
#define IDC_C_ADDCHEAT 1207
|
#define IDC_C_ADDCHEAT 1207
|
||||||
|
#define IDC_CHECK6 1207
|
||||||
|
#define IDC_CHECK_HISTORY 1207
|
||||||
#define IDC_C_WATCH 1208
|
#define IDC_C_WATCH 1208
|
||||||
|
#define IDC_CHECK7 1208
|
||||||
|
#define IDC_CHECK_SELECTION 1208
|
||||||
#define IDC_C_RESET 1209
|
#define IDC_C_RESET 1209
|
||||||
|
#define IDC_CHECK8 1209
|
||||||
|
#define IDC_CHECK_LIST 1209
|
||||||
#define IDC_C_ELIMINATE 1210
|
#define IDC_C_ELIMINATE 1210
|
||||||
#define IDC_LESSTHAN 1211
|
#define IDC_LESSTHAN 1211
|
||||||
#define IDC_MORETHAN 1212
|
#define IDC_MORETHAN 1212
|
||||||
|
@ -647,7 +661,7 @@
|
||||||
#define ID_Menu40175 40175
|
#define ID_Menu40175 40175
|
||||||
#define ID_Menu40176 40176
|
#define ID_Menu40176 40176
|
||||||
#define ID_EDIT_TRUNCATE 40177
|
#define ID_EDIT_TRUNCATE 40177
|
||||||
#define ID_FILE_IMPORT 40178
|
#define ID_FILE_IMPORT 40178
|
||||||
#define ID_FILE_NEWPROJECT 40179
|
#define ID_FILE_NEWPROJECT 40179
|
||||||
#define ID_FILE_OPEN_PROJECT 40180
|
#define ID_FILE_OPEN_PROJECT 40180
|
||||||
#define ID_FILE_OPENPROJECT 40181
|
#define ID_FILE_OPENPROJECT 40181
|
||||||
|
@ -928,7 +942,7 @@
|
||||||
//
|
//
|
||||||
#ifdef APSTUDIO_INVOKED
|
#ifdef APSTUDIO_INVOKED
|
||||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||||
#define _APS_NEXT_RESOURCE_VALUE 186
|
#define _APS_NEXT_RESOURCE_VALUE 187
|
||||||
#define _APS_NEXT_COMMAND_VALUE 40501
|
#define _APS_NEXT_COMMAND_VALUE 40501
|
||||||
#define _APS_NEXT_CONTROL_VALUE 1270
|
#define _APS_NEXT_CONTROL_VALUE 1270
|
||||||
#define _APS_NEXT_SYMED_VALUE 101
|
#define _APS_NEXT_SYMED_VALUE 101
|
||||||
|
|
|
@ -61,6 +61,13 @@ extern bool muteTurbo;
|
||||||
bool TASEdit_enable_hot_changes = true;
|
bool TASEdit_enable_hot_changes = true;
|
||||||
bool TASEdit_jump_to_undo = true;
|
bool TASEdit_jump_to_undo = true;
|
||||||
int TASEdit_last_export_type = EXPORT_TYPE_1P;
|
int TASEdit_last_export_type = EXPORT_TYPE_1P;
|
||||||
|
bool TASEdit_savecompact_binary = true;
|
||||||
|
bool TASEdit_savecompact_markers = true;
|
||||||
|
bool TASEdit_savecompact_bookmarks = true;
|
||||||
|
bool TASEdit_savecompact_greenzone = false;
|
||||||
|
bool TASEdit_savecompact_history = false;
|
||||||
|
bool TASEdit_savecompact_selection = false;
|
||||||
|
bool TASEdit_savecompact_list = true;
|
||||||
|
|
||||||
// Recent Menu
|
// Recent Menu
|
||||||
HMENU recent_projects_menu;
|
HMENU recent_projects_menu;
|
||||||
|
@ -778,7 +785,7 @@ void OpenProject()
|
||||||
ofn.hwndOwner = hwndTasEdit;
|
ofn.hwndOwner = hwndTasEdit;
|
||||||
ofn.hInstance = fceu_hInstance;
|
ofn.hInstance = fceu_hInstance;
|
||||||
ofn.lpstrTitle = "Open TAS Editor Project";
|
ofn.lpstrTitle = "Open TAS Editor Project";
|
||||||
const char filter[] = "TAS Editor Project (*.tas)\0*.tas\0\0";
|
const char filter[] = "TAS Editor Projects (*.tas)\0*.tas\0\0";
|
||||||
ofn.lpstrFilter = filter;
|
ofn.lpstrFilter = filter;
|
||||||
|
|
||||||
char nameo[2048];
|
char nameo[2048];
|
||||||
|
@ -844,7 +851,7 @@ void LoadRecentProject(int slot)
|
||||||
// Saves current project
|
// Saves current project
|
||||||
bool SaveProjectAs()
|
bool SaveProjectAs()
|
||||||
{
|
{
|
||||||
const char filter[] = "TAS Editor Project (*.tas)\0*.tas\0All Files (*.*)\0*.*\0\0";
|
const char filter[] = "TAS Editor Projects (*.tas)\0*.tas\0All Files (*.*)\0*.*\0\0";
|
||||||
OPENFILENAME ofn;
|
OPENFILENAME ofn;
|
||||||
memset(&ofn, 0, sizeof(ofn));
|
memset(&ofn, 0, sizeof(ofn));
|
||||||
ofn.lStructSize = sizeof(ofn);
|
ofn.lStructSize = sizeof(ofn);
|
||||||
|
@ -887,6 +894,94 @@ bool SaveProject()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SaveCompact_GetCheckboxes(HWND hwndDlg)
|
||||||
|
{
|
||||||
|
TASEdit_savecompact_binary = (SendDlgItemMessage(hwndDlg, IDC_CHECK_BINARY, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_markers = (SendDlgItemMessage(hwndDlg, IDC_CHECK_MARKERS, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_bookmarks = (SendDlgItemMessage(hwndDlg, IDC_CHECK_BOOKMARKS, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_greenzone = (SendDlgItemMessage(hwndDlg, IDC_CHECK_GREENZONE, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_history = (SendDlgItemMessage(hwndDlg, IDC_CHECK_HISTORY, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_selection = (SendDlgItemMessage(hwndDlg, IDC_CHECK_SELECTION, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
TASEdit_savecompact_list = (SendDlgItemMessage(hwndDlg, IDC_CHECK_LIST, BM_GETCHECK, 0, 0) == BST_CHECKED);
|
||||||
|
}
|
||||||
|
BOOL CALLBACK SaveCompactProc(HWND hwndDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
switch (message)
|
||||||
|
{
|
||||||
|
case WM_INITDIALOG:
|
||||||
|
{
|
||||||
|
SetWindowPos(hwndDlg, 0, TasEdit_wndx + 100, TasEdit_wndy + 200, 0, 0, SWP_NOSIZE | SWP_NOZORDER | SWP_NOOWNERZORDER);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_BINARY, TASEdit_savecompact_binary?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_MARKERS, TASEdit_savecompact_markers?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_BOOKMARKS, TASEdit_savecompact_bookmarks?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_GREENZONE, TASEdit_savecompact_greenzone?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_HISTORY, TASEdit_savecompact_history?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_SELECTION, TASEdit_savecompact_selection?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndDlg, IDC_CHECK_LIST, TASEdit_savecompact_list?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
case WM_COMMAND:
|
||||||
|
{
|
||||||
|
switch (LOWORD(wParam))
|
||||||
|
{
|
||||||
|
case IDOK:
|
||||||
|
SaveCompact_GetCheckboxes(hwndDlg);
|
||||||
|
EndDialog(hwndDlg, 1);
|
||||||
|
return TRUE;
|
||||||
|
case IDCANCEL:
|
||||||
|
SaveCompact_GetCheckboxes(hwndDlg);
|
||||||
|
EndDialog(hwndDlg, 0);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case WM_CLOSE:
|
||||||
|
case WM_QUIT:
|
||||||
|
{
|
||||||
|
SaveCompact_GetCheckboxes(hwndDlg);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SaveCompact()
|
||||||
|
{
|
||||||
|
if (DialogBox(fceu_hInstance, MAKEINTRESOURCE(IDD_TASEDIT_SAVECOMPACT), hwndTasEdit, SaveCompactProc) > 0)
|
||||||
|
{
|
||||||
|
const char filter[] = "TAS Editor Projects (*.tas)\0*.tas\0All Files (*.*)\0*.*\0\0";
|
||||||
|
OPENFILENAME ofn;
|
||||||
|
memset(&ofn, 0, sizeof(ofn));
|
||||||
|
ofn.lStructSize = sizeof(ofn);
|
||||||
|
ofn.hwndOwner = hwndTasEdit;
|
||||||
|
ofn.hInstance = fceu_hInstance;
|
||||||
|
ofn.lpstrTitle = "Save Compact";
|
||||||
|
ofn.lpstrFilter = filter;
|
||||||
|
|
||||||
|
char nameo[2048];
|
||||||
|
if (project.GetProjectName().empty())
|
||||||
|
// suggest ROM name for this project
|
||||||
|
strcpy(nameo, mass_replace(GetRomName(), "|", ".").c_str()); //convert | to . for archive filenames
|
||||||
|
else
|
||||||
|
// suggest current name
|
||||||
|
strcpy(nameo, project.GetProjectName().c_str());
|
||||||
|
// add "-compact"
|
||||||
|
strcat(nameo, "-compact");
|
||||||
|
|
||||||
|
ofn.lpstrFile = nameo;
|
||||||
|
ofn.lpstrDefExt = "tas";
|
||||||
|
ofn.nMaxFile = 2048;
|
||||||
|
ofn.Flags = OFN_EXPLORER|OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT;
|
||||||
|
string initdir = FCEU_GetPath(FCEUMKF_MOVIE); //Initial directory
|
||||||
|
ofn.lpstrInitialDir = initdir.c_str();
|
||||||
|
|
||||||
|
if(GetSaveFileName(&ofn)) //If it is a valid filename
|
||||||
|
{
|
||||||
|
project.save_compact(nameo, TASEdit_savecompact_binary, TASEdit_savecompact_markers, TASEdit_savecompact_bookmarks, TASEdit_savecompact_greenzone, TASEdit_savecompact_history, TASEdit_savecompact_selection, TASEdit_savecompact_list);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// returns false if user doesn't want to exit
|
// returns false if user doesn't want to exit
|
||||||
bool AskSaveProject()
|
bool AskSaveProject()
|
||||||
{
|
{
|
||||||
|
@ -907,7 +1002,7 @@ bool AskSaveProject()
|
||||||
extern bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader);
|
extern bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader);
|
||||||
void Import()
|
void Import()
|
||||||
{
|
{
|
||||||
const char filter[] = "FCEUX Movie Files, TAS Editor Projects\0*.fm2;*.tas\0All Files (*.*)\0*.*\0\0";
|
const char filter[] = "FCEUX Movie Files (*.fm2), TAS Editor Projects (*.tas)\0*.fm2;*.tas\0All Files (*.*)\0*.*\0\0";
|
||||||
OPENFILENAME ofn;
|
OPENFILENAME ofn;
|
||||||
memset(&ofn, 0, sizeof(ofn));
|
memset(&ofn, 0, sizeof(ofn));
|
||||||
ofn.lStructSize = sizeof(ofn);
|
ofn.lStructSize = sizeof(ofn);
|
||||||
|
@ -985,6 +1080,7 @@ BOOL CALLBACK ExportProc(HWND hwndDlg, UINT message, WPARAM wParam, LPARAM lPara
|
||||||
EndDialog(hwndDlg, 0);
|
EndDialog(hwndDlg, 0);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1180,10 +1276,13 @@ BOOL CALLBACK WndprocTasEdit(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPar
|
||||||
break;
|
break;
|
||||||
case ACCEL_CTRL_S:
|
case ACCEL_CTRL_S:
|
||||||
case ID_FILE_SAVEPROJECT:
|
case ID_FILE_SAVEPROJECT:
|
||||||
SaveProject();
|
SaveProject();
|
||||||
break;
|
break;
|
||||||
case ID_FILE_SAVEPROJECTAS:
|
case ID_FILE_SAVEPROJECTAS:
|
||||||
SaveProjectAs();
|
SaveProjectAs();
|
||||||
|
break;
|
||||||
|
case ID_FILE_SAVECOMPACT:
|
||||||
|
SaveCompact();
|
||||||
break;
|
break;
|
||||||
case ID_FILE_IMPORT:
|
case ID_FILE_IMPORT:
|
||||||
Import();
|
Import();
|
||||||
|
@ -1565,89 +1664,92 @@ BOOL CALLBACK WndprocTasEdit(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPar
|
||||||
bool EnterTasEdit()
|
bool EnterTasEdit()
|
||||||
{
|
{
|
||||||
if(!FCEU_IsValidUI(FCEUI_TASEDIT)) return false;
|
if(!FCEU_IsValidUI(FCEUI_TASEDIT)) return false;
|
||||||
if(!hwndTasEdit) hwndTasEdit = CreateDialog(fceu_hInstance,"TASEDIT", hAppWnd, WndprocTasEdit);
|
if(!hwndTasEdit)
|
||||||
if(hwndTasEdit)
|
|
||||||
{
|
{
|
||||||
// save "eoptions"
|
hwndTasEdit = CreateDialog(fceu_hInstance,"TASEDIT", hAppWnd, WndprocTasEdit);
|
||||||
saved_eoptions = eoptions;
|
if(hwndTasEdit)
|
||||||
// set "Run in background"
|
|
||||||
eoptions |= EO_BGRUN;
|
|
||||||
GotFocus();
|
|
||||||
// "Set high-priority thread"
|
|
||||||
eoptions |= EO_HIGHPRIO;
|
|
||||||
DoPriority();
|
|
||||||
// clear "Disable speed throttling"
|
|
||||||
eoptions &= ~EO_NOTHROTTLE;
|
|
||||||
// switch off autosaves
|
|
||||||
saved_EnableAutosave = EnableAutosave;
|
|
||||||
EnableAutosave = 0;
|
|
||||||
UpdateCheckedMenuItems();
|
|
||||||
|
|
||||||
hmenu = GetMenu(hwndTasEdit);
|
|
||||||
hrmenu = LoadMenu(fceu_hInstance,"TASEDITCONTEXTMENUS");
|
|
||||||
recent_projects_menu = CreateMenu();
|
|
||||||
UpdateRecentProjectsMenu();
|
|
||||||
// check option ticks
|
|
||||||
CheckDlgButton(hwndTasEdit, CHECK_FOLLOW_CURSOR, TASEdit_follow_playback?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckDlgButton(hwndTasEdit, CHECK_TURBO_SEEK, TASEdit_turbo_seek?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_VIEW_SHOW_LAG_FRAMES, TASEdit_show_lag_frames?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_VIEW_SHOW_MARKERS, TASEdit_show_markers?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_VIEW_SHOWBRANCHSCREENSHOTS, TASEdit_show_branch_screenshots?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_VIEW_JUMPWHENMAKINGUNDO, TASEdit_jump_to_undo?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_VIEW_ENABLEHOTCHANGES, TASEdit_enable_hot_changes?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESRESTOREFULLMOVIE, TASEdit_branch_full_movie?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESWORKONLYWHENRECORDING, TASEdit_branch_only_when_rec?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_HUDINBRANCHSCREENSHOTS, TASEdit_branch_scr_hud?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BINDMARKERSTOINPUT, TASEdit_bind_markers?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_USE1PFORRECORDING, TASEdit_use_1p_rec?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_COMBINECONSECUTIVERECORDINGS, TASEdit_combine_consecutive_rec?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_SUPERIMPOSE_AFFECTS_PASTE, TASEdit_superimpose_affects_paste?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_MUTETURBO, muteTurbo?MF_CHECKED : MF_UNCHECKED);
|
|
||||||
CheckDlgButton(hwndTasEdit,CHECK_AUTORESTORE_PLAYBACK,TASEdit_restore_position?BST_CHECKED:BST_UNCHECKED);
|
|
||||||
CheckDlgButton(hwndTasEdit, IDC_SUPERIMPOSE, TASEdit_superimpose);
|
|
||||||
|
|
||||||
SetWindowPos(hwndTasEdit, HWND_TOP, 0, 0, 0, 0, SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
|
|
||||||
// init modules
|
|
||||||
greenzone.init();
|
|
||||||
playback.init();
|
|
||||||
// either start new movie or use current movie
|
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_INACTIVE))
|
|
||||||
{
|
{
|
||||||
FCEUI_StopMovie();
|
// save "eoptions"
|
||||||
CreateCleanMovie();
|
saved_eoptions = eoptions;
|
||||||
playback.StartFromZero();
|
// set "Run in background"
|
||||||
} else
|
eoptions |= EO_BGRUN;
|
||||||
{
|
GotFocus();
|
||||||
// use current movie to create a new project
|
// "Set high-priority thread"
|
||||||
if (currMovieData.savestate.size() != 0)
|
eoptions |= EO_HIGHPRIO;
|
||||||
|
DoPriority();
|
||||||
|
// clear "Disable speed throttling"
|
||||||
|
eoptions &= ~EO_NOTHROTTLE;
|
||||||
|
// switch off autosaves
|
||||||
|
saved_EnableAutosave = EnableAutosave;
|
||||||
|
EnableAutosave = 0;
|
||||||
|
UpdateCheckedMenuItems();
|
||||||
|
|
||||||
|
hmenu = GetMenu(hwndTasEdit);
|
||||||
|
hrmenu = LoadMenu(fceu_hInstance,"TASEDITCONTEXTMENUS");
|
||||||
|
recent_projects_menu = CreateMenu();
|
||||||
|
UpdateRecentProjectsMenu();
|
||||||
|
// check option ticks
|
||||||
|
CheckDlgButton(hwndTasEdit, CHECK_FOLLOW_CURSOR, TASEdit_follow_playback?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndTasEdit, CHECK_TURBO_SEEK, TASEdit_turbo_seek?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_VIEW_SHOW_LAG_FRAMES, TASEdit_show_lag_frames?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_VIEW_SHOW_MARKERS, TASEdit_show_markers?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_VIEW_SHOWBRANCHSCREENSHOTS, TASEdit_show_branch_screenshots?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_VIEW_JUMPWHENMAKINGUNDO, TASEdit_jump_to_undo?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_VIEW_ENABLEHOTCHANGES, TASEdit_enable_hot_changes?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESRESTOREFULLMOVIE, TASEdit_branch_full_movie?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESWORKONLYWHENRECORDING, TASEdit_branch_only_when_rec?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_HUDINBRANCHSCREENSHOTS, TASEdit_branch_scr_hud?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_BINDMARKERSTOINPUT, TASEdit_bind_markers?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_USE1PFORRECORDING, TASEdit_use_1p_rec?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_COMBINECONSECUTIVERECORDINGS, TASEdit_combine_consecutive_rec?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_SUPERIMPOSE_AFFECTS_PASTE, TASEdit_superimpose_affects_paste?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckMenuItem(hmenu, ID_CONFIG_MUTETURBO, muteTurbo?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndTasEdit,CHECK_AUTORESTORE_PLAYBACK,TASEdit_restore_position?BST_CHECKED:BST_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndTasEdit, IDC_SUPERIMPOSE, TASEdit_superimpose);
|
||||||
|
|
||||||
|
SetWindowPos(hwndTasEdit, HWND_TOP, 0, 0, 0, 0, SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
|
||||||
|
// init modules
|
||||||
|
greenzone.init();
|
||||||
|
playback.init();
|
||||||
|
// either start new movie or use current movie
|
||||||
|
if (FCEUMOV_Mode(MOVIEMODE_INACTIVE))
|
||||||
{
|
{
|
||||||
FCEUD_PrintError("This version of TAS Editor doesn't work with movies starting from savestate.");
|
FCEUI_StopMovie();
|
||||||
// delete savestate, but preserve input
|
CreateCleanMovie();
|
||||||
currMovieData.savestate.clear();
|
playback.StartFromZero();
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// use current movie to create a new project
|
||||||
|
if (currMovieData.savestate.size() != 0)
|
||||||
|
{
|
||||||
|
FCEUD_PrintError("This version of TAS Editor doesn't work with movies starting from savestate.");
|
||||||
|
// delete savestate, but preserve input
|
||||||
|
currMovieData.savestate.clear();
|
||||||
|
}
|
||||||
|
FCEUI_StopMovie();
|
||||||
|
greenzone.TryDumpIncremental(lagFlag != 0);
|
||||||
}
|
}
|
||||||
FCEUI_StopMovie();
|
// switch to taseditor mode
|
||||||
greenzone.TryDumpIncremental(lagFlag != 0);
|
movieMode = MOVIEMODE_TASEDIT;
|
||||||
}
|
currMovieData.ports[0] = SI_GAMEPAD;
|
||||||
// switch to taseditor mode
|
currMovieData.ports[1] = SI_GAMEPAD;
|
||||||
movieMode = MOVIEMODE_TASEDIT;
|
//force the input configuration stored in the movie to apply
|
||||||
currMovieData.ports[0] = SI_GAMEPAD;
|
FCEUD_SetInput(currMovieData.fourscore, currMovieData.microphone, (ESI)currMovieData.ports[0], (ESI)currMovieData.ports[1], (ESIFC)currMovieData.ports[2]);
|
||||||
currMovieData.ports[1] = SI_GAMEPAD;
|
// init variables
|
||||||
//force the input configuration stored in the movie to apply
|
recorder.init();
|
||||||
FCEUD_SetInput(currMovieData.fourscore, currMovieData.microphone, (ESI)currMovieData.ports[0], (ESI)currMovieData.ports[1], (ESIFC)currMovieData.ports[2]);
|
tasedit_list.init();
|
||||||
// init variables
|
markers.init();
|
||||||
recorder.init();
|
project.init();
|
||||||
tasedit_list.init();
|
bookmarks.init();
|
||||||
markers.init();
|
screenshot_display.init();
|
||||||
project.init();
|
history.init();
|
||||||
bookmarks.init();
|
selection.init();
|
||||||
screenshot_display.init();
|
SetFocus(history.hwndHistoryList); // set focus only once, to show selection cursor
|
||||||
history.init();
|
SetFocus(tasedit_list.hwndList);
|
||||||
selection.init();
|
FCEU_DispMessage("TAS Editor engaged", 0);
|
||||||
SetFocus(history.hwndHistoryList); // set focus only once, to show selection cursor
|
return true;
|
||||||
SetFocus(tasedit_list.hwndList);
|
} else return false;
|
||||||
FCEU_DispMessage("TAS Editor engaged", 0);
|
} else return true;
|
||||||
return true;
|
|
||||||
} else return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ExitTasEdit()
|
bool ExitTasEdit()
|
||||||
|
|
|
@ -32,6 +32,7 @@ bool LoadProject(char* fullname);
|
||||||
void LoadRecentProject(int slot);
|
void LoadRecentProject(int slot);
|
||||||
bool SaveProject();
|
bool SaveProject();
|
||||||
bool SaveProjectAs();
|
bool SaveProjectAs();
|
||||||
|
void SaveCompact();
|
||||||
bool AskSaveProject();
|
bool AskSaveProject();
|
||||||
void Import();
|
void Import();
|
||||||
void Export();
|
void Export();
|
||||||
|
|
|
@ -27,6 +27,7 @@ extern bool TASEdit_view_branches_tree;
|
||||||
|
|
||||||
// resources
|
// resources
|
||||||
char bookmarks_save_id[BOOKMARKS_ID_LEN] = "BOOKMARKS";
|
char bookmarks_save_id[BOOKMARKS_ID_LEN] = "BOOKMARKS";
|
||||||
|
char bookmarks_skipsave_id[BOOKMARKS_ID_LEN] = "BOOKMARKX";
|
||||||
char bookmarksCaption[3][23] = { " Bookmarks ", " Bookmarks / Branches ", " Branches " };
|
char bookmarksCaption[3][23] = { " Bookmarks ", " Bookmarks / Branches ", " Branches " };
|
||||||
// color tables for flashing when saving/loading bookmarks
|
// color tables for flashing when saving/loading bookmarks
|
||||||
COLORREF bookmark_flash_colors[3][FLASH_PHASE_MAX+1] = {
|
COLORREF bookmark_flash_colors[3][FLASH_PHASE_MAX+1] = {
|
||||||
|
@ -524,24 +525,31 @@ void BOOKMARKS::unleash(int slot)
|
||||||
FCEU_DispMessage("Branch %d loaded.", 0, slot);
|
FCEU_DispMessage("Branch %d loaded.", 0, slot);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BOOKMARKS::save(EMUFILE *os)
|
void BOOKMARKS::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
// write "BOOKMARKS" string
|
if (really_save)
|
||||||
os->fwrite(bookmarks_save_id, BOOKMARKS_ID_LEN);
|
|
||||||
// write cloud time
|
|
||||||
os->fwrite(cloud_time, TIME_DESC_LENGTH);
|
|
||||||
// write current branch and flag of changes since it
|
|
||||||
write32le(current_branch, os);
|
|
||||||
if (changes_since_current_branch)
|
|
||||||
write8le((uint8)1, os);
|
|
||||||
else
|
|
||||||
write8le((uint8)0, os);
|
|
||||||
// write current_position time
|
|
||||||
os->fwrite(current_pos_time, TIME_DESC_LENGTH);
|
|
||||||
// write all 10 bookmarks
|
|
||||||
for (int i = 0; i < TOTAL_BOOKMARKS; ++i)
|
|
||||||
{
|
{
|
||||||
bookmarks_array[i].save(os);
|
// write "BOOKMARKS" string
|
||||||
|
os->fwrite(bookmarks_save_id, BOOKMARKS_ID_LEN);
|
||||||
|
// write cloud time
|
||||||
|
os->fwrite(cloud_time, TIME_DESC_LENGTH);
|
||||||
|
// write current branch and flag of changes since it
|
||||||
|
write32le(current_branch, os);
|
||||||
|
if (changes_since_current_branch)
|
||||||
|
write8le((uint8)1, os);
|
||||||
|
else
|
||||||
|
write8le((uint8)0, os);
|
||||||
|
// write current_position time
|
||||||
|
os->fwrite(current_pos_time, TIME_DESC_LENGTH);
|
||||||
|
// write all 10 bookmarks
|
||||||
|
for (int i = 0; i < TOTAL_BOOKMARKS; ++i)
|
||||||
|
{
|
||||||
|
bookmarks_array[i].save(os);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "BOOKMARKX" string
|
||||||
|
os->fwrite(bookmarks_skipsave_id, BOOKMARKS_ID_LEN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
|
@ -549,26 +557,37 @@ bool BOOKMARKS::load(EMUFILE *is)
|
||||||
{
|
{
|
||||||
// read "BOOKMARKS" string
|
// read "BOOKMARKS" string
|
||||||
char save_id[BOOKMARKS_ID_LEN];
|
char save_id[BOOKMARKS_ID_LEN];
|
||||||
if ((int)is->fread(save_id, BOOKMARKS_ID_LEN) < BOOKMARKS_ID_LEN) return true;
|
if ((int)is->fread(save_id, BOOKMARKS_ID_LEN) < BOOKMARKS_ID_LEN) goto error;
|
||||||
if (strcmp(bookmarks_save_id, save_id)) return true; // string is not valid
|
if (!strcmp(bookmarks_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading Bookmarks
|
||||||
|
FCEU_printf("No bookmarks in the file\n");
|
||||||
|
reset();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (strcmp(bookmarks_save_id, save_id)) goto error; // string is not valid
|
||||||
// read cloud time
|
// read cloud time
|
||||||
if ((int)is->fread(cloud_time, TIME_DESC_LENGTH) < TIME_DESC_LENGTH) return true;
|
if ((int)is->fread(cloud_time, TIME_DESC_LENGTH) < TIME_DESC_LENGTH) goto error;
|
||||||
// read current branch and flag of changes since it
|
// read current branch and flag of changes since it
|
||||||
uint8 tmp;
|
uint8 tmp;
|
||||||
if (!read32le(¤t_branch, is)) return true;
|
if (!read32le(¤t_branch, is)) goto error;
|
||||||
if (!read8le(&tmp, is)) return true;
|
if (!read8le(&tmp, is)) goto error;
|
||||||
changes_since_current_branch = (tmp != 0);
|
changes_since_current_branch = (tmp != 0);
|
||||||
// read current_position time
|
// read current_position time
|
||||||
if ((int)is->fread(current_pos_time, TIME_DESC_LENGTH) < TIME_DESC_LENGTH) return true;
|
if ((int)is->fread(current_pos_time, TIME_DESC_LENGTH) < TIME_DESC_LENGTH) goto error;
|
||||||
// read all 10 bookmarks
|
// read all 10 bookmarks
|
||||||
for (int i = 0; i < TOTAL_BOOKMARKS; ++i)
|
for (int i = 0; i < TOTAL_BOOKMARKS; ++i)
|
||||||
{
|
{
|
||||||
if (bookmarks_array[i].load(is)) return true;
|
if (bookmarks_array[i].load(is)) goto error;
|
||||||
}
|
}
|
||||||
// all ok
|
// all ok
|
||||||
reset_vars();
|
reset_vars();
|
||||||
RedrawBookmarksCaption();
|
RedrawBookmarksCaption();
|
||||||
return false;
|
return false;
|
||||||
|
error:
|
||||||
|
FCEU_printf("Error loading bookmarks\n");
|
||||||
|
reset();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
void BOOKMARKS::RedrawBookmarksCaption()
|
void BOOKMARKS::RedrawBookmarksCaption()
|
||||||
|
|
|
@ -94,7 +94,7 @@ public:
|
||||||
void reset_vars();
|
void reset_vars();
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
|
|
||||||
void set(int slot);
|
void set(int slot);
|
||||||
|
|
|
@ -16,6 +16,7 @@ extern bool TASEdit_restore_position;
|
||||||
extern void FCEU_printf(char *format, ...);
|
extern void FCEU_printf(char *format, ...);
|
||||||
|
|
||||||
char greenzone_save_id[GREENZONE_ID_LEN] = "GREENZONE";
|
char greenzone_save_id[GREENZONE_ID_LEN] = "GREENZONE";
|
||||||
|
char greenzone_skipsave_id[GREENZONE_ID_LEN] = "GREENZONX";
|
||||||
|
|
||||||
GREENZONE::GREENZONE()
|
GREENZONE::GREENZONE()
|
||||||
{
|
{
|
||||||
|
@ -182,44 +183,60 @@ void GREENZONE::ClearSavestate(int index)
|
||||||
savestates[index].swap(tmp);
|
savestates[index].swap(tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GREENZONE::save(EMUFILE *os)
|
void GREENZONE::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
int frame, size;
|
if (really_save)
|
||||||
int last_tick = 0;
|
|
||||||
// write "GREENZONE" string
|
|
||||||
os->fwrite(greenzone_save_id, GREENZONE_ID_LEN);
|
|
||||||
// write size
|
|
||||||
write32le(greenZoneCount, os);
|
|
||||||
// compress and write lag history
|
|
||||||
int len = lag_history.size();
|
|
||||||
uLongf comprlen = (len>>9)+12 + len;
|
|
||||||
std::vector<uint8> cbuf(comprlen);
|
|
||||||
compress(&cbuf[0], &comprlen, &lag_history[0], len);
|
|
||||||
write32le(comprlen, os);
|
|
||||||
os->fwrite(&cbuf[0], comprlen);
|
|
||||||
// write playback position
|
|
||||||
write32le(currFrameCounter, os);
|
|
||||||
// write savestates
|
|
||||||
GreenzoneCleaning();
|
|
||||||
for (frame = 0; frame < greenZoneCount; ++frame)
|
|
||||||
{
|
{
|
||||||
// update TASEditor progressbar from time to time
|
// write "GREENZONE" string
|
||||||
if (frame / PROGRESSBAR_UPDATE_RATE > last_tick)
|
os->fwrite(greenzone_save_id, GREENZONE_ID_LEN);
|
||||||
|
// write size
|
||||||
|
write32le(greenZoneCount, os);
|
||||||
|
// compress and write lag history
|
||||||
|
int len = lag_history.size();
|
||||||
|
uLongf comprlen = (len>>9)+12 + len;
|
||||||
|
std::vector<uint8> cbuf(comprlen);
|
||||||
|
compress(&cbuf[0], &comprlen, &lag_history[0], len);
|
||||||
|
write32le(comprlen, os);
|
||||||
|
os->fwrite(&cbuf[0], comprlen);
|
||||||
|
// write playback position
|
||||||
|
write32le(currFrameCounter, os);
|
||||||
|
// write savestates
|
||||||
|
int frame, size;
|
||||||
|
int last_tick = 0;
|
||||||
|
GreenzoneCleaning();
|
||||||
|
for (frame = 0; frame < greenZoneCount; ++frame)
|
||||||
{
|
{
|
||||||
playback.SetProgressbar(frame, greenZoneCount);
|
// update TASEditor progressbar from time to time
|
||||||
last_tick = frame / PROGRESSBAR_UPDATE_RATE;
|
if (frame / PROGRESSBAR_UPDATE_RATE > last_tick)
|
||||||
|
{
|
||||||
|
playback.SetProgressbar(frame, greenZoneCount);
|
||||||
|
last_tick = frame / PROGRESSBAR_UPDATE_RATE;
|
||||||
|
}
|
||||||
|
if (savestates[frame].empty()) continue;
|
||||||
|
write32le(frame, os);
|
||||||
|
// write lua_colorings
|
||||||
|
// write monitorings
|
||||||
|
// write savestate
|
||||||
|
size = savestates[frame].size();
|
||||||
|
write32le(size, os);
|
||||||
|
os->fwrite(&savestates[frame][0], size);
|
||||||
|
}
|
||||||
|
// write -1 as eof for greenzone
|
||||||
|
write32le(-1, os);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "GREENZONX" string
|
||||||
|
os->fwrite(greenzone_skipsave_id, GREENZONE_ID_LEN);
|
||||||
|
// write playback position
|
||||||
|
write32le(currFrameCounter, os);
|
||||||
|
if (currFrameCounter > 0)
|
||||||
|
{
|
||||||
|
// write ONE savestate for currFrameCounter
|
||||||
|
int size = savestates[currFrameCounter].size();
|
||||||
|
write32le(size, os);
|
||||||
|
os->fwrite(&savestates[currFrameCounter][0], size);
|
||||||
}
|
}
|
||||||
if (savestates[frame].empty()) continue;
|
|
||||||
write32le(frame, os);
|
|
||||||
// write lua_colorings
|
|
||||||
// write monitorings
|
|
||||||
// write savestate
|
|
||||||
size = savestates[frame].size();
|
|
||||||
write32le(size, os);
|
|
||||||
os->fwrite(&savestates[frame][0], size);
|
|
||||||
}
|
}
|
||||||
// write -1 as eof for greenzone
|
|
||||||
write32le(-1, os);
|
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
bool GREENZONE::load(EMUFILE *is)
|
bool GREENZONE::load(EMUFILE *is)
|
||||||
|
@ -230,6 +247,41 @@ bool GREENZONE::load(EMUFILE *is)
|
||||||
// read "GREENZONE" string
|
// read "GREENZONE" string
|
||||||
char save_id[GREENZONE_ID_LEN];
|
char save_id[GREENZONE_ID_LEN];
|
||||||
if ((int)is->fread(save_id, GREENZONE_ID_LEN) < GREENZONE_ID_LEN) goto error;
|
if ((int)is->fread(save_id, GREENZONE_ID_LEN) < GREENZONE_ID_LEN) goto error;
|
||||||
|
if (!strcmp(greenzone_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading Greenzone
|
||||||
|
// read playback position
|
||||||
|
if (read32le(&frame, is))
|
||||||
|
{
|
||||||
|
currFrameCounter = frame;
|
||||||
|
greenZoneCount = currFrameCounter + 1;
|
||||||
|
savestates.resize(greenZoneCount);
|
||||||
|
if (currFrameCounter)
|
||||||
|
{
|
||||||
|
// there must be one savestate in the file
|
||||||
|
if (read32le(&size, is) && size >= 0)
|
||||||
|
{
|
||||||
|
savestates[frame].resize(size);
|
||||||
|
if (is->fread(&savestates[frame][0], size) == size)
|
||||||
|
{
|
||||||
|
if (loadTasSavestate(currFrameCounter))
|
||||||
|
{
|
||||||
|
FCEU_printf("No greenzone in the file\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// literally no greenzone in the file, but this is still not a error
|
||||||
|
reset();
|
||||||
|
playback.StartFromZero(); // reset playback to frame 0
|
||||||
|
FCEU_printf("No greenzone in the file, playback at frame 0\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
if (strcmp(greenzone_save_id, save_id)) goto error; // string is not valid
|
if (strcmp(greenzone_save_id, save_id)) goto error; // string is not valid
|
||||||
// read size
|
// read size
|
||||||
if (read32le(&size, is) && size >= 0 && size <= currMovieData.getNumRecords())
|
if (read32le(&size, is) && size >= 0 && size <= currMovieData.getNumRecords())
|
||||||
|
@ -315,6 +367,9 @@ bool GREENZONE::load(EMUFILE *is)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
error:
|
error:
|
||||||
|
FCEU_printf("Error loading greenzone\n");
|
||||||
|
reset();
|
||||||
|
playback.StartFromZero(); // reset playback to frame 0
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ public:
|
||||||
void free();
|
void free();
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
|
|
||||||
void TryDumpIncremental(bool lagFlag = true);
|
void TryDumpIncremental(bool lagFlag = true);
|
||||||
|
|
|
@ -20,6 +20,7 @@ extern TASEDIT_PROJECT project;
|
||||||
extern TASEDIT_LIST tasedit_list;
|
extern TASEDIT_LIST tasedit_list;
|
||||||
|
|
||||||
char history_save_id[HISTORY_ID_LEN] = "HISTORY";
|
char history_save_id[HISTORY_ID_LEN] = "HISTORY";
|
||||||
|
char history_skipsave_id[HISTORY_ID_LEN] = "HISTORX";
|
||||||
char modCaptions[36][20] = {" Init",
|
char modCaptions[36][20] = {" Init",
|
||||||
" Change",
|
" Change",
|
||||||
" Set",
|
" Set",
|
||||||
|
@ -476,20 +477,27 @@ void INPUT_HISTORY::RegisterImport(MovieData& md, char* filename)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void INPUT_HISTORY::save(EMUFILE *os)
|
void INPUT_HISTORY::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
int real_pos, last_tick = 0;
|
if (really_save)
|
||||||
// write "HISTORY" string
|
|
||||||
os->fwrite(history_save_id, HISTORY_ID_LEN);
|
|
||||||
// write vars
|
|
||||||
write32le(history_cursor_pos, os);
|
|
||||||
write32le(history_total_items, os);
|
|
||||||
// write snapshots starting from history_start_pos
|
|
||||||
for (int i = 0; i < history_total_items; ++i)
|
|
||||||
{
|
{
|
||||||
real_pos = (history_start_pos + i) % history_size;
|
int real_pos, last_tick = 0;
|
||||||
input_snapshots[real_pos].save(os);
|
// write "HISTORY" string
|
||||||
playback.SetProgressbar(i, history_total_items);
|
os->fwrite(history_save_id, HISTORY_ID_LEN);
|
||||||
|
// write vars
|
||||||
|
write32le(history_cursor_pos, os);
|
||||||
|
write32le(history_total_items, os);
|
||||||
|
// write snapshots starting from history_start_pos
|
||||||
|
for (int i = 0; i < history_total_items; ++i)
|
||||||
|
{
|
||||||
|
real_pos = (history_start_pos + i) % history_size;
|
||||||
|
input_snapshots[real_pos].save(os);
|
||||||
|
playback.SetProgressbar(i, history_total_items);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "HISTORX" string
|
||||||
|
os->fwrite(history_skipsave_id, HISTORY_ID_LEN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
|
@ -502,6 +510,13 @@ bool INPUT_HISTORY::load(EMUFILE *is)
|
||||||
// read "HISTORY" string
|
// read "HISTORY" string
|
||||||
char save_id[HISTORY_ID_LEN];
|
char save_id[HISTORY_ID_LEN];
|
||||||
if ((int)is->fread(save_id, HISTORY_ID_LEN) < HISTORY_ID_LEN) goto error;
|
if ((int)is->fread(save_id, HISTORY_ID_LEN) < HISTORY_ID_LEN) goto error;
|
||||||
|
if (!strcmp(history_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading History
|
||||||
|
FCEU_printf("No history in the file\n");
|
||||||
|
reset();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (strcmp(history_save_id, save_id)) goto error; // string is not valid
|
if (strcmp(history_save_id, save_id)) goto error; // string is not valid
|
||||||
// read vars
|
// read vars
|
||||||
if (!read32le(&history_cursor_pos, is)) goto error;
|
if (!read32le(&history_cursor_pos, is)) goto error;
|
||||||
|
@ -548,6 +563,8 @@ bool INPUT_HISTORY::load(EMUFILE *is)
|
||||||
RedrawHistoryList();
|
RedrawHistoryList();
|
||||||
return false;
|
return false;
|
||||||
error:
|
error:
|
||||||
|
FCEU_printf("Error loading history\n");
|
||||||
|
reset();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// ----------------------------
|
// ----------------------------
|
||||||
|
|
|
@ -53,7 +53,7 @@ public:
|
||||||
void reset();
|
void reset();
|
||||||
void update(); // called every frame
|
void update(); // called every frame
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
|
|
||||||
int undo();
|
int undo();
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
|
||||||
char markers_save_id[MARKERS_ID_LEN] = "MARKERS";
|
char markers_save_id[MARKERS_ID_LEN] = "MARKERS";
|
||||||
|
char markers_skipsave_id[MARKERS_ID_LEN] = "MARKERX";
|
||||||
|
|
||||||
MARKERS::MARKERS()
|
MARKERS::MARKERS()
|
||||||
{
|
{
|
||||||
|
@ -29,20 +30,27 @@ void MARKERS::update()
|
||||||
markers_array.resize(currMovieData.getNumRecords());
|
markers_array.resize(currMovieData.getNumRecords());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MARKERS::save(EMUFILE *os)
|
void MARKERS::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
// write "MARKERS" string
|
if (really_save)
|
||||||
os->fwrite(markers_save_id, MARKERS_ID_LEN);
|
{
|
||||||
// write size
|
// write "MARKERS" string
|
||||||
int size = markers_array.size();
|
os->fwrite(markers_save_id, MARKERS_ID_LEN);
|
||||||
write32le(size, os);
|
// write size
|
||||||
// compress and write array
|
int size = markers_array.size();
|
||||||
int len = markers_array.size();
|
write32le(size, os);
|
||||||
uLongf comprlen = (len>>9)+12 + len;
|
// compress and write array
|
||||||
std::vector<uint8> cbuf(comprlen);
|
int len = markers_array.size();
|
||||||
compress(&cbuf[0], &comprlen, &markers_array[0], len);
|
uLongf comprlen = (len>>9)+12 + len;
|
||||||
write32le(comprlen, os);
|
std::vector<uint8> cbuf(comprlen);
|
||||||
os->fwrite(&cbuf[0], comprlen);
|
compress(&cbuf[0], &comprlen, &markers_array[0], len);
|
||||||
|
write32le(comprlen, os);
|
||||||
|
os->fwrite(&cbuf[0], comprlen);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "MARKERX" string
|
||||||
|
os->fwrite(markers_skipsave_id, MARKERS_ID_LEN);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
bool MARKERS::load(EMUFILE *is)
|
bool MARKERS::load(EMUFILE *is)
|
||||||
|
@ -50,6 +58,13 @@ bool MARKERS::load(EMUFILE *is)
|
||||||
// read "MARKERS" string
|
// read "MARKERS" string
|
||||||
char save_id[MARKERS_ID_LEN];
|
char save_id[MARKERS_ID_LEN];
|
||||||
if ((int)is->fread(save_id, MARKERS_ID_LEN) < MARKERS_ID_LEN) goto error;
|
if ((int)is->fread(save_id, MARKERS_ID_LEN) < MARKERS_ID_LEN) goto error;
|
||||||
|
if (!strcmp(markers_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading Markers
|
||||||
|
FCEU_printf("No markers in the file\n");
|
||||||
|
reset();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (strcmp(markers_save_id, save_id)) goto error; // string is not valid
|
if (strcmp(markers_save_id, save_id)) goto error; // string is not valid
|
||||||
int size;
|
int size;
|
||||||
if (read32le((uint32 *)&size, is) && size >= currMovieData.getNumRecords())
|
if (read32le((uint32 *)&size, is) && size >= currMovieData.getNumRecords())
|
||||||
|
@ -67,6 +82,8 @@ bool MARKERS::load(EMUFILE *is)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
error:
|
error:
|
||||||
|
FCEU_printf("Error loading markers\n");
|
||||||
|
reset();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
|
|
|
@ -13,7 +13,7 @@ public:
|
||||||
void free();
|
void free();
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
|
|
||||||
void MakeCopy(std::vector<uint8> &destination_array);
|
void MakeCopy(std::vector<uint8> &destination_array);
|
||||||
|
|
|
@ -30,6 +30,7 @@ COLORREF hot_changes_colors[16] = { 0x0, 0x5c4c44, 0x854604, 0xab2500, 0xc20006,
|
||||||
//COLORREF hot_changes_colors[16] = { 0x0, 0x661212, 0x842B4E, 0x652C73, 0x48247D, 0x383596, 0x2947AE, 0x1E53C1, 0x135DD2, 0x116EDA, 0x107EE3, 0x0F8EEB, 0x209FF4, 0x3DB1FD, 0x51C2FF, 0x4DCDFF };
|
//COLORREF hot_changes_colors[16] = { 0x0, 0x661212, 0x842B4E, 0x652C73, 0x48247D, 0x383596, 0x2947AE, 0x1E53C1, 0x135DD2, 0x116EDA, 0x107EE3, 0x0F8EEB, 0x209FF4, 0x3DB1FD, 0x51C2FF, 0x4DCDFF };
|
||||||
|
|
||||||
char list_save_id[LIST_ID_LEN] = "LIST";
|
char list_save_id[LIST_ID_LEN] = "LIST";
|
||||||
|
char list_skipsave_id[LIST_ID_LEN] = "LISX";
|
||||||
|
|
||||||
TASEDIT_LIST::TASEDIT_LIST()
|
TASEDIT_LIST::TASEDIT_LIST()
|
||||||
{
|
{
|
||||||
|
@ -184,15 +185,21 @@ void TASEDIT_LIST::update()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TASEDIT_LIST::save(EMUFILE *os)
|
void TASEDIT_LIST::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
update();
|
if (really_save)
|
||||||
// write "LIST" string
|
{
|
||||||
os->fwrite(list_save_id, LIST_ID_LEN);
|
update();
|
||||||
// write current top item
|
// write "LIST" string
|
||||||
int top_item = ListView_GetTopIndex(hwndList);
|
os->fwrite(list_save_id, LIST_ID_LEN);
|
||||||
write32le(top_item, os);
|
// write current top item
|
||||||
|
int top_item = ListView_GetTopIndex(hwndList);
|
||||||
|
write32le(top_item, os);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "LISX" string
|
||||||
|
os->fwrite(list_skipsave_id, LIST_ID_LEN);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
bool TASEDIT_LIST::load(EMUFILE *is)
|
bool TASEDIT_LIST::load(EMUFILE *is)
|
||||||
|
@ -201,15 +208,23 @@ bool TASEDIT_LIST::load(EMUFILE *is)
|
||||||
// read "LIST" string
|
// read "LIST" string
|
||||||
char save_id[LIST_ID_LEN];
|
char save_id[LIST_ID_LEN];
|
||||||
if ((int)is->fread(save_id, LIST_ID_LEN) < LIST_ID_LEN) goto error;
|
if ((int)is->fread(save_id, LIST_ID_LEN) < LIST_ID_LEN) goto error;
|
||||||
|
if (!strcmp(list_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading List
|
||||||
|
FCEU_printf("No list data in the file\n");
|
||||||
|
reset();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (strcmp(list_save_id, save_id)) goto error; // string is not valid
|
if (strcmp(list_save_id, save_id)) goto error; // string is not valid
|
||||||
// read current top item and scroll list there
|
// read current top item and scroll list there
|
||||||
int top_item;
|
int top_item;
|
||||||
if (!read32le(&top_item, is)) goto error;
|
if (!read32le(&top_item, is)) goto error;
|
||||||
ListView_EnsureVisible(hwndList, currMovieData.getNumRecords() - 1, FALSE);
|
ListView_EnsureVisible(hwndList, currMovieData.getNumRecords() - 1, FALSE);
|
||||||
ListView_EnsureVisible(hwndList, top_item, FALSE);
|
ListView_EnsureVisible(hwndList, top_item, FALSE);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
error:
|
error:
|
||||||
|
FCEU_printf("Error loading list data\n");
|
||||||
|
reset();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
|
@ -93,7 +93,7 @@ public:
|
||||||
void reset();
|
void reset();
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
|
|
||||||
void AddFourscore();
|
void AddFourscore();
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include "taseditproj.h"
|
#include "taseditproj.h"
|
||||||
|
|
||||||
char selection_save_id[SELECTION_ID_LEN] = "SELECTION";
|
char selection_save_id[SELECTION_ID_LEN] = "SELECTION";
|
||||||
|
char selection_skipsave_id[SELECTION_ID_LEN] = "SELECTIOX";
|
||||||
|
|
||||||
extern HWND hwndTasEdit;
|
extern HWND hwndTasEdit;
|
||||||
extern int TasEdit_undo_levels;
|
extern int TasEdit_undo_levels;
|
||||||
|
@ -55,7 +56,6 @@ void TASEDIT_SELECTION::reset()
|
||||||
history_start_pos = 0;
|
history_start_pos = 0;
|
||||||
history_cursor_pos = -1;
|
history_cursor_pos = -1;
|
||||||
// create initial selection
|
// create initial selection
|
||||||
ClearSelection();
|
|
||||||
AddNewSelectionToHistory();
|
AddNewSelectionToHistory();
|
||||||
track_selection_changes = true;
|
track_selection_changes = true;
|
||||||
reset_vars();
|
reset_vars();
|
||||||
|
@ -213,20 +213,27 @@ void TASEDIT_SELECTION::JumpToFrame(int frame)
|
||||||
tasedit_list.FollowSelection();
|
tasedit_list.FollowSelection();
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
void TASEDIT_SELECTION::save(EMUFILE *os)
|
void TASEDIT_SELECTION::save(EMUFILE *os, bool really_save)
|
||||||
{
|
{
|
||||||
// write "SELECTION" string
|
if (really_save)
|
||||||
os->fwrite(selection_save_id, SELECTION_ID_LEN);
|
|
||||||
// write vars
|
|
||||||
write32le(history_cursor_pos, os);
|
|
||||||
write32le(history_total_items, os);
|
|
||||||
// write selections starting from history_start_pos
|
|
||||||
for (int i = 0; i < history_total_items; ++i)
|
|
||||||
{
|
{
|
||||||
saveSelection(selections_history[(history_start_pos + i) % history_size], os);
|
// write "SELECTION" string
|
||||||
|
os->fwrite(selection_save_id, SELECTION_ID_LEN);
|
||||||
|
// write vars
|
||||||
|
write32le(history_cursor_pos, os);
|
||||||
|
write32le(history_total_items, os);
|
||||||
|
// write selections starting from history_start_pos
|
||||||
|
for (int i = 0; i < history_total_items; ++i)
|
||||||
|
{
|
||||||
|
saveSelection(selections_history[(history_start_pos + i) % history_size], os);
|
||||||
|
}
|
||||||
|
// write clipboard_selection
|
||||||
|
saveSelection(clipboard_selection, os);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// write "SELECTIOX" string
|
||||||
|
os->fwrite(selection_skipsave_id, SELECTION_ID_LEN);
|
||||||
}
|
}
|
||||||
// write clipboard_selection
|
|
||||||
saveSelection(clipboard_selection, os);
|
|
||||||
}
|
}
|
||||||
// returns true if couldn't load
|
// returns true if couldn't load
|
||||||
bool TASEDIT_SELECTION::load(EMUFILE *is)
|
bool TASEDIT_SELECTION::load(EMUFILE *is)
|
||||||
|
@ -234,6 +241,13 @@ bool TASEDIT_SELECTION::load(EMUFILE *is)
|
||||||
// read "SELECTION" string
|
// read "SELECTION" string
|
||||||
char save_id[SELECTION_ID_LEN];
|
char save_id[SELECTION_ID_LEN];
|
||||||
if ((int)is->fread(save_id, SELECTION_ID_LEN) < SELECTION_ID_LEN) goto error;
|
if ((int)is->fread(save_id, SELECTION_ID_LEN) < SELECTION_ID_LEN) goto error;
|
||||||
|
if (!strcmp(selection_skipsave_id, save_id))
|
||||||
|
{
|
||||||
|
// string says to skip loading Selection
|
||||||
|
FCEU_printf("No selection in the file\n");
|
||||||
|
reset();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (strcmp(selection_save_id, save_id)) goto error; // string is not valid
|
if (strcmp(selection_save_id, save_id)) goto error; // string is not valid
|
||||||
// read vars
|
// read vars
|
||||||
if (!read32le(&history_cursor_pos, is)) goto error;
|
if (!read32le(&history_cursor_pos, is)) goto error;
|
||||||
|
@ -278,6 +292,8 @@ bool TASEDIT_SELECTION::load(EMUFILE *is)
|
||||||
reset_vars();
|
reset_vars();
|
||||||
return false;
|
return false;
|
||||||
error:
|
error:
|
||||||
|
FCEU_printf("Error loading selection\n");
|
||||||
|
reset();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ public:
|
||||||
|
|
||||||
void RedrawTextClipboard();
|
void RedrawTextClipboard();
|
||||||
|
|
||||||
void save(EMUFILE *os);
|
void save(EMUFILE *os, bool really_save = true);
|
||||||
bool load(EMUFILE *is);
|
bool load(EMUFILE *is);
|
||||||
void saveSelection(SelectionFrames& selection, EMUFILE *os);
|
void saveSelection(SelectionFrames& selection, EMUFILE *os);
|
||||||
bool loadSelection(SelectionFrames& selection, EMUFILE *is);
|
bool loadSelection(SelectionFrames& selection, EMUFILE *is);
|
||||||
|
|
|
@ -71,6 +71,24 @@ bool TASEDIT_PROJECT::save()
|
||||||
this->reset();
|
this->reset();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
bool TASEDIT_PROJECT::save_compact(char* filename, bool save_binary, bool save_markers, bool save_bookmarks, bool save_greenzone, bool save_history, bool save_selection, bool save_list)
|
||||||
|
{
|
||||||
|
EMUFILE_FILE* ofs = FCEUD_UTF8_fstream(filename,"wb");
|
||||||
|
|
||||||
|
currMovieData.loadFrameCount = currMovieData.records.size();
|
||||||
|
currMovieData.dump(ofs, save_binary);
|
||||||
|
markers.save(ofs, save_markers);
|
||||||
|
bookmarks.save(ofs, save_bookmarks);
|
||||||
|
greenzone.save(ofs, save_greenzone);
|
||||||
|
history.save(ofs, save_history);
|
||||||
|
selection.save(ofs, save_selection);
|
||||||
|
tasedit_list.save(ofs, save_list);
|
||||||
|
|
||||||
|
delete ofs;
|
||||||
|
|
||||||
|
playback.updateProgressbar();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
bool TASEDIT_PROJECT::load(char* fullname)
|
bool TASEDIT_PROJECT::load(char* fullname)
|
||||||
{
|
{
|
||||||
EMUFILE_FILE ifs(fullname, "rb");
|
EMUFILE_FILE ifs(fullname, "rb");
|
||||||
|
@ -83,74 +101,27 @@ bool TASEDIT_PROJECT::load(char* fullname)
|
||||||
|
|
||||||
FCEU_printf("\nLoading TAS Editor project %s...\n", fullname);
|
FCEU_printf("\nLoading TAS Editor project %s...\n", fullname);
|
||||||
|
|
||||||
bool error;
|
MovieData tempMovieData = MovieData();
|
||||||
extern bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader);
|
extern bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader);
|
||||||
if (LoadFM2(currMovieData, &ifs, ifs.size(), false))
|
if (LoadFM2(tempMovieData, &ifs, ifs.size(), false))
|
||||||
{
|
{
|
||||||
|
currMovieData = tempMovieData;
|
||||||
LoadSubtitles(currMovieData);
|
LoadSubtitles(currMovieData);
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
FCEU_printf("Error loading movie data\n");
|
FCEU_PrintError("Error loading movie data from %s!", fullname);
|
||||||
error = true;
|
return false;
|
||||||
}
|
|
||||||
// try to load markers
|
|
||||||
error = markers.load(&ifs);
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading markers\n");
|
|
||||||
markers.reset();
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// try to load bookmarks
|
|
||||||
error = bookmarks.load(&ifs);
|
|
||||||
}
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading bookmarks\n");
|
|
||||||
bookmarks.reset();
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// try to load greenzone
|
|
||||||
error = greenzone.load(&ifs);
|
|
||||||
}
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading greenzone\n");
|
|
||||||
greenzone.reset();
|
|
||||||
playback.StartFromZero(); // reset playback to frame 0
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// try to load history
|
|
||||||
error = history.load(&ifs);
|
|
||||||
}
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading history\n");
|
|
||||||
history.reset();
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// try to load selection
|
|
||||||
error = selection.load(&ifs);
|
|
||||||
}
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading selection\n");
|
|
||||||
selection.reset();
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// update and try to load list
|
|
||||||
error = tasedit_list.load(&ifs);
|
|
||||||
}
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
FCEU_printf("Error loading list\n");
|
|
||||||
tasedit_list.reset();
|
|
||||||
}
|
}
|
||||||
|
markers.load(&ifs);
|
||||||
|
bookmarks.load(&ifs);
|
||||||
|
greenzone.load(&ifs);
|
||||||
|
history.load(&ifs);
|
||||||
|
selection.load(&ifs);
|
||||||
|
tasedit_list.load(&ifs);
|
||||||
|
|
||||||
playback.reset();
|
playback.reset();
|
||||||
recorder.reset();
|
recorder.reset();
|
||||||
screenshot_display.reset();
|
screenshot_display.reset();
|
||||||
|
|
||||||
reset();
|
reset();
|
||||||
RenameProject(fullname);
|
RenameProject(fullname);
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -27,6 +27,7 @@ public:
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
bool save();
|
bool save();
|
||||||
|
bool save_compact(char* filename, bool save_binary, bool save_markers, bool save_bookmarks, bool save_greenzone, bool save_history, bool save_selection, bool save_list);
|
||||||
bool load(char* fullname);
|
bool load(char* fullname);
|
||||||
|
|
||||||
void RenameProject(char* new_fullname);
|
void RenameProject(char* new_fullname);
|
||||||
|
|
|
@ -1498,9 +1498,11 @@ LRESULT FAR PASCAL AppWndProc(HWND hWnd,UINT msg,WPARAM wParam,LPARAM lParam)
|
||||||
LoadNewGamey(hWnd, 0);
|
LoadNewGamey(hWnd, 0);
|
||||||
if (GameInfo && !(fileDropped.find(".tas") == string::npos))
|
if (GameInfo && !(fileDropped.find(".tas") == string::npos))
|
||||||
{
|
{
|
||||||
//.tas is at the end of the filename so that must be the extension
|
//.tas is at the end of the filename so that must be the extension
|
||||||
FCEUI_LoadMovie(ftmp, 1, false); //We are convinced it is a TAS Editor project file, attempt to load and replay it
|
extern bool EnterTasEdit();
|
||||||
FCEUX_LoadMovieExtras(ftmp);
|
extern bool LoadProject(char* fullname);
|
||||||
|
if (EnterTasEdit()) //We are convinced it is a TAS Editor project file, attempt to load in TAS Editor
|
||||||
|
LoadProject(ftmp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//-------------------------------------------------------
|
//-------------------------------------------------------
|
||||||
|
|
|
@ -593,9 +593,10 @@ static void LoadFM2_binarychunk(MovieData& movieData, EMUFILE* fp, int size)
|
||||||
//yuck... another custom text parser.
|
//yuck... another custom text parser.
|
||||||
bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader)
|
bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader)
|
||||||
{
|
{
|
||||||
|
// if there's no "binary" tag in the movie header, consider it as a movie in text format
|
||||||
|
movieData.binaryFlag = false;
|
||||||
// Non-TASEditor projects consume until EOF
|
// Non-TASEditor projects consume until EOF
|
||||||
std::string a("length"), b("-1");
|
movieData.loadFrameCount = -1;
|
||||||
movieData.installValue(a, b);
|
|
||||||
|
|
||||||
//first, look for an fcm signature
|
//first, look for an fcm signature
|
||||||
char fcmbuf[3];
|
char fcmbuf[3];
|
||||||
|
@ -636,7 +637,9 @@ bool LoadFM2(MovieData& movieData, EMUFILE* fp, int size, bool stopAfterHeader)
|
||||||
{
|
{
|
||||||
LoadFM2_binarychunk(movieData, fp, size);
|
LoadFM2_binarychunk(movieData, fp, size);
|
||||||
return true;
|
return true;
|
||||||
}
|
} else if (isnewline && movieData.loadFrameCount == movieData.records.size())
|
||||||
|
// exit prematurely if loaded the specified amound of records
|
||||||
|
return true;
|
||||||
switch(state)
|
switch(state)
|
||||||
{
|
{
|
||||||
case NEWLINE:
|
case NEWLINE:
|
||||||
|
@ -1196,6 +1199,8 @@ bool FCEUMOV_ReadState(EMUFILE* is, uint32 size)
|
||||||
if (EnterTasEdit())
|
if (EnterTasEdit())
|
||||||
LoadProject(fullname);
|
LoadProject(fullname);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
FCEUI_printf("This movie is a TAS Editor project file! It can be modified in TAS Editor only.\nMovie is now Read-Only.\n");
|
||||||
#endif
|
#endif
|
||||||
movie_readonly = true;
|
movie_readonly = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue