[Lldb-commits] [lldb] r228658 - Add a "launch with globber" mode that lets you launch a process after having globbed the command line arguments via argdumper instead of routing via /bin/sh
    Enrico Granata 
    egranata at apple.com
       
    Mon Feb  9 19:06:25 PST 2015
    
    
  
Author: enrico
Date: Mon Feb  9 21:06:24 2015
New Revision: 228658
URL: http://llvm.org/viewvc/llvm-project?rev=228658&view=rev
Log:
Add a "launch with globber" mode that lets you launch a process after having globbed the command line arguments via argdumper instead of routing via /bin/sh
Modified:
    lldb/trunk/include/lldb/Target/ProcessLaunchInfo.h
    lldb/trunk/include/lldb/lldb-enumerations.h
    lldb/trunk/source/Target/Platform.cpp
    lldb/trunk/source/Target/Process.cpp
    lldb/trunk/source/Target/ProcessLaunchInfo.cpp
Modified: lldb/trunk/include/lldb/Target/ProcessLaunchInfo.h
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Target/ProcessLaunchInfo.h?rev=228658&r1=228657&r2=228658&view=diff
==============================================================================
--- lldb/trunk/include/lldb/Target/ProcessLaunchInfo.h (original)
+++ lldb/trunk/include/lldb/Target/ProcessLaunchInfo.h Mon Feb  9 21:06:24 2015
@@ -132,6 +132,15 @@ namespace lldb_private
 
         void
         SetLaunchInSeparateProcessGroup (bool separate);
+        
+        bool
+        GetGlobArguments () const
+        {
+            return m_flags.Test(lldb::eLaunchFlagGlobArguments);
+        }
+        
+        void
+        SetGlobArguments (bool glob);
 
         void
         Clear ();
Modified: lldb/trunk/include/lldb/lldb-enumerations.h
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/lldb-enumerations.h?rev=228658&r1=228657&r2=228658&view=diff
==============================================================================
--- lldb/trunk/include/lldb/lldb-enumerations.h (original)
+++ lldb/trunk/include/lldb/lldb-enumerations.h Mon Feb  9 21:06:24 2015
@@ -49,8 +49,9 @@ namespace lldb {
         eLaunchFlagLaunchInSeparateProcessGroup = (1u << 7), ///< Launch the process in a separate process group
         eLaunchFlagDontSetExitStatus = (1u << 8), ///< If you are going to hand the process off (e.g. to debugserver)
                                                    ///< set this flag so lldb & the handee don't race to set its exit status.
-        eLaunchFlagDetachOnError = (1u << 9)      ///< If set, then the client stub should detach rather than killing the debugee
+        eLaunchFlagDetachOnError = (1u << 9),     ///< If set, then the client stub should detach rather than killing the debugee
                                                    ///< if it loses connection with lldb.
+        eLaunchFlagGlobArguments  = (1u << 10),       ///< Glob arguments without going through a shell
     } LaunchFlags;
         
     //----------------------------------------------------------------------
Modified: lldb/trunk/source/Target/Platform.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Target/Platform.cpp?rev=228658&r1=228657&r2=228658&view=diff
==============================================================================
--- lldb/trunk/source/Target/Platform.cpp (original)
+++ lldb/trunk/source/Target/Platform.cpp Mon Feb  9 21:06:24 2015
@@ -18,6 +18,7 @@
 #include "lldb/Core/Log.h"
 #include "lldb/Core/ModuleSpec.h"
 #include "lldb/Core/PluginManager.h"
+#include "lldb/Core/StructuredData.h"
 #include "lldb/Host/FileSpec.h"
 #include "lldb/Host/FileSystem.h"
 #include "lldb/Host/Host.h"
@@ -1092,6 +1093,84 @@ Platform::LaunchProcess (ProcessLaunchIn
                                                                   num_resumes))
                 return error;
         }
+        else if (launch_info.GetFlags().Test(eLaunchFlagGlobArguments))
+        {
+            FileSpec glob_tool_spec;
+            if (!HostInfo::GetLLDBPath(lldb::ePathTypeSupportExecutableDir, glob_tool_spec))
+            {
+                error.SetErrorString("could not find argdumper tool");
+                return error;
+            }
+            glob_tool_spec.AppendPathComponent("argdumper");
+            if (!glob_tool_spec.Exists())
+            {
+                error.SetErrorString("could not find argdumper tool");
+                return error;
+            }
+
+            std::string quoted_cmd_string;
+            launch_info.GetArguments().GetQuotedCommandString(quoted_cmd_string);
+            
+            StreamString glob_command;
+            
+            glob_command.Printf("%s %s",
+                                glob_tool_spec.GetPath().c_str(),
+                                quoted_cmd_string.c_str());
+            
+            int status;
+            std::string output;
+            RunShellCommand(glob_command.GetData(), launch_info.GetWorkingDirectory(), &status, nullptr, &output, 10);
+            
+            if (status != 0)
+            {
+                error.SetErrorStringWithFormat("argdumper exited with error %d", status);
+                return error;
+            }
+            
+            auto data_sp = StructuredData::ParseJSON(output);
+            if (!data_sp)
+            {
+                error.SetErrorString("invalid JSON");
+                return error;
+            }
+            
+            auto dict_sp = data_sp->GetAsDictionary();
+            if (!data_sp)
+            {
+                error.SetErrorString("invalid JSON");
+                return error;
+            }
+
+            auto args_sp = dict_sp->GetObjectForDotSeparatedPath("arguments");
+            if (!args_sp)
+            {
+                error.SetErrorString("invalid JSON");
+                return error;
+            }
+            
+            auto args_array_sp = args_sp->GetAsArray();
+            if (!args_array_sp)
+            {
+                error.SetErrorString("invalid JSON");
+                return error;
+            }
+            
+            launch_info.GetArguments().Clear();
+            
+            for (size_t i = 0;
+                 i < args_array_sp->GetSize();
+                 i++)
+            {
+                auto item_sp = args_array_sp->GetItemAtIndex(i);
+                if (!item_sp)
+                    continue;
+                auto str_sp = item_sp->GetAsString();
+                if (!str_sp)
+                    continue;
+                
+                launch_info.GetArguments().AppendArgument(str_sp->GetValue().c_str());
+            }
+        }
 
         if (log)
             log->Printf ("Platform::%s final launch_info resume count: %" PRIu32, __FUNCTION__, launch_info.GetResumeCount ());
