gtk: display more relevant error messages

sdl: use FCEUD_PrintError for palette loading
gtk: remove redundant error dialogs now that FCEUD_PrintError is implemented in GTK
gtk: prevent GTK FCEUD_PrintError calls from spawning GTK dialogs before GTK is initialized
This commit is contained in:
punkrockguy318 2013-02-13 00:19:00 +00:00
parent 45f53470b9
commit 3f05056fed
4 changed files with 30 additions and 27 deletions

View File

@ -36,12 +36,18 @@ LoadCPalette(const std::string &file)
FILE *fp; FILE *fp;
if(!(fp = FCEUD_UTF8fopen(file.c_str(), "rb"))) { if(!(fp = FCEUD_UTF8fopen(file.c_str(), "rb"))) {
printf(" Error loading custom palette from file: %s\n", file.c_str()); char errorMsg[256];
strcpy(errorMsg, "Error loading custom palette from file: ");
strcat(errorMsg, file.c_str());
FCEUD_PrintError(errorMsg);
return 0; return 0;
} }
size_t result = fread(tmpp, 1, 192, fp); size_t result = fread(tmpp, 1, 192, fp);
if(result != 192) { if(result != 192) {
printf(" Error reading custom palette from file: %s\n", file.c_str()); char errorMsg[256];
strcpy(errorMsg, "Error loading custom palette from file: ");
strcat(errorMsg, file.c_str());
FCEUD_PrintError(errorMsg);
return 0; return 0;
} }
FCEUI_SetPaletteArray(tmpp); FCEUI_SetPaletteArray(tmpp);

View File

