forked from OSchip/llvm-project
[lldb] Explicitly test the template argument SB API
This commit is contained in:
parent
0ff4bc38ab
commit
82ed18601d
|
@ -0,0 +1,3 @@
|
||||||
|
CXX_SOURCES := main.cpp
|
||||||
|
|
||||||
|
include Makefile.rules
|
|
@ -0,0 +1,30 @@
|
||||||
|
import lldb
|
||||||
|
from lldbsuite.test.decorators import *
|
||||||
|
from lldbsuite.test.lldbtest import *
|
||||||
|
from lldbsuite.test import lldbutil
|
||||||
|
|
||||||
|
class TestCase(TestBase):
|
||||||
|
|
||||||
|
mydir = TestBase.compute_mydir(__file__)
|
||||||
|
|
||||||
|
@no_debug_info_test
|
||||||
|
def test(self):
|
||||||
|
self.build()
|
||||||
|
self.dbg.CreateTarget(self.getBuildArtifact("a.out"))
|
||||||
|
|
||||||
|
value = self.expect_expr("temp1", result_type="C<int, 2>")
|
||||||
|
template_type = value.GetType()
|
||||||
|
self.assertEqual(template_type.GetNumberOfTemplateArguments(), 2)
|
||||||
|
|
||||||
|
# Check a type argument.
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentKind(0), lldb.eTemplateArgumentKindType)
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentType(0).GetName(), "int")
|
||||||
|
|
||||||
|
# Check a integral argument.
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentKind(1), lldb.eTemplateArgumentKindIntegral)
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentType(1).GetName(), "unsigned int")
|
||||||
|
#FIXME: There is no way to get the actual value of the parameter.
|
||||||
|
|
||||||
|
# Try to get an invalid template argument.
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentKind(2), lldb.eTemplateArgumentKindNull)
|
||||||
|
self.assertEqual(template_type.GetTemplateArgumentType(2).GetName(), "")
|
|
@ -0,0 +1,8 @@
|
||||||
|
template<typename T, unsigned value>
|
||||||
|
struct C {
|
||||||
|
T member = value;
|
||||||
|
};
|
||||||
|
|
||||||
|
C<int, 2> temp1;
|
||||||
|
|
||||||
|
int main() {}
|
Loading…
Reference in New Issue