X-Git-Url: https://develop.uap-core.de/gitweb/uwplayer.git/blobdiff_plain/d165fb07a7fd8e80662281e46b998d5458e9d02c..01d5015ba093f8c5fdb18b669943c7da6450e72f:/application/main.c diff --git a/application/main.c b/application/main.c index 55a9d4f..422b6ee 100644 --- a/application/main.c +++ b/application/main.c @@ -26,18 +26,23 @@ #include #include #include +#include #include "window.h" #include "main.h" #include "settings.h" -#include -#include +#include +#include static XtAppContext app; static Display *display; static Widget toplevel_window; +static char *open_file_arg; + +static int event_pipe[2]; + static String fallback[] = { "*renderTable: rt", "*rt*fontType: FONT_IS_XFT", @@ -46,7 +51,7 @@ static String fallback[] = { "*pbbutton.shadowThickness: 1", "*pbbutton.highlightThickness: 1", - + "*XmText.baseTranslations: #override\\n" \ "Ctrl~Alt~Metav: paste-clipboard()\\n" \ "Ctrl~Alt~Metac: copy-clipboard()\\n" \ @@ -66,10 +71,30 @@ static String langProc(Display *dp, String xnl, XtPointer closure) { return setlocale(LC_ALL, NULL); } +typedef struct EventLoopCB { + XtWorkProc proc; + XtPointer data; +} EventLoopCB; + +static void input_proc(XtPointer data, int *source, XtInputId *iid) { + EventLoopCB cb[16]; + ssize_t r = read(event_pipe[0], cb, sizeof(EventLoopCB)*16); + size_t n = r / sizeof(EventLoopCB); + for(int i=0;i 1) { + struct stat s; + if(stat(argv[1], &s)) { + fprintf(stderr, "Cannot open file: %s\n", argv[1]); + perror(""); + return 1; + } + open_file_arg = argv[1]; + } + // load settings - if(load_settings()) { + if(load_config()) { return 1; } + // try single instance open + if(open_file_arg) { + char *instance_path = InstanceFilePath(display); + int instance_fd = ConnectToInstance(instance_path); + free(instance_path); + + if(instance_fd >= 0) { + write(instance_fd, "open ", 5); + write(instance_fd, open_file_arg, strlen(open_file_arg)); + write(instance_fd, "\n", 1); + close(instance_fd); + return 0; + } + } + + XtAppAddInput( + app, + event_pipe[0], + (XtPointer)XtInputReadMask, + input_proc, + NULL); + MainWindow *window = WindowCreate(display); toplevel_window = window->window; - // random numbers only used for creating tmp dirs + // random numbers used for creating tmp dirs and for random playback srand(time(NULL)); WindowShow(window); - XtAppMainLoop(app); + AppMainLoop(app); return 0; } @@ -104,18 +161,39 @@ void ApplicationExit(void) { XtAppSetExitFlag(app); } -void AppAddTimeOut(unsigned long interval, XtTimerCallbackProc proc, XtPointer data) { - XtAppAddTimeOut(app, interval, proc, data); - - if(!toplevel_window) return; - - // send a dummy X11 event, because the event loop may be waiting - // and the timeout proc is only called when an event is processed - XClientMessageEvent event; - memset(&event, 0, sizeof(XClientMessageEvent)); - event.type = ClientMessage; - event.window = XtWindow(toplevel_window); - event.format = 32; - XSendEvent(display, XtWindow(toplevel_window), 0, 0, (XEvent*)&event); - XFlush(display); +void AppExecProc(XtWorkProc proc, XtPointer data) { + EventLoopCB cb; + cb.proc = proc; + cb.data = data; + write(event_pipe[1], &cb, sizeof(cb)); +} + +char* GetOpenFileArg(void) { + return open_file_arg; +} + +void CleanOpenFileArg(void) { + open_file_arg = NULL; +} + +static Window app_player_window = 0; + +void SetPlayerWindow(Window w) { + app_player_window = w; +} + +/* + * Extended Xt main loop, that also handles external window events + */ +void AppMainLoop(XtAppContext app) { + while(!XtAppGetExitFlag(app)) { + XEvent event; + XtAppNextEvent(app, &event); + + if(app_player_window != 0 && event.xany.window == app_player_window) { + WindowHandlePlayerEvent(GetMainWindow(), &event); + } else { + XtDispatchEvent(&event); + } + } }