@ -51,6 +51,7 @@ GtkWidget* padNoCombo = NULL;
GtkWidget* configNoCombo = NULL; GtkWidget* configNoCombo = NULL;
GtkWidget* buttonMappings[10]; GtkWidget* buttonMappings[10];
GtkRadioAction* stateSlot = NULL; GtkRadioAction* stateSlot = NULL;
bool gtkIsStarted = false;
// check to see if a particular GTK version is available // check to see if a particular GTK version is available
// 2.24 is required for most of the dialogs -- ie: checkGTKVersion(2,24); // 2.24 is required for most of the dialogs -- ie: checkGTKVersion(2,24);
@ -233,15 +234,7 @@ void loadPalette (GtkWidget* w, gpointer p)
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fileChooser)); filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fileChooser));
g_config->setOption("SDL.Palette", filename); g_config->setOption("SDL.Palette", filename);
g_config->setOption("SDL.SDL.NTSCpalette", 0); g_config->setOption("SDL.SDL.NTSCpalette", 0);
if(LoadCPalette(filename) == 0) LoadCPalette(filename);
{
GtkWidget* msgbox;
msgbox = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE,
"Failed to load the palette.");
gtk_dialog_run(GTK_DIALOG(msgbox));
gtk_widget_hide(msgbox);
}
gtk_entry_set_text(GTK_ENTRY(p), filename); gtk_entry_set_text(GTK_ENTRY(p), filename);
@ -1362,14 +1355,7 @@ void hardReset ()
closeGame(); closeGame();
const char* lastFile; const char* lastFile;
g_config->getOption("SDL.LastOpenFile", &lastFile); g_config->getOption("SDL.LastOpenFile", &lastFile);
if(LoadGame(lastFile) == 0) LoadGame(lastFile) == 0;
{
GtkWidget* d;
d = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK,
"Error opening the ROM file.");
gtk_dialog_run(GTK_DIALOG(d));
gtk_widget_destroy(d);
}
resizeGtkWindow(); resizeGtkWindow();
} }
} }
@ -1523,6 +1509,7 @@ void loadLua ()
gtk_widget_destroy(fileChooser); gtk_widget_destroy(fileChooser);
if(FCEU_LoadLuaCode(filename) == 0) if(FCEU_LoadLuaCode(filename) == 0)
{ {
// This is necessary because lua scripts do not use FCEUD_PrintError to print errors.
GtkWidget* d; GtkWidget* d;
d = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, d = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK,
"Could not open the selected lua script."); "Could not open the selected lua script.");
@ -1720,7 +1707,9 @@ void loadNSF ()
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fileChooser)); filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fileChooser));
gtk_widget_destroy (fileChooser); gtk_widget_destroy (fileChooser);
if(LoadGame(filename) == 0) LoadGame(filename);
// no longer required with GTK FCEUD_PrintError implementation
/*if(LoadGame(filename) == 0)
{ {
GtkWidget* d; GtkWidget* d;
@ -1728,7 +1717,7 @@ void loadNSF ()
"Could not open the selected NSF file."); "Could not open the selected NSF file.");
gtk_dialog_run(GTK_DIALOG(d)); gtk_dialog_run(GTK_DIALOG(d));
gtk_widget_destroy(d); gtk_widget_destroy(d);
} }*/
g_config->setOption("SDL.LastOpenNSF", filename); g_config->setOption("SDL.LastOpenNSF", filename);
g_free(filename); g_free(filename);
} }
@ -1811,7 +1800,9 @@ void loadGame ()
gtk_widget_destroy (fileChooser); gtk_widget_destroy (fileChooser);
g_config->setOption("SDL.LastOpenFile", filename); g_config->setOption("SDL.LastOpenFile", filename);
closeGame(); closeGame();
if(LoadGame(filename) == 0) LoadGame(filename);
// Error dialog no longer required with GTK implementation of FCEUD_PrintError()
/*if(LoadGame(filename) == 0)
{ {
GtkWidget* d; GtkWidget* d;
@ -1819,7 +1810,7 @@ void loadGame ()
"Could not open the selected ROM file."); "Could not open the selected ROM file.");
gtk_dialog_run(GTK_DIALOG(d)); gtk_dialog_run(GTK_DIALOG(d));
gtk_widget_destroy(d); gtk_widget_destroy(d);
} }*/
resizeGtkWindow(); resizeGtkWindow();
g_free(filename); g_free(filename);
} }
@ -2477,6 +2468,7 @@ int InitGTKSubsystem(int argc, char** argv)
GtkRequisition req; GtkRequisition req;
gtk_widget_size_request(GTK_WIDGET(MainWindow), &req); gtk_widget_size_request(GTK_WIDGET(MainWindow), &req);
gtk_window_resize(GTK_WINDOW(MainWindow), req.width, req.height); gtk_window_resize(GTK_WINDOW(MainWindow), req.width, req.height);
gtkIsStarted = true;
return 0; return 0;
} }

View File

@ -25,6 +25,7 @@ extern GtkWidget* MainWindow;
extern GtkWidget* evbox; extern GtkWidget* evbox;
extern GtkRadioAction* stateSlot; extern GtkRadioAction* stateSlot;
extern int GtkMouseData[3]; extern int GtkMouseData[3];
extern bool gtkIsStarted;
int InitGTKSubsystem(int argc, char** argv); int InitGTKSubsystem(int argc, char** argv);
void pushOutputToGTK(const char* str); void pushOutputToGTK(const char* str);
void showGui(bool b); void showGui(bool b);

View File

@ -885,10 +885,14 @@ void FCEUD_Message(const char *text)
void FCEUD_PrintError(const char *errormsg) void FCEUD_PrintError(const char *errormsg)
{ {
#ifdef GTK #ifdef GTK
GtkWidget* d; //if(noGui == 0)
d = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, errormsg); if(gtkIsStarted == true)
gtk_dialog_run(GTK_DIALOG(d)); {
gtk_widget_destroy(d); GtkWidget* d;
d = gtk_message_dialog_new(GTK_WINDOW(MainWindow), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, errormsg);
gtk_dialog_run(GTK_DIALOG(d));
gtk_widget_destroy(d);
}
#endif #endif
fprintf(stderr, "%s\n", errormsg); fprintf(stderr, "%s\n", errormsg);