[Lldb-commits] [lldb] r158693 - in /lldb/trunk: test/functionalities/single-quote-in-filename-to-lldb/ test/functionalities/single-quote-in-filename-to-lldb/Makefile test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py test/functionalities/single-quote-in-filename-to-lldb/main.c test/functionalities/single-quote-in-filename-to-lldb/path with '09/ tools/driver/Driver.cpp

Johnny Chen johnny.chen at apple.com
Mon Jun 18 17:56:55 PDT 2012


Author: johnny
Date: Mon Jun 18 19:56:55 2012
New Revision: 158693

URL: http://llvm.org/viewvc/llvm-project?rev=158693&view=rev
Log:
rdar://problem/11649610
lldb confused by single quote in executable path

Also add a test case.

Added:
    lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/
    lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/Makefile
    lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py
    lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/main.c
    lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/path with '09/
Modified:
    lldb/trunk/tools/driver/Driver.cpp

Added: lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/Makefile
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/Makefile?rev=158693&view=auto
==============================================================================
--- lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/Makefile (added)
+++ lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/Makefile Mon Jun 18 19:56:55 2012
@@ -0,0 +1,5 @@
+LEVEL = ../../make
+
+C_SOURCES := main.c
+
+include $(LEVEL)/Makefile.rules

Added: lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py?rev=158693&view=auto
==============================================================================
--- lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py (added)
+++ lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/TestSingleQuoteInFilename.py Mon Jun 18 19:56:55 2012
@@ -0,0 +1,70 @@
+"""
+Test the lldb command line takes a filename with single quote chars.
+"""
+
+import os
+import unittest2
+import lldb
+import pexpect
+from lldbtest import *
+
+class SingleQuoteInCommandLineTestCase(TestBase):
+
+    mydir = os.path.join("functionalities", "single-quote-in-filename-to-lldb")
+    myexe = "path with '09/a.out"
+
+    @classmethod
+    def classCleanup(cls):
+        """Cleanup the test byproducts."""
+        system(["/bin/sh", "-c", "rm -f child_send.txt"])
+        system(["/bin/sh", "-c", "rm -f child_read.txt"])
+        system(["/bin/sh", "-c", "rm -f \"%s\"" % cls.myexe])
+
+    def test_lldb_invocation_with_single_quote_in_filename(self):
+        """Test that 'lldb my_file_name' works where my_file_name is a string with a single quote char in it."""
+        self.buildDefault()
+        system(["/bin/sh", "-c", "cp a.out \"%s\"" % self.myexe])
+
+        # The default lldb prompt.
+        prompt = "(lldb) "
+
+        # So that the child gets torn down after the test.
+        self.child = pexpect.spawn('%s %s "%s"' % (self.lldbHere, self.lldbOption, self.myexe))
+        child = self.child
+        child.setecho(True)
+        # Turn on logging for input/output to/from the child.
+        with open('child_send.txt', 'w') as f_send:
+            with open('child_read.txt', 'w') as f_read:
+                child.logfile_send = f_send
+                child.logfile_read = f_read
+
+                child.expect_exact(prompt)
+
+                child.send("help watchpoint")
+                child.sendline('')
+                child.expect_exact(prompt)
+
+        # Now that the necessary logging is done, restore logfile to None to
+        # stop further logging.
+        child.logfile_send = None
+        child.logfile_read = None
+        
+        with open('child_send.txt', 'r') as fs:
+            if self.TraceOn():
+                print "\n\nContents of child_send.txt:"
+                print fs.read()
+        with open('child_read.txt', 'r') as fr:
+            from_child = fr.read()
+            if self.TraceOn():
+                print "\n\nContents of child_read.txt:"
+                print from_child
+
+            self.expect(from_child, exe=False,
+                substrs = ["Current executable set to"])
+
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()

Added: lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/main.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/main.c?rev=158693&view=auto
==============================================================================
--- lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/main.c (added)
+++ lldb/trunk/test/functionalities/single-quote-in-filename-to-lldb/main.c Mon Jun 18 19:56:55 2012
@@ -0,0 +1,7 @@
+#include <stdio.h>
+
+int main(int argc, const char *argv[])
+{
+    printf("Hello, world!\n");
+    return 0;
+}

Modified: lldb/trunk/tools/driver/Driver.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/tools/driver/Driver.cpp?rev=158693&r1=158692&r2=158693&view=diff
==============================================================================
--- lldb/trunk/tools/driver/Driver.cpp (original)
+++ lldb/trunk/tools/driver/Driver.cpp Mon Jun 18 19:56:55 2012
@@ -1317,13 +1317,13 @@
                 if (m_debugger.GetDefaultArchitecture (arch_name, sizeof (arch_name)))
                     ::snprintf (command_string, 
                                 sizeof (command_string), 
-                                "target create --arch=%s '%s'", 
+                                "target create --arch=%s \"%s\"", 
                                 arch_name,
                                 m_option_data.m_args[0].c_str());
                 else
                     ::snprintf (command_string, 
                                 sizeof(command_string), 
-                                "target create '%s'", 
+                                "target create \"%s\"", 
                                 m_option_data.m_args[0].c_str());
 
                 m_debugger.HandleCommand (command_string);





More information about the lldb-commits mailing list