improve sysex data display.
[ardour.git] / gtk2_ardour / main.cc
index ce7dc4b5d14bd247aac1c47c0f626363150b66f6..9b0a0c5e2f42edd3ffd9caa2490e29d3c50ff7a9 100644 (file)
 */
 
 #include <cstdlib>
-#include <signal.h>
 #include <cerrno>
 #include <vector>
 
+#include <signal.h>
+#include <locale.h>
+
 #include <sigc++/bind.h>
 #include <gtkmm/settings.h>
 
+#ifdef HAVE_FFTW35F
+#include <fftw3.h>
+#endif
+
 #include "pbd/error.h"
 #include "pbd/file_utils.h"
 #include "pbd/textreceiver.h"
@@ -52,7 +58,7 @@
 #include "enums.h"
 #include "bundle_env.h"
 
-#include "i18n.h"
+#include "pbd/i18n.h"
 
 #ifdef PLATFORM_WINDOWS
 #include <fcntl.h> // Needed for '_fmode'
@@ -269,6 +275,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
@@ -283,8 +291,30 @@ int main (int argc, char *argv[])
                Glib::thread_init();
        }
 
+#ifdef HAVE_FFTW35F
+       fftwf_make_planner_thread_safe ();
+#endif
+
 #ifdef ENABLE_NLS
-       gtk_set_locale ();
+       /* initialize C and C++ locales to user preference */
+       char* l_msg = NULL;
+       char* l_num = NULL;
+       if (ARDOUR::translations_are_enabled ()) {
+               setlocale (LC_ALL, "");
+               try {
+                       std::locale::global (std::locale (setlocale (LC_ALL, 0)));
+               } catch (...) {
+                       std::cerr << "Cannot set C++ locale\n";
+               }
+#ifndef COMPILER_MSVC
+               // LC_MESSAGES isn't a supported locale setting when building
+               // with MSVC (in fact, I doubt if it's valid for Windows at all)
+               l_msg = setlocale (LC_MESSAGES, NULL);
+#endif
+               l_num = setlocale (LC_NUMERIC, NULL);
+               if (l_msg) { l_msg = strdup (l_msg); }
+               if (l_num) { l_num = strdup (l_num); }
+       }
 #endif
 
        console_madness_begin();
@@ -361,12 +391,33 @@ int main (int argc, char *argv[])
                return curvetest (curvetest_file);
        }
 
+#ifdef ENABLE_NLS
+       ARDOUR::LocaleMode locale_mode = UIConfiguration::instance().get_locale_mode ();
+       if (l_msg && l_num && locale_mode != ARDOUR::SET_LC_ALL) {
+               try {
+                       std::locale cpp_locale (std::locale::classic ());
+                       cpp_locale = std::locale (cpp_locale, l_msg, std::locale::messages);
+                       if (ARDOUR::SET_LC_MESSAGES_AND_LC_NUMERIC == locale_mode) {
+                               cpp_locale = std::locale (cpp_locale, l_num, std::locale::numeric);
+                       }
+                       std::locale::global (cpp_locale);
+               } catch (...) {
+                       std::cerr << "Cannot override C++ locale\n";
+               }
+               info << "LC_ALL: " << setlocale (LC_ALL, NULL) << endmsg;
+       }
+       free (l_msg);
+       free (l_num);
+#endif
+
 #ifndef PLATFORM_WINDOWS
        if (::signal (SIGPIPE, sigpipe_handler)) {
                cerr << _("Cannot xinstall SIGPIPE error handler") << endl;
        }
 #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);
@@ -391,8 +442,22 @@ int main (int argc, char *argv[])
        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;