Index: lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/Makefile =================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/Makefile +++ lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/Makefile @@ -0,0 +1,5 @@ +LEVEL = ../../make + +CXX_SOURCES := main.cpp + +include $(LEVEL)/Makefile.rules Index: lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/TestVectorOfEnums.py =================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/TestVectorOfEnums.py +++ lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/TestVectorOfEnums.py @@ -0,0 +1,28 @@ +""" +Test Expression Parser regression test to ensure that we handle enums +correctly, in this case specifically std::vector of enums. +""" + + +import lldb +from lldbsuite.test.decorators import * +from lldbsuite.test.lldbtest import * +from lldbsuite.test import lldbutil + +class TestVectorOfEnums(TestBase): + + mydir = TestBase.compute_mydir(__file__) + + def test_vector_of_enums(self): + self.build() + + lldbutil.run_to_source_breakpoint(self, '// break here', + lldb.SBFileSpec("main.cpp", False)) + + self.expect("expr v", substrs=[ + 'size=3', + '[0] = a', + '[1] = b', + '[2] = c', + '}' + ]) Index: lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/main.cpp =================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/main.cpp +++ lldb/trunk/packages/Python/lldbsuite/test/expression_command/vector_of_enums/main.cpp @@ -0,0 +1,14 @@ +#include + +enum E { +a, +b, +c, +d +} ; + +int main() { + std::vector v = {E::a, E::b, E::c}; + + return v.size(); // break here +}