mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-22 04:55:50 -04:00

This is the conclusion of an effort to get LLDB's Python code structured into a bona-fide Python package. This has a number of benefits, but most notably the ability to more easily share Python code between different but related pieces of LLDB's Python infrastructure (for example, `scripts` can now share code with `test`). llvm-svn: 251532
50 lines
1.7 KiB
Python
50 lines
1.7 KiB
Python
"""
|
|
Tests that rvalue references are supported in C++
|
|
"""
|
|
|
|
import lldb
|
|
from lldbtest import *
|
|
import lldbutil
|
|
|
|
class RvalueReferencesTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
#rdar://problem/11479676
|
|
@expectedFailureIcc("ICC (13.1, 14-beta) do not emit DW_TAG_rvalue_reference_type.")
|
|
@expectedFailureWindows("llvm.org/pr24489: Name lookup not working correctly on Windows")
|
|
def test_with_run_command(self):
|
|
"""Test that rvalues are supported in the C++ expression parser"""
|
|
self.build()
|
|
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
|
|
|
|
self.set_breakpoint(line_number('main.cpp', '// breakpoint 1'))
|
|
self.set_breakpoint(line_number('main.cpp', '// breakpoint 2'))
|
|
|
|
self.runCmd("process launch", RUN_SUCCEEDED)
|
|
|
|
# Note that clang as of r187480 doesn't emit DW_TAG_const_type, unlike gcc 4.8.1
|
|
# With gcc 4.8.1, lldb reports the type as (int &&const)
|
|
self.expect("frame variable i",
|
|
startstr = "(int &&",
|
|
substrs = ["i = 0x", "&i = 3"])
|
|
|
|
self.expect("expression -- i",
|
|
startstr = "(int) ",
|
|
substrs = ["3"])
|
|
|
|
self.expect("breakpoint delete 1")
|
|
|
|
self.runCmd("process continue")
|
|
|
|
self.expect("expression -- foo(2)")
|
|
|
|
self.expect("expression -- int &&j = 3; foo(j)",
|
|
error = True)
|
|
|
|
self.expect("expression -- int &&k = 6; k",
|
|
startstr = "(int) $1 = 6")
|
|
|
|
def set_breakpoint(self, line):
|
|
lldbutil.run_break_set_by_file_and_line (self, "main.cpp", line, num_expected_locations=1, loc_exact=True)
|