libui/unix/main.c

80 lines
1.4 KiB
C

// 6 april 2015
#include "uipriv_unix.h"
const char **uiprivSysInitErrors(void)
{
return NULL;
}
static pthread_t mainThread;
static gboolean initialized = FALSE; // TODO deduplicate this from common/init.c
int uiprivSysInit(void *options, uiInitError *err)
{
GError *gerr = NULL;
if (gtk_init_with_args(NULL, NULL, NULL, NULL, NULL, &gerr) == FALSE) {
// TODO make sure this is safe
strncpy(err->Message, gerr->message, 255);
g_error_free(gerr);
return 0;
}
mainThread = pthread_self();
initialized = TRUE;
return 1;
}
void uiMain(void)
{
if (!uiprivCheckInitializedAndThread())
return;
gtk_main();
}
void uiQuit(void)
{
if (!uiprivCheckInitializedAndThread())
return;
gtk_main_quit();
}
struct queued {
void (*f)(void *);
void *data;
};
static gboolean doqueued(gpointer data)
{
struct queued *q = (struct queued *) data;
(*(q->f))(q->data);
g_free(q);
return FALSE;
}
void uiQueueMain(void (*f)(void *data), void *data)
{
struct queued *q;
if (!initialized) {
uiprivProgrammerError(uiprivProgrammerErrorNotInitialized, uiprivFunc);
return;
}
q = g_new0(struct queued, 1);
q->f = f;
q->data = data;
gdk_threads_add_idle(doqueued, q);
}
bool uiprivSysCheckThread(void)
{
return pthread_equal(pthread_self(), mainThread);
}
void uiprivReportError(const char *prefix, const char *msg, const char *suffix, bool internal)
{
g_critical("%s: %s. %s", prefix, msg, suffix);
G_BREAKPOINT();
abort(); // we shouldn't reach here
}