Modified: lldb/trunk/source/Target/Process.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Target/Process.cpp?rev=228658&r1=228657&r2=228658&view=diff
==============================================================================
--- lldb/trunk/source/Target/Process.cpp (original)
+++ lldb/trunk/source/Target/Process.cpp Mon Feb  9 21:06:24 2015
@@ -491,6 +491,17 @@ ProcessLaunchCommandOptions::SetOptionVa
             break;
         }
 
+        case 'G':   // Glob args.
+        {
+            bool success;
+            const bool glob_args = Args::StringToBoolean (option_arg, true, &success);
+            if (success)
+                launch_info.SetGlobArguments(glob_args);
+            else
+                error.SetErrorStringWithFormat ("Invalid boolean value for glob-args option: '%s'", option_arg ? option_arg : "<null>");
+            break;
+        }
+            
         case 'c':
             if (option_arg && option_arg[0])
                 launch_info.SetShell (FileSpec(option_arg, false));
@@ -518,7 +529,7 @@ ProcessLaunchCommandOptions::g_option_ta
 { LLDB_OPT_SET_ALL, false, "working-dir",   'w', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeDirectoryName,          "Set the current working directory to <path> when running the inferior."},
 { LLDB_OPT_SET_ALL, false, "arch",          'a', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeArchitecture,  "Set the architecture for the process to launch when ambiguous."},
 { LLDB_OPT_SET_ALL, false, "environment",   'v', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeNone,          "Specify an environment variable name/value string (--environment NAME=VALUE). Can be specified multiple times for subsequent environment entries."},
-{ LLDB_OPT_SET_ALL, false, "shell",         'c', OptionParser::eOptionalArgument, NULL, NULL, 0, eArgTypeFilename,          "Run the process in a shell (not supported on all platforms)."},
+{ LLDB_OPT_SET_1|LLDB_OPT_SET_2|LLDB_OPT_SET_3, false, "shell",         'c', OptionParser::eOptionalArgument, NULL, NULL, 0, eArgTypeFilename,          "Run the process in a shell (not supported on all platforms)."},
 
 { LLDB_OPT_SET_1  , false, "stdin",         'i', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeFilename,    "Redirect stdin for the process to <filename>."},
 { LLDB_OPT_SET_1  , false, "stdout",        'o', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeFilename,    "Redirect stdout for the process to <filename>."},
@@ -527,7 +538,7 @@ ProcessLaunchCommandOptions::g_option_ta
 { LLDB_OPT_SET_2  , false, "tty",           't', OptionParser::eNoArgument,       NULL, NULL, 0, eArgTypeNone,    "Start the process in a terminal (not supported on all platforms)."},
 
 { LLDB_OPT_SET_3  , false, "no-stdio",      'n', OptionParser::eNoArgument,       NULL, NULL, 0, eArgTypeNone,    "Do not set up for terminal I/O to go to running process."},
-
+{ LLDB_OPT_SET_4,   false, "glob-args",       'G', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeBoolean,          "Set whether to glob arguments to the process when launching."},
 { 0               , false, NULL,             0,  0,                 NULL, NULL, 0, eArgTypeNone,    NULL }
 };
 
Modified: lldb/trunk/source/Target/ProcessLaunchInfo.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Target/ProcessLaunchInfo.cpp?rev=228658&r1=228657&r2=228658&view=diff
==============================================================================
--- lldb/trunk/source/Target/ProcessLaunchInfo.cpp (original)
+++ lldb/trunk/source/Target/ProcessLaunchInfo.cpp Mon Feb  9 21:06:24 2015
@@ -208,7 +208,15 @@ ProcessLaunchInfo::SetLaunchInSeparatePr
         m_flags.Set(lldb::eLaunchFlagLaunchInSeparateProcessGroup);
     else
         m_flags.Clear (lldb::eLaunchFlagLaunchInSeparateProcessGroup);
+}
 
+void
+ProcessLaunchInfo::SetGlobArguments (bool glob)
+{
+    if (glob)
+        m_flags.Set(lldb::eLaunchFlagGlobArguments);
+    else
+        m_flags.Clear(lldb::eLaunchFlagGlobArguments);
 }
 
 void
    
    
More information about the lldb-commits
mailing list