summaryrefslogtreecommitdiff
path: root/src/parsers/decl/var_decl.cpp
blob: 8ff0e44561af0009847ea05e9449776666316a0e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
 *  Copyright (C) 2015  Andrei Karas
 *
 *  This file is part of Paranoid null checker.
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 3 of the License, or
 *  any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#include "includes/parserincludes.h"

parserDefine(VarDecl);

#include "nodesmap.h"

#include "parsers/base/decl.h"

#include "nodes/decl/var_decl.h"

namespace Generic
{

void parseVarDeclNode(VarDeclNode *node)
{
    fillType(node);
    fillLocation(node);
    fillDeclLabel(node);

    Log::dump(node);

    setPrintField(node, DECL_THIS_STATIC, isStatic);
    setPrintField(node, DECL_REGISTER, isRegister);
    setPrintField(node, TREE_USED, isUsed);
    setPrintField(node, DECL_VIRTUAL_P, isVirtual);

    fillDeclAutoGenerated(node);

    if (isIn(node->gccNode, foundNodesMap))
    {
        VarDeclNode *const oldNode = static_cast<VarDeclNode*>(
            foundNodesMap[node->gccNode]);
        if (node->parseChilds <= 0)
        {
            updateNodesMap[node] = oldNode;
            return;
        }

        node->declSize = static_cast<IntegerCstNode*>(createParseNode(
            node,
            DECL_SIZE(node->gccNode),
            INTEGER_CST,
            "decl size 2",
            15));

        node->initial = createParseNode(
            node,
            DECL_INITIAL(node->gccNode),
            "initial 2",
            20);

        node->varType = static_cast<TypeNode*>(createParseNode(
            node,
            TREE_TYPE(node->gccNode),
            "var type 2",
            15));

        return;
    }
    else
    {
        foundNodesMap[node->gccNode] = node;
    }

    fillDeclAttributes(node);

    if (node->parseChilds <= 0)
        return;

    node->declSize = static_cast<IntegerCstNode*>(createParseNode(
        node,
        DECL_SIZE(node->gccNode),
        INTEGER_CST,
        "decl size"));

    // not loading because it reference self recursivly
    node->initial = createParseNode(
        node,
        DECL_INITIAL(node->gccNode),
        "initial",
        20);

    node->varType = static_cast<TypeNode*>(createParseNode(
        node,
        TREE_TYPE(node->gccNode),
        "var type"));

    node->complete = true;
}

void parseVarDeclNode(VarDeclNode *node1, VarDeclNode *node2)
{
    if (!node1 || !node2)
        return;

    node1->declSize = node2->declSize;
    node1->initial = node2->initial;
    node1->varType = node2->varType;
}

}