implement ui_call_mainthread (Motif)

Sun, 23 Nov 2025 10:23:10 +0100

author
Olaf Wintermann <olaf.wintermann@gmail.com>
date
Sun, 23 Nov 2025 10:23:10 +0100
changeset 929
43cb1ea4c582
parent 928
35a0fd2f4f3d
child 930
4ce8df2311f0

implement ui_call_mainthread (Motif)

ui/motif/toolkit.c file | annotate | diff | comparison | revisions
ui/motif/toolkit.h file | annotate | diff | comparison | revisions
--- a/ui/motif/toolkit.c	Sun Nov 23 10:12:42 2025 +0100
+++ b/ui/motif/toolkit.c	Sun Nov 23 10:23:10 2025 +0100
@@ -84,13 +84,15 @@
 	NULL
 };
 
+static String *fallback_resources = fallback;
+
 void input_proc(XtPointer data, int *source, XtInputId *iid) {
     void *ptr;
     read(event_pipe[0], &ptr, sizeof(void*));
 }
 
-void ui_motif_set_fallback_resources(String fallbackres[]) {
-    fallback = fallbackres;
+void ui_motif_set_fallback_resources(String *fallbackres) {
+    fallback_resources = fallbackres;
 }
 
 void ui_init(const char *appname, int argc, char **argv) { 
@@ -100,7 +102,7 @@
     XtToolkitInitialize();
     XtSetLanguageProc(NULL, NULL, NULL);
     app = XtCreateApplicationContext();
-    XtAppSetFallbackResources(app, fallback);
+    XtAppSetFallbackResources(app, fallback_resources);
     
     display =  XtOpenDisplay(app, NULL, appname, appname, NULL, 0, &argc, argv);
     
@@ -224,6 +226,15 @@
     return TRUE;
 }
 
+static Boolean ui_mainthread_job(void *data) {
+    UiJob *job = data;
+    if(job->job_func) {
+        job->job_func(job->job_data);
+    }
+    free(job);
+    return TRUE;
+}
+
 static void* ui_jobthread(void *data) {
     UiJob *job = data;
     int result = job->job_func(job->job_data);
@@ -235,6 +246,15 @@
     return NULL;
 }
 
+void ui_call_mainthread(ui_threadfunc tf, void* td) {
+    UiJob *job = malloc(sizeof(UiJob));
+    memset(job, 0, sizeof(UiJob));
+    job->job_func = tf;
+    job->job_data = td;
+    write(event_pipe[1], &job, sizeof(void*)); // hack
+    XtAppAddWorkProc(app, ui_mainthread_job, job);
+}
+
 void ui_job(UiObject *obj, ui_threadfunc tf, void *td, ui_callback f, void *fd) {
     UiJob *job = malloc(sizeof(UiJob));
     job->obj = obj;
--- a/ui/motif/toolkit.h	Sun Nov 23 10:12:42 2025 +0100
+++ b/ui/motif/toolkit.h	Sun Nov 23 10:23:10 2025 +0100
@@ -84,7 +84,7 @@
 
 XtAppContext ui_motif_get_app(void);
 Display* ui_motif_get_display(void);
-void ui_motif_set_fallback_resources(String fallback[]);
+void ui_motif_set_fallback_resources(String *fallback);
 
 void ui_set_active_window(Widget w);
 Widget ui_get_active_window();

mercurial