Implement code generation
This commit is contained in:
parent
c44e0b512e
commit
d18070a799
29 changed files with 2522 additions and 280 deletions
|
|
@ -13,10 +13,22 @@ using namespace cppast;
|
|||
TEST_CASE("cpp_language_linkage")
|
||||
{
|
||||
auto code = R"(
|
||||
/// extern "C" enum a{
|
||||
/// };
|
||||
extern "C" enum a {};
|
||||
|
||||
enum b {};
|
||||
|
||||
/// extern "C++"{
|
||||
/// enum c{
|
||||
/// };
|
||||
///
|
||||
/// enum d{
|
||||
/// };
|
||||
///
|
||||
/// enum e{
|
||||
/// };
|
||||
/// }
|
||||
extern "C++" // yup
|
||||
{
|
||||
enum c {};
|
||||
|
|
@ -41,21 +53,23 @@ enum f {};
|
|||
REQUIRE(count == 2u);
|
||||
|
||||
// check enums for their correct parent
|
||||
count = test_visit<cpp_enum>(*file, [&](const cpp_enum& e) {
|
||||
if (e.name() == "a")
|
||||
check_parent(e, "\"C\"", "a");
|
||||
else if (e.name() == "b")
|
||||
check_parent(e, "cpp_language_linkage.cpp", "b");
|
||||
else if (e.name() == "c")
|
||||
check_parent(e, "\"C++\"", "c");
|
||||
else if (e.name() == "d")
|
||||
check_parent(e, "\"C++\"", "d");
|
||||
else if (e.name() == "e")
|
||||
check_parent(e, "\"C++\"", "e");
|
||||
else if (e.name() == "f")
|
||||
check_parent(e, "cpp_language_linkage.cpp", "f");
|
||||
else
|
||||
REQUIRE(false);
|
||||
});
|
||||
count = test_visit<cpp_enum>(*file,
|
||||
[&](const cpp_enum& e) {
|
||||
if (e.name() == "a")
|
||||
check_parent(e, "\"C\"", "a");
|
||||
else if (e.name() == "b")
|
||||
check_parent(e, "cpp_language_linkage.cpp", "b");
|
||||
else if (e.name() == "c")
|
||||
check_parent(e, "\"C++\"", "c");
|
||||
else if (e.name() == "d")
|
||||
check_parent(e, "\"C++\"", "d");
|
||||
else if (e.name() == "e")
|
||||
check_parent(e, "\"C++\"", "e");
|
||||
else if (e.name() == "f")
|
||||
check_parent(e, "cpp_language_linkage.cpp", "f");
|
||||
else
|
||||
REQUIRE(false);
|
||||
},
|
||||
false); // don't check code generation here
|
||||
REQUIRE(count == 6u);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue