[Lldb-commits] [lldb] r201103 - <rdar://problem/15996848>

Han Ming Ong hanming at apple.com
Mon Feb 10 11:23:28 PST 2014


Author: hanming
Date: Mon Feb 10 13:23:28 2014
New Revision: 201103

URL: http://llvm.org/viewvc/llvm-project?rev=201103&view=rev
Log:
<rdar://problem/15996848>

Made sure we pass along the file action paths for stdin/stdout/stderr to the XPC service.
[Reviewed by Greg Clayton]

Modified:
    lldb/trunk/source/Host/macosx/Host.mm
    lldb/trunk/source/Host/macosx/launcherXPCService/LauncherXPCService.h
    lldb/trunk/source/Host/macosx/launcherXPCService/main.mm

Modified: lldb/trunk/source/Host/macosx/Host.mm
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/Host.mm?rev=201103&r1=201102&r2=201103&view=diff
==============================================================================
--- lldb/trunk/source/Host/macosx/Host.mm (original)
+++ lldb/trunk/source/Host/macosx/Host.mm Mon Feb 10 13:23:28 2014
@@ -1499,6 +1499,21 @@ LaunchProcessXPC (const char *exe_path,
     // Posix spawn stuff.
     xpc_dictionary_set_int64(message, LauncherXPCServiceCPUTypeKey, launch_info.GetArchitecture().GetMachOCPUType());
     xpc_dictionary_set_int64(message, LauncherXPCServicePosixspawnFlagsKey, Host::GetPosixspawnFlags(launch_info));
+    const ProcessLaunchInfo::FileAction *file_action = launch_info.GetFileActionForFD(STDIN_FILENO);
+    if (file_action && file_action->GetPath())
+    {
+        xpc_dictionary_set_string(message, LauncherXPCServiceStdInPathKeyKey, file_action->GetPath());
+    }
+    file_action = launch_info.GetFileActionForFD(STDOUT_FILENO);
+    if (file_action && file_action->GetPath())
+    {
+        xpc_dictionary_set_string(message, LauncherXPCServiceStdOutPathKeyKey, file_action->GetPath());
+    }
+    file_action = launch_info.GetFileActionForFD(STDERR_FILENO);
+    if (file_action && file_action->GetPath())
+    {
+        xpc_dictionary_set_string(message, LauncherXPCServiceStdErrPathKeyKey, file_action->GetPath());
+    }
     
     xpc_object_t reply = xpc_connection_send_message_with_reply_sync(conn, message);
     xpc_type_t returnType = xpc_get_type(reply);

Modified: lldb/trunk/source/Host/macosx/launcherXPCService/LauncherXPCService.h
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/launcherXPCService/LauncherXPCService.h?rev=201103&r1=201102&r2=201103&view=diff
==============================================================================
--- lldb/trunk/source/Host/macosx/launcherXPCService/LauncherXPCService.h (original)
+++ lldb/trunk/source/Host/macosx/launcherXPCService/LauncherXPCService.h Mon Feb 10 13:23:28 2014
@@ -9,6 +9,9 @@
 #define LauncherXPCServiceEnvPrefxKey           "env"
 #define LauncherXPCServiceCPUTypeKey            "cpuType"
 #define LauncherXPCServicePosixspawnFlagsKey    "posixspawnFlags"
+#define LauncherXPCServiceStdInPathKeyKey       "stdInPath"
+#define LauncherXPCServiceStdOutPathKeyKey      "stdOutPath"
+#define LauncherXPCServiceStdErrPathKeyKey      "stdErrPath"
 #define LauncherXPCServiceChildPIDKey           "childPID"
 #define LauncherXPCServiceErrorTypeKey          "errorType"
 #define LauncherXPCServiceCodeTypeKey           "errorCode"

Modified: lldb/trunk/source/Host/macosx/launcherXPCService/main.mm
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/launcherXPCService/main.mm?rev=201103&r1=201102&r2=201103&view=diff
==============================================================================
--- lldb/trunk/source/Host/macosx/launcherXPCService/main.mm (original)
+++ lldb/trunk/source/Host/macosx/launcherXPCService/main.mm Mon Feb 10 13:23:28 2014
@@ -52,17 +52,44 @@ int _setup_posixspawn_attributes_file_ac
     if (errorCode)
         return errorCode;
     
-    // Setup any file actions. Here we are emulating what debugserver would do normally in Host.mm since the XPC service meant only for debugserver.
+    // Setup any file actions.
     errorCode = posix_spawn_file_actions_init(file_actions);
     if (errorCode)
         return errorCode;
-    errorCode = posix_spawn_file_actions_addclose(file_actions, STDIN_FILENO);
+    
+    const char *path = xpc_dictionary_get_string(message, LauncherXPCServiceStdInPathKeyKey);
+    if (path)
+    {
+        errorCode = posix_spawn_file_actions_addopen(file_actions, STDIN_FILENO, path, O_NOCTTY | O_RDONLY, 0);
+    }
+    else
+    {
+        errorCode = posix_spawn_file_actions_addclose(file_actions, STDIN_FILENO);
+    }
     if (errorCode)
         return errorCode;
-    errorCode = posix_spawn_file_actions_addclose(file_actions, STDOUT_FILENO);
+    
+    path = xpc_dictionary_get_string(message, LauncherXPCServiceStdOutPathKeyKey);
+    if (path)
+    {
+        errorCode = posix_spawn_file_actions_addopen(file_actions, STDOUT_FILENO, path, O_NOCTTY | O_CREAT | O_WRONLY, 0640);
+    }
+    else
+    {
+        errorCode = posix_spawn_file_actions_addclose(file_actions, STDOUT_FILENO);
+    }
     if (errorCode)
         return errorCode;
-    errorCode = posix_spawn_file_actions_addclose(file_actions, STDERR_FILENO);
+    
+    path = xpc_dictionary_get_string(message, LauncherXPCServiceStdErrPathKeyKey);
+    if (path)
+    {
+        errorCode = posix_spawn_file_actions_addopen(file_actions, STDERR_FILENO, path, O_NOCTTY | O_CREAT | O_RDWR, 0640);
+    }
+    else
+    {
+        errorCode = posix_spawn_file_actions_addclose(file_actions, STDERR_FILENO);
+    }
     
     return errorCode;
 }





More information about the lldb-commits mailing list