restore sending stderr/stdout to the console
authorPaul Davis <paul@linuxaudiosystems.com>
Sun, 24 Apr 2016 15:24:34 +0000 (11:24 -0400)
committerPaul Davis <paul@linuxaudiosystems.com>
Sun, 24 Apr 2016 15:25:03 +0000 (11:25 -0400)
This is done unconditionally right now for any ARDOUR_BUNDLED case. Need to
find a conditional, so that we can run from the command line/inside a debugger.
The -psn_XXXX argument will likely work

gtk2_ardour/bundle_env_cocoa.cc

index df951b8801bb2eb43f6f150e5240225c84a70636..8603db3f45c1f8d5e29d892a472476da198f0c31 100644 (file)
@@ -40,6 +40,7 @@
 
 #include "i18n.h"
 
+#include <asl.h>
 #include <Carbon/Carbon.h>
 #include <mach-o/dyld.h>
 #include <sys/param.h>
@@ -50,8 +51,27 @@ using namespace std;
 
 extern void set_language_preference (); // cocoacarbon.mm
 
+static void
+setup_logging(void)
+{
+        aslmsg msg;
+        aslclient c = asl_open (PROGRAM_NAME, "com.apple.console", 0);
+
+        msg = asl_new(ASL_TYPE_MSG);
+        asl_set(msg, ASL_KEY_FACILITY, "com.apple.console");
+        asl_set(msg, ASL_KEY_LEVEL, ASL_STRING_NOTICE);
+        asl_set(msg, ASL_KEY_READ_UID, "-1");
+
+        int fd = dup(2);
+        //asl_set_filter(c, ASL_FILTER_MASK_UPTO(ASL_LEVEL_DEBUG));
+        asl_add_log_file(c, fd);
+        asl_log(c, NULL, ASL_LEVEL_INFO, string_compose ("Hello world from %1", PROGRAM_NAME).c_str());
+        asl_log_descriptor(c, msg, ASL_LEVEL_INFO, 1,  ASL_LOG_DESCRIPTOR_WRITE);
+        asl_log_descriptor(c, msg, ASL_LEVEL_INFO, 2, ASL_LOG_DESCRIPTOR_WRITE);
+}
+
 void
-fixup_bundle_environment (int, char* [], string & localedir)
+fixup_bundle_environment (int argc, char* argv[], string & localedir)
 {
        if (!g_getenv ("ARDOUR_BUNDLED")) {
                return;
@@ -61,6 +81,8 @@ fixup_bundle_environment (int, char* [], string & localedir)
 
        set_language_preference ();
 
+        setup_logging ();
+
        char execpath[MAXPATHLEN+1];
        uint32_t pathsz = sizeof (execpath);