Clang import; Arrays

This commit is contained in:
Daniel Marjamäki 2020-01-07 12:19:06 +01:00
parent 7024d29a9d
commit b829c4cebb
5 changed files with 66 additions and 2 deletions

View File

@ -24,6 +24,7 @@
#include <vector> #include <vector>
#include <iostream> #include <iostream>
static const std::string ArraySubscriptExpr = "ArraySubscriptExpr";
static const std::string BinaryOperator = "BinaryOperator"; static const std::string BinaryOperator = "BinaryOperator";
static const std::string CallExpr = "CallExpr"; static const std::string CallExpr = "CallExpr";
static const std::string CompoundStmt = "CompoundStmt"; static const std::string CompoundStmt = "CompoundStmt";
@ -246,6 +247,16 @@ Scope *clangastdump::AstNode::createScope(TokenList *tokenList, Scope::ScopeType
Token *clangastdump::AstNode::createTokens(TokenList *tokenList) Token *clangastdump::AstNode::createTokens(TokenList *tokenList)
{ {
if (nodeType == ArraySubscriptExpr) {
Token *array = children[0]->createTokens(tokenList);
Token *bracket1 = addtoken(tokenList, "[");
Token *index = children[1]->createTokens(tokenList);
Token *bracket2 = addtoken(tokenList, "]");
bracket1->astOperand1(array);
bracket1->astOperand2(index);
bracket1->link(bracket2);
return bracket1;
}
if (nodeType == BinaryOperator) { if (nodeType == BinaryOperator) {
Token *tok1 = children[0]->createTokens(tokenList); Token *tok1 = children[0]->createTokens(tokenList);
Token *binop = addtoken(tokenList, unquote(mExtTokens.back())); Token *binop = addtoken(tokenList, unquote(mExtTokens.back()));
@ -367,7 +378,7 @@ Token *clangastdump::AstNode::createTokens(TokenList *tokenList)
Token *vartok1 = addtoken(tokenList, name); Token *vartok1 = addtoken(tokenList, name);
Scope *scope = const_cast<Scope *>(tokenList->back()->scope()); Scope *scope = const_cast<Scope *>(tokenList->back()->scope());
const AccessControl accessControl = (scope->type == Scope::ScopeType::eGlobal) ? (AccessControl::Global) : (AccessControl::Local); const AccessControl accessControl = (scope->type == Scope::ScopeType::eGlobal) ? (AccessControl::Global) : (AccessControl::Local);
scope->varlist.push_back(Variable(vartok1, nullptr, nullptr, 0, accessControl, nullptr, scope, nullptr)); scope->varlist.push_back(Variable(vartok1, type, 0, accessControl, nullptr, scope));
mData->varDecl(addr, vartok1, &scope->varlist.back()); mData->varDecl(addr, vartok1, &scope->varlist.back());
addtoken(tokenList, ";"); addtoken(tokenList, ";");
if (isInit) { if (isInit) {

View File

@ -25,7 +25,6 @@
#include <string> #include <string>
#include <vector> #include <vector>
class SymbolDatabase;
class Tokenizer; class Tokenizer;
namespace clangastdump { namespace clangastdump {

View File

@ -1723,6 +1723,36 @@ void SymbolDatabase::clangSetVariables(const std::vector<const Variable *> &vari
mVariableList = variableList; mVariableList = variableList;
} }
Variable::Variable(const Token *name_, const std::string &clangType,
nonneg int index_, AccessControl access_, const Type *type_,
const Scope *scope_)
: mNameToken(name_),
mTypeStartToken(nullptr),
mTypeEndToken(nullptr),
mIndex(index_),
mAccess(access_),
mFlags(0),
mType(type_),
mScope(scope_),
mValueType(nullptr)
{
std::string::size_type pos = clangType.find("[");
if (pos != std::string::npos) {
setFlag(fIsArray, true);
do {
const std::string::size_type pos1 = pos+1;
pos = clangType.find("]", pos1);
Dimension dim;
dim.tok = nullptr;
dim.known = true;
dim.num = MathLib::toLongNumber(clangType.substr(pos1, pos-pos1));
mDimensions.push_back(dim);
++pos;
} while (pos < clangType.size() && clangType[pos] == '[');
}
}
Variable::~Variable() Variable::~Variable()
{ {
delete mValueType; delete mValueType;

View File

@ -235,6 +235,10 @@ public:
evaluate(settings); evaluate(settings);
} }
Variable(const Token *name_, const std::string &clangType,
nonneg int index_, AccessControl access_, const Type *type_,
const Scope *scope_);
~Variable(); ~Variable();
/** /**

View File

@ -32,6 +32,7 @@ private:
TEST_CASE(funcdecl1); TEST_CASE(funcdecl1);
TEST_CASE(funcdecl2); TEST_CASE(funcdecl2);
TEST_CASE(vardecl1); TEST_CASE(vardecl1);
TEST_CASE(vardecl2);
} }
std::string parse(const char clang[]) { std::string parse(const char clang[]) {
@ -76,6 +77,25 @@ private:
"int b@2 ; b@2 = a@1 ;", "int b@2 ; b@2 = a@1 ;",
parse(clang)); parse(clang));
} }
void vardecl2() {
const char clang[] = "|-VarDecl 0x3873b50 <1.c:1:1, col:9> col:5 used a 'int [10]'\n"
"`-FunctionDecl 0x3873c38 <line:3:1, line:6:1> line:3:6 foo 'void ()'\n"
" `-CompoundStmt 0x3873dd0 <line:4:1, line:6:1>\n"
" `-BinaryOperator 0x3873da8 <line:5:3, col:10> 'int' '='\n"
" |-ArraySubscriptExpr 0x3873d60 <col:3, col:6> 'int' lvalue\n"
" | |-ImplicitCastExpr 0x3873d48 <col:3> 'int *' <ArrayToPointerDecay>\n"
" | | `-DeclRefExpr 0x3873cd8 <col:3> 'int [10]' lvalue Var 0x3873b50 'a' 'int [10]'\n"
" | `-IntegerLiteral 0x3873d00 <col:5> 'int' 0\n"
" `-IntegerLiteral 0x3873d88 <col:10> 'int' 0\n";
ASSERT_EQUALS("int[10] a@1 ;\n"
"\n"
"void foo ( ) {\n"
"\n"
"a@1 [ 0 ] = 0 ; }",
parse(clang));
}
}; };
REGISTER_TEST(TestClangAstDump) REGISTER_TEST(TestClangAstDump)