mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-26 03:11:30 +00:00
Cleaning up some file dialog tidbits in Rambetter-temp-fixes branch.
Just some code maintenence. Like removing unused local vars. PLS MERGE TO TRUNK. git-svn-id: svn://svn.icculus.org/gtkradiant/GtkRadiant/branches/Rambetter-temp-fixes@356 8a3a26a2-13c4-0310-b231-cf6edde360e5
This commit is contained in:
parent
b292b8db59
commit
36a1c4bbad
2 changed files with 10 additions and 12 deletions
|
@ -1203,13 +1203,11 @@ private:
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
|
||||||
static int in_file_dialog = 0;
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
gboolean open;
|
gboolean open;
|
||||||
OPENFILENAME *ofn;
|
OPENFILENAME *ofn;
|
||||||
BOOL dlgRtnVal;
|
BOOL dlgRtnVal;
|
||||||
int done;
|
bool done;
|
||||||
} win32_native_file_dialog_comms_t;
|
} win32_native_file_dialog_comms_t;
|
||||||
|
|
||||||
DWORD WINAPI win32_native_file_dialog_thread_func(LPVOID lpParam)
|
DWORD WINAPI win32_native_file_dialog_thread_func(LPVOID lpParam)
|
||||||
|
@ -1222,7 +1220,7 @@ DWORD WINAPI win32_native_file_dialog_thread_func(LPVOID lpParam)
|
||||||
else {
|
else {
|
||||||
fileDialogComms->dlgRtnVal = GetSaveFileName(fileDialogComms->ofn);
|
fileDialogComms->dlgRtnVal = GetSaveFileName(fileDialogComms->ofn);
|
||||||
}
|
}
|
||||||
fileDialogComms->done = -1; // No need to synchronize around lock.
|
fileDialogComms->done = true; // No need to synchronize around lock, one-way gate.
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1235,14 +1233,14 @@ const char* file_dialog (void *parent, gboolean open, const char* title, const c
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
static bool in_file_dialog = false;
|
||||||
HANDLE fileDialogThreadHandle;
|
HANDLE fileDialogThreadHandle;
|
||||||
win32_native_file_dialog_comms_t fileDialogComms;
|
win32_native_file_dialog_comms_t fileDialogComms;
|
||||||
int dialogDone;
|
bool dialogDone;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Gtk dialog
|
// Gtk dialog
|
||||||
GtkWidget* file_sel;
|
GtkWidget* file_sel;
|
||||||
int loop = 1;
|
|
||||||
char *new_path = NULL;
|
char *new_path = NULL;
|
||||||
|
|
||||||
const char* r;
|
const char* r;
|
||||||
|
@ -1258,7 +1256,7 @@ const char* file_dialog (void *parent, gboolean open, const char* title, const c
|
||||||
// do that the native way
|
// do that the native way
|
||||||
|
|
||||||
if (in_file_dialog) return NULL; // Avoid recursive entry.
|
if (in_file_dialog) return NULL; // Avoid recursive entry.
|
||||||
in_file_dialog = 1;
|
in_file_dialog = true;
|
||||||
/* Set the members of the OPENFILENAME structure. */
|
/* Set the members of the OPENFILENAME structure. */
|
||||||
// See http://msdn.microsoft.com/en-us/library/ms646839%28v=vs.85%29.aspx .
|
// See http://msdn.microsoft.com/en-us/library/ms646839%28v=vs.85%29.aspx .
|
||||||
memset(&ofn, 0, sizeof(ofn));
|
memset(&ofn, 0, sizeof(ofn));
|
||||||
|
@ -1305,16 +1303,16 @@ const char* file_dialog (void *parent, gboolean open, const char* title, const c
|
||||||
0, // dwCreationFlags
|
0, // dwCreationFlags
|
||||||
NULL); // lpThreadId
|
NULL); // lpThreadId
|
||||||
|
|
||||||
dialogDone = 0;
|
dialogDone = false;
|
||||||
while (1) {
|
while (1) {
|
||||||
// Avoid blocking indefinitely. Another thread will set fileDialogComms->done to nonzero;
|
// Avoid blocking indefinitely. Another thread will set fileDialogComms->done to true;
|
||||||
// we don't want to be in an indefinite blocked state when this happens. We want to break
|
// we don't want to be in an indefinite blocked state when this happens. We want to break
|
||||||
// out of here eventually.
|
// out of here eventually.
|
||||||
while (gtk_events_pending()) {
|
while (gtk_events_pending()) {
|
||||||
gtk_main_iteration();
|
gtk_main_iteration();
|
||||||
}
|
}
|
||||||
if (dialogDone) break;
|
if (dialogDone) break;
|
||||||
if (fileDialogComms.done) dialogDone = 1; // One more loop of gtk_main_iteration() to get things in sync.
|
if (fileDialogComms.done) dialogDone = true; // One more loop of gtk_main_iteration() to get things in sync.
|
||||||
// Avoid tight infinte loop, add a small amount of sleep.
|
// Avoid tight infinte loop, add a small amount of sleep.
|
||||||
Sleep(10);
|
Sleep(10);
|
||||||
}
|
}
|
||||||
|
@ -1322,7 +1320,7 @@ const char* file_dialog (void *parent, gboolean open, const char* title, const c
|
||||||
WaitForSingleObject(fileDialogThreadHandle, INFINITE);
|
WaitForSingleObject(fileDialogThreadHandle, INFINITE);
|
||||||
CloseHandle(fileDialogThreadHandle);
|
CloseHandle(fileDialogThreadHandle);
|
||||||
|
|
||||||
in_file_dialog = 0;
|
in_file_dialog = false;
|
||||||
|
|
||||||
if (!fileDialogComms.dlgRtnVal) {
|
if (!fileDialogComms.dlgRtnVal) {
|
||||||
return NULL; // Cancelled.
|
return NULL; // Cancelled.
|
||||||
|
|
|
@ -2218,7 +2218,7 @@ void PrefsDlg::BuildDialog ()
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
// win32 file dialog
|
// win32 file dialog
|
||||||
check = gtk_check_button_new_with_label (_("Use win32 file load dialog (hacky)"));
|
check = gtk_check_button_new_with_label (_("Use win32 file dialog (hacky)"));
|
||||||
gtk_widget_show (check);
|
gtk_widget_show (check);
|
||||||
// gtk_container_add (GTK_CONTAINER (vbox), check);
|
// gtk_container_add (GTK_CONTAINER (vbox), check);
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), check, FALSE, FALSE, 0);
|
gtk_box_pack_start(GTK_BOX(vbox), check, FALSE, FALSE, 0);
|
||||||
|
|
Loading…
Reference in a new issue