80 lines
1.4 KiB
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
|
|
}
|