Avoid assert() when loading xml: Throw an XMLerror if attribute_value fails.
[ardour.git] / libs / pbd / pbd.cc
index 58c8440a0ff9b5a34f964860bf5b584d0703f725..a7a818ee5ffff8782c16451dc67e8bad39971c22 100644 (file)
 
 #include <iostream>
 #include <cstdlib>
+#include <string>
+
+#ifdef PLATFORM_WINDOWS
+#include <fcntl.h>
+#endif
+
+#include <giomm.h>
 
 #include <glibmm/thread.h>
 
 #include "pbd/pbd.h"
 #include "pbd/debug.h"
+#include "pbd/error.h"
 #include "pbd/id.h"
 #include "pbd/enumwriter.h"
+#include "pbd/fpu.h"
+
+#ifdef PLATFORM_WINDOWS
+#include <winsock2.h>
+#include "pbd/windows_timer_utils.h"
+#include "pbd/windows_mmcss.h"
+#endif
+
+#include "pbd/i18n.h"
 
-#include "i18n.h"
+extern void setup_libpbd_enums ();
 
 namespace {
 
 static bool libpbd_initialized = false;
 
+static
+void
+set_debug_options_from_env ()
+{
+       bool set;
+       std::string options;
+
+       options = Glib::getenv ("PBD_DEBUG", set);
+       if (set) {
+               std::cerr << X_("PBD_DEBUG=") << options << std::endl;
+               PBD::parse_debug_options (options.c_str());
+       }
+}
+
+#ifdef PLATFORM_WINDOWS
+static
+void
+test_timers_from_env ()
+{
+       bool set;
+       std::string options;
+
+       options = Glib::getenv ("PBD_TEST_TIMERS", set);
+       if (set) {
+               if (!PBD::QPC::check_timer_valid ()) {
+                       PBD::error << X_("Windows QPC Timer source not usable") << endmsg;
+               } else {
+                       PBD::info << X_("Windows QPC Timer source usable") << endmsg;
+               }
+       }
 }
+#endif
+
+} // namespace
 
 bool
 PBD::init ()
@@ -42,12 +92,43 @@ PBD::init ()
                return true;
        }
 
+#ifdef PLATFORM_WINDOWS
+       // Essential!!  Make sure that any files used by Ardour
+       //              will be created or opened in BINARY mode!
+       _fmode = O_BINARY;
+
+       WSADATA wsaData;
+
+       /* Initialize windows socket DLL for PBD::CrossThreadChannel
+        */
+
+       if (WSAStartup(MAKEWORD(1,1),&wsaData) != 0) {
+               error << X_("Windows socket initialization failed with error: ") << WSAGetLastError() << endmsg;
+               return false;
+       }
+
+       QPC::initialize();
+       test_timers_from_env ();
+
+       if (!PBD::MMCSS::initialize()) {
+               PBD::info << X_("Unable to initialize MMCSS") << endmsg;
+       } else {
+               PBD::info << X_("MMCSS Initialized") << endmsg;
+       }
+#endif
+
        if (!Glib::thread_supported()) {
                Glib::thread_init();
        }
 
+       Gio::init ();
+
        PBD::ID::init ();
 
+       setup_libpbd_enums ();
+
+       set_debug_options_from_env ();
+
        libpbd_initialized = true;
        return true;
 }
@@ -55,5 +136,11 @@ PBD::init ()
 void
 PBD::cleanup ()
 {
+#ifdef PLATFORM_WINDOWS
+       PBD::MMCSS::deinitialize ();
+       WSACleanup();
+#endif
+
        EnumWriter::destroy ();
+       FPU::destroy ();
 }