2015-04-22 12:53:22 -05:00
|
|
|
// 6 april 2015
|
|
|
|
#include "uipriv_unix.h"
|
|
|
|
|
|
|
|
uiInitOptions options;
|
|
|
|
|
|
|
|
const char *uiInit(uiInitOptions *o)
|
|
|
|
{
|
|
|
|
GError *err = NULL;
|
|
|
|
const char *msg;
|
|
|
|
|
|
|
|
options = *o;
|
|
|
|
if (gtk_init_with_args(NULL, NULL, NULL, NULL, NULL, &err) == FALSE) {
|
|
|
|
msg = g_strdup(err->message);
|
|
|
|
g_error_free(err);
|
|
|
|
return msg;
|
|
|
|
}
|
2015-05-04 18:26:05 -05:00
|
|
|
initAlloc();
|
2015-04-22 12:53:22 -05:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2015-05-07 21:32:17 -05:00
|
|
|
void uiUninit(void)
|
|
|
|
{
|
2015-05-08 09:17:33 -05:00
|
|
|
uninitMenus();
|
2015-05-07 22:10:19 -05:00
|
|
|
uninitAlloc();
|
2015-05-07 21:32:17 -05:00
|
|
|
}
|
|
|
|
|
2015-04-22 12:53:22 -05:00
|
|
|
void uiFreeInitError(const char *err)
|
|
|
|
{
|
|
|
|
g_free((gpointer) err);
|
|
|
|
}
|
|
|
|
|
|
|
|
void uiMain(void)
|
|
|
|
{
|
|
|
|
gtk_main();
|
|
|
|
}
|
|
|
|
|
2016-06-16 12:59:35 -05:00
|
|
|
struct mainStepsData {
|
|
|
|
void (*f)(void *);
|
|
|
|
void *data;
|
|
|
|
};
|
|
|
|
|
|
|
|
static gboolean mainSteps(gpointer data)
|
|
|
|
{
|
|
|
|
struct mainStepsData *d = (struct mainStepsData *) data;
|
|
|
|
|
|
|
|
(*(d->f))(d->data);
|
|
|
|
// TODO call gtk_main_quit() here again?
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void uiMainSteps(void (*f)(void *), void *data)
|
|
|
|
{
|
|
|
|
struct mainStepsData d;
|
|
|
|
|
|
|
|
d.f = f;
|
|
|
|
d.data = data;
|
|
|
|
gdk_threads_add_idle(mainSteps, &d);
|
|
|
|
gtk_main();
|
|
|
|
}
|
|
|
|
|
2016-05-24 21:29:33 -05:00
|
|
|
int uiMainStep(int wait)
|
|
|
|
{
|
|
|
|
gboolean block;
|
|
|
|
|
|
|
|
block = FALSE;
|
|
|
|
if (wait)
|
|
|
|
block = TRUE;
|
|
|
|
return gtk_main_iteration_do(block) == FALSE;
|
|
|
|
}
|
|
|
|
|
2015-04-22 12:53:22 -05:00
|
|
|
// gtk_main_quit() may run immediately, or it may wait for other pending events; "it depends" (thanks mclasen in irc.gimp.net/#gtk+)
|
|
|
|
// PostQuitMessage() on Windows always waits, so we must do so too
|
|
|
|
// we'll do it by using an idle callback
|
|
|
|
static gboolean quit(gpointer data)
|
|
|
|
{
|
|
|
|
gtk_main_quit();
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void uiQuit(void)
|
|
|
|
{
|
|
|
|
gdk_threads_add_idle(quit, NULL);
|
|
|
|
}
|
2015-12-04 22:42:03 -06:00
|
|
|
|
|
|
|
struct queued {
|
|
|
|
void (*f)(void *);
|
|
|
|
void *data;
|
|
|
|
};
|
|
|
|
|
|
|
|
static gboolean doqueued(gpointer data)
|
|
|
|
{
|
|
|
|
struct queued *q = (struct queued *) data;
|
|
|
|
|
|
|
|
(*(q->f))(q->data);
|
|
|
|
uiFree(q);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void uiQueueMain(void (*f)(void *data), void *data)
|
|
|
|
{
|
|
|
|
struct queued *q;
|
|
|
|
|
|
|
|
q = uiNew(struct queued);
|
|
|
|
q->f = f;
|
|
|
|
q->data = data;
|
|
|
|
gdk_threads_add_idle(doqueued, q);
|
|
|
|
}
|