X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=main.cpp;h=4287b7e56f8d4faf321f28221d432492ac54c1bd;hb=b9feb66845bf24465b7671ac9ff7a52b88f6032b;hp=afac03ed4d3ea81e4c2c813d3bb0b119a097ef07;hpb=0c85018bc5c468ad1b3775d69951e43f11baca19;p=nageru diff --git a/main.cpp b/main.cpp index afac03e..4287b7e 100644 --- a/main.cpp +++ b/main.cpp @@ -13,15 +13,46 @@ extern "C" { #include #include +#ifdef HAVE_CEF +#include +#include +#include +#include +#endif + #include "basic_stats.h" +#ifdef HAVE_CEF +#include "nageru_cef_app.h" +#endif #include "context.h" #include "flags.h" #include "image_input.h" #include "mainwindow.h" #include "mixer.h" +#ifdef HAVE_CEF +CefRefPtr cef_app; +#endif + int main(int argc, char *argv[]) { +#ifdef HAVE_CEF + // Let CEF have first priority on parsing the command line, because we might be + // launched as a CEF sub-process. + CefMainArgs main_args(argc, argv); + cef_app = CefRefPtr(new NageruCefApp()); + int err = CefExecuteProcess(main_args, cef_app.get(), nullptr); + if (err >= 0) { + return err; + } + + // CEF wants to use GLib for its main loop, which interferes with Qt's use of it. + // The alternative is trying to integrate CEF into Qt's main loop, but that requires + // fairly extensive cross-thread communication and that parts of CEF runs on Qt's UI + // thread. + setenv("QT_NO_GLIB", "1", 0); +#endif + parse_flags(PROGRAM_NAGERU, argc, argv); if (global_flags.va_display.empty() ||