module-loading support for the expression parser. - It adds support for auto-loading modules referred to by a compile unit. These references are currently in the form of empty translation units. This functionality is gated by the setting target.auto-import-clang-modules (boolean) = false - It improves and corrects support for loading macros from modules, currently by textually pasting all #defines into the user's expression. The improvements center around including only those modules that are relevant to the current context - hand-loaded modules and the modules that are imported from the current compile unit. - It adds an "opt-in" mechanism for all of this functionality. Modules have to be explicitly imported (via @import) or auto-loaded (by enabling the above setting) to enable any of this functionality. It also adds support to the compile unit and symbol file code to deal with empty translation units that indicate module imports, and plumbs this through to the CompileUnit interface. Finally, it makes the following changes to the test suite: - It adds a testcase that verifies that modules are automatically loaded when the appropriate setting is enabled (lang/objc/modules-auto-import); and - It modifies lanb/objc/modules-incomplete to test the case where a module #undefs something that is #defined in another module. <rdar://problem/20299554> llvm-svn: 235313
89 lines
2.5 KiB
Python
89 lines
2.5 KiB
Python
"""Test that DWARF types are trusted over module types"""
|
|
|
|
import os, time
|
|
import unittest2
|
|
import lldb
|
|
import platform
|
|
import lldbutil
|
|
|
|
from distutils.version import StrictVersion
|
|
|
|
from lldbtest import *
|
|
|
|
class IncompleteModulesTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
@skipUnlessDarwin
|
|
@dsym_test
|
|
@unittest2.expectedFailure("rdar://20416388")
|
|
def test_expr_with_dsym(self):
|
|
self.buildDsym()
|
|
self.expr()
|
|
|
|
@dwarf_test
|
|
@skipIfFreeBSD
|
|
@skipIfLinux
|
|
@unittest2.expectedFailure("rdar://20416388")
|
|
def test_expr_with_dwarf(self):
|
|
self.buildDwarf()
|
|
self.expr()
|
|
|
|
def setUp(self):
|
|
# Call super's setUp().
|
|
TestBase.setUp(self)
|
|
# Find the line number to break inside main().
|
|
self.line = line_number('main.m', '// Set breakpoint 0 here.')
|
|
|
|
def applies(self):
|
|
if platform.system() != "Darwin":
|
|
return False
|
|
if StrictVersion('12.0.0') > platform.release():
|
|
return False
|
|
|
|
return True
|
|
|
|
def common_setup(self):
|
|
exe = os.path.join(os.getcwd(), "a.out")
|
|
self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
|
|
|
|
# Break inside the foo function which takes a bar_ptr argument.
|
|
lldbutil.run_break_set_by_file_and_line (self, "main.m", self.line, num_expected_locations=1, loc_exact=True)
|
|
|
|
self.runCmd("run", RUN_SUCCEEDED)
|
|
|
|
# The stop reason of the thread should be breakpoint.
|
|
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
|
|
substrs = ['stopped',
|
|
'stop reason = breakpoint'])
|
|
|
|
# The breakpoint should have a hit count of 1.
|
|
self.expect("breakpoint list -f", BREAKPOINT_HIT_ONCE,
|
|
substrs = [' resolved, hit count = 1'])
|
|
|
|
def expr(self):
|
|
if not self.applies():
|
|
return
|
|
|
|
self.common_setup()
|
|
|
|
self.runCmd("settings set target.clang-module-search-paths \"" + os.getcwd() + "\"")
|
|
|
|
self.expect("expr @import myModule; 3", VARIABLES_DISPLAYED_CORRECTLY,
|
|
substrs = ["int", "3"])
|
|
|
|
self.expect("expr [myObject privateMethod]", VARIABLES_DISPLAYED_CORRECTLY,
|
|
substrs = ["int", "5"])
|
|
|
|
self.expect("expr MIN(2,3)", "#defined macro was found",
|
|
substrs = ["int", "2"])
|
|
|
|
self.expect("expr MAX(2,3)", "#undefd macro was correcltly not found",
|
|
error=True)
|
|
|
|
if __name__ == '__main__':
|
|
import atexit
|
|
lldb.SBDebugger.Initialize()
|
|
atexit.register(lambda: lldb.SBDebugger.Terminate())
|
|
unittest2.main()
|