X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmain.cc;h=9c9981bcc382087363e888ec44f32ef781681868;hb=ff61435a8857e2bcc843beee8e633f40c9f8d989;hp=abdfa35877a8e461b925664e20f252b2d408bf74;hpb=76b28e7ff22a5829da275e29e26faac404a107ae;p=ardour.git diff --git a/gtk2_ardour/main.cc b/gtk2_ardour/main.cc index abdfa35877..9c9981bcc3 100644 --- a/gtk2_ardour/main.cc +++ b/gtk2_ardour/main.cc @@ -18,14 +18,19 @@ */ #include -#include #include -#include #include +#include +#include + #include #include +#ifdef HAVE_FFTW35F +#include +#endif + #include "pbd/error.h" #include "pbd/file_utils.h" #include "pbd/textreceiver.h" @@ -43,16 +48,18 @@ #include "ardour/filesystem_paths.h" #include +#include + #include -#include #include #include "ardour_ui.h" +#include "ui_config.h" #include "opts.h" #include "enums.h" #include "bundle_env.h" -#include "i18n.h" +#include "pbd/i18n.h" #ifdef PLATFORM_WINDOWS #include // Needed for '_fmode' @@ -63,6 +70,10 @@ #include "gtk2ardour-version.h" #endif +#ifdef LXVST_SUPPORT +#include +#endif + using namespace std; using namespace Gtk; using namespace ARDOUR_COMMAND_LINE; @@ -99,6 +110,28 @@ gui_jack_error () win.run (); } +#ifndef NDEBUG +static void ardour_g_log (const gchar *log_domain, GLogLevelFlags log_level, const gchar *message, gpointer user_data) { + switch (log_level) { + case G_LOG_FLAG_FATAL: + case G_LOG_LEVEL_CRITICAL: + fatal << "g_log: " << message << endmsg; + break; + case G_LOG_LEVEL_ERROR: + error << "g_log: " << message << endmsg; + break; + case G_LOG_LEVEL_WARNING: + warning << "g_log: " << message << endmsg; + break; + case G_LOG_LEVEL_MESSAGE: + case G_LOG_LEVEL_INFO: + default: + info << "g_log: " << message << endmsg; + break; + } +} +#endif + static gboolean tell_about_backend_death (void* /* ignored */) { @@ -247,6 +280,8 @@ extern "C" { int ardour_main (int argc, char *argv[]) +#elif defined NOMAIN +int nomain (int argc, char *argv[]) #else int main (int argc, char *argv[]) #endif @@ -261,8 +296,19 @@ int main (int argc, char *argv[]) Glib::thread_init(); } +#ifdef LXVST_SUPPORT + XInitThreads (); +#endif + +#ifdef HAVE_FFTW35F + fftwf_make_planner_thread_safe (); +#endif + #ifdef ENABLE_NLS - gtk_set_locale (); + /* initialize C locale to user preference */ + if (ARDOUR::translations_are_enabled ()) { + setlocale (LC_ALL, ""); + } #endif console_madness_begin(); @@ -332,6 +378,11 @@ int main (int argc, char *argv[]) if (!ARDOUR::init (ARDOUR_COMMAND_LINE::use_vst, ARDOUR_COMMAND_LINE::try_hw_optimization, localedir.c_str())) { error << string_compose (_("could not initialize %1."), PROGRAM_NAME) << endmsg; + Gtk::Main main (argc, argv); + Gtk::MessageDialog msg (string_compose (_("Could not initialize %1 (likely due to corrupt config files).\n" + "Run %1 from a commandline for more information."), PROGRAM_NAME), + false, Gtk::MESSAGE_ERROR , Gtk::BUTTONS_OK, true); + msg.run (); exit (1); } @@ -345,6 +396,13 @@ int main (int argc, char *argv[]) } #endif + DEBUG_TRACE (DEBUG::Locale, string_compose ("main() locale '%1'\n", setlocale (LC_NUMERIC, NULL))); + + if (UIConfiguration::instance().pre_gui_init ()) { + error << _("Could not complete pre-GUI initialization") << endmsg; + exit (1); + } + try { ui = new ARDOUR_UI (&argc, &argv, localedir.c_str()); } catch (failed_constructor& err) { @@ -352,14 +410,34 @@ int main (int argc, char *argv[]) exit (1); } +#ifndef NDEBUG + g_log_set_handler (NULL, + GLogLevelFlags (G_LOG_LEVEL_WARNING | G_LOG_FLAG_FATAL | G_LOG_LEVEL_CRITICAL | G_LOG_FLAG_RECURSION), + &ardour_g_log, NULL); +#endif + ui->run (text_receiver); Gtkmm2ext::Application::instance()->cleanup(); delete ui; ui = 0; ARDOUR::cleanup (); +#ifndef NDEBUG + if (getenv ("ARDOUR_RUNNING_UNDER_VALGRIND")) { + Glib::usleep(100000); + sched_yield(); + } +#endif + pthread_cancel_all (); +#ifndef NDEBUG + if (getenv ("ARDOUR_RUNNING_UNDER_VALGRIND")) { + Glib::usleep(100000); + sched_yield(); + } +#endif + console_madness_end (); return 0;