Clang import: handle DefaultStmt
This commit is contained in:
parent
40156365b8
commit
16f4f198eb
|
@ -63,6 +63,7 @@ static const std::string CXXThisExpr = "CXXThisExpr";
|
||||||
static const std::string CXXThrowExpr = "CXXThrowExpr";
|
static const std::string CXXThrowExpr = "CXXThrowExpr";
|
||||||
static const std::string DeclRefExpr = "DeclRefExpr";
|
static const std::string DeclRefExpr = "DeclRefExpr";
|
||||||
static const std::string DeclStmt = "DeclStmt";
|
static const std::string DeclStmt = "DeclStmt";
|
||||||
|
static const std::string DefaultStmt = "DefaultStmt";
|
||||||
static const std::string DoStmt = "DoStmt";
|
static const std::string DoStmt = "DoStmt";
|
||||||
static const std::string EnumConstantDecl = "EnumConstantDecl";
|
static const std::string EnumConstantDecl = "EnumConstantDecl";
|
||||||
static const std::string EnumDecl = "EnumDecl";
|
static const std::string EnumDecl = "EnumDecl";
|
||||||
|
@ -747,6 +748,12 @@ Token *clangimport::AstNode::createTokens(TokenList *tokenList)
|
||||||
}
|
}
|
||||||
if (nodeType == DeclStmt)
|
if (nodeType == DeclStmt)
|
||||||
return children[0]->createTokens(tokenList);
|
return children[0]->createTokens(tokenList);
|
||||||
|
if (nodeType == DefaultStmt) {
|
||||||
|
addtoken(tokenList, "default");
|
||||||
|
addtoken(tokenList, ":");
|
||||||
|
children.back()->createTokens(tokenList);
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
if (nodeType == DoStmt) {
|
if (nodeType == DoStmt) {
|
||||||
addtoken(tokenList, "do");
|
addtoken(tokenList, "do");
|
||||||
createScope(tokenList, Scope::ScopeType::eDo, children[0], tokenList->back());
|
createScope(tokenList, Scope::ScopeType::eDo, children[0], tokenList->back());
|
||||||
|
|
|
@ -63,6 +63,7 @@ private:
|
||||||
TEST_CASE(cxxStaticCastExpr2);
|
TEST_CASE(cxxStaticCastExpr2);
|
||||||
TEST_CASE(cxxStdInitializerListExpr);
|
TEST_CASE(cxxStdInitializerListExpr);
|
||||||
TEST_CASE(cxxThrowExpr);
|
TEST_CASE(cxxThrowExpr);
|
||||||
|
TEST_CASE(defaultStmt);
|
||||||
TEST_CASE(doStmt);
|
TEST_CASE(doStmt);
|
||||||
TEST_CASE(enumDecl);
|
TEST_CASE(enumDecl);
|
||||||
TEST_CASE(forStmt);
|
TEST_CASE(forStmt);
|
||||||
|
@ -577,6 +578,20 @@ private:
|
||||||
ASSERT_EQUALS("void foo ( ) { throw 1 ; }", parse(clang));
|
ASSERT_EQUALS("void foo ( ) { throw 1 ; }", parse(clang));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void defaultStmt() {
|
||||||
|
const char clang[] = "`-FunctionDecl 0x18476b8 <1.c:3:1, line:9:1> line:3:5 foo 'int (int)'\n"
|
||||||
|
" |-ParmVarDecl 0x18475e0 <col:9, col:13> col:13 used rc 'int'\n"
|
||||||
|
" `-CompoundStmt 0x1847868 <line:4:1, line:9:1>\n"
|
||||||
|
" `-SwitchStmt 0x18477e0 <line:5:3, line:8:3>\n"
|
||||||
|
" |-ImplicitCastExpr 0x18477c8 <line:5:10> 'int' <LValueToRValue>\n"
|
||||||
|
" | `-DeclRefExpr 0x18477a8 <col:10> 'int' lvalue ParmVar 0x18475e0 'rc' 'int'\n"
|
||||||
|
" `-CompoundStmt 0x1847850 <col:14, line:8:3>\n"
|
||||||
|
" `-DefaultStmt 0x1847830 <line:6:3, line:7:12>\n"
|
||||||
|
" `-ReturnStmt 0x1847820 <col:5, col:12>\n"
|
||||||
|
" `-IntegerLiteral 0x1847800 <col:12> 'int' 1";
|
||||||
|
ASSERT_EQUALS("int foo ( int rc@1 ) {\n\nswitch ( rc@1 ) {\ndefault : return 1 ; } }", parse(clang));
|
||||||
|
}
|
||||||
|
|
||||||
void doStmt() {
|
void doStmt() {
|
||||||
const char clang[] = "`-FunctionDecl 0x27fbbc8 <line:2:1, col:34> col:6 foo 'void ()'\n"
|
const char clang[] = "`-FunctionDecl 0x27fbbc8 <line:2:1, col:34> col:6 foo 'void ()'\n"
|
||||||
" `-CompoundStmt 0x27fbd08 <col:12, col:34>\n"
|
" `-CompoundStmt 0x27fbd08 <col:12, col:34>\n"
|
||||||
|
|
Loading…
Reference in New Issue