1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
| """
Tests that rvalue references are supported in C++
"""
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class RvalueReferencesTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
# rdar://problem/11479676
@expectedFailureAll(
compiler="icc",
bugnumber="ICC (13.1, 14-beta) do not emit DW_TAG_rvalue_reference_type.")
def test_with_run_command(self):
"""Test that rvalues are supported in the C++ expression parser"""
self.build()
self.runCmd("file " + self.getBuildArtifact("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)
|