[Lldb-commits] [PATCH] D64995: [lldb] Fix crash when tab-completing in multi-line expr
Raphael Isemann via Phabricator via lldb-commits
lldb-commits at lists.llvm.org
Mon Jul 29 07:37:25 PDT 2019
teemperor updated this revision to Diff 212163.
teemperor added a comment.
- Added test.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64995/new/
https://reviews.llvm.org/D64995
Files:
lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/Makefile
lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/TestMultilineCompletion.py
lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/main.c
lldb/source/Core/IOHandler.cpp
Index: lldb/source/Core/IOHandler.cpp
===================================================================
--- lldb/source/Core/IOHandler.cpp
+++ lldb/source/Core/IOHandler.cpp
@@ -233,7 +233,7 @@
matches, descriptions);
case Completion::Expression: {
CompletionResult result;
- CompletionRequest request(current_line, current_line - cursor,
+ CompletionRequest request(current_line, cursor - current_line,
skip_first_n_matches, max_matches, result);
CommandCompletions::InvokeCommonCompletionCallbacks(
io_handler.GetDebugger().GetCommandInterpreter(),
Index: lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/main.c
===================================================================
--- /dev/null
+++ lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/main.c
@@ -0,0 +1,5 @@
+int main(int argc, char **argv) {
+ lldb_enable_attach();
+ int to_complete = 0;
+ return to_complete;
+}
Index: lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/TestMultilineCompletion.py
===================================================================
--- /dev/null
+++ lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/TestMultilineCompletion.py
@@ -0,0 +1,51 @@
+"""
+Test completion for multiline expressions.
+"""
+
+import lldb
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+
+class MultilineCompletionTest(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ def setUp(self):
+ TestBase.setUp(self)
+ self.source = 'main.c'
+
+ def expect_string(self, string):
+ import pexpect
+ """This expects for "string", with timeout & EOF being test fails."""
+ try:
+ self.child.expect_exact(string)
+ except pexpect.EOF:
+ self.fail("Got EOF waiting for '%s'" % (string))
+ except pexpect.TIMEOUT:
+ self.fail("Timed out waiting for '%s'" % (string))
+
+ @expectedFailureAll(
+ oslist=["windows"],
+ bugnumber="llvm.org/pr22274: need a pexpect replacement for windows")
+ def test_basic_completion(self):
+ """Test that we can complete a simple multiline expression"""
+ self.build()
+ self.setTearDownCleanup()
+
+ import pexpect
+ exe = self.getBuildArtifact("a.out")
+ prompt = "(lldb) "
+
+ run_commands = ' -o "b main" -o "r"'
+ self.child = pexpect.spawn(
+ '%s %s %s %s' %
+ (lldbtest_config.lldbExec, self.lldbOption, run_commands, exe))
+ child = self.child
+
+ self.expect_string(prompt)
+ self.child.sendline("expr")
+ self.expect_string("terminate with an empty line to evaluate")
+ self.child.send("to_\t")
+ self.expect_string("to_complete")
+
+ self.deletePexpectChild()
Index: lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/Makefile
===================================================================
--- /dev/null
+++ lldb/packages/Python/lldbsuite/test/expression_command/multiline-completion/Makefile
@@ -0,0 +1,3 @@
+LEVEL = ../../make
+C_SOURCES := main.c
+include $(LEVEL)/Makefile.rules
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D64995.212163.patch
Type: text/x-patch
Size: 3274 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20190729/5d3a4c13/attachment.bin>
More information about the lldb-commits
mailing list