File: mark_nodes_visitor.cpp

package info (click to toggle)
foundry 0.0.20100226-1
  • links: PTS
  • area: main
  • in suites: squeeze, wheezy
  • size: 392 kB
  • ctags: 1,574
  • sloc: cpp: 4,191; yacc: 292; lex: 141; makefile: 123
file content (77 lines) | stat: -rw-r--r-- 1,441 bytes parent folder | download
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
#include "mark_nodes_visitor.hpp"

namespace foundry {
namespace tree {

void mark_nodes_visitor::visit(basic_type_node &n)
{
    std::map<std::string, smartpointer_provider>::iterator i = n.ns->node_types.find(n.name);
    if(i == n.ns->node_types.end())
        n.is_node = false;
    else
    {
        n.is_node = true;
        n.sp_prov = i->second;
    }
}

void mark_nodes_visitor::visit(reference_type_node &n)
{
    descend(n.type);
}

void mark_nodes_visitor::visit(pointer_type_node &n)
{
    descend(n.type);
}

void mark_nodes_visitor::visit(template_type_node &n)
{
    descend(n.template_args);
}

void mark_nodes_visitor::visit(list_type_node &n)
{
    descend(n.type);
}

void mark_nodes_visitor::visit(root &r)
{
    collecting = true;
    descend(r.global_namespace);
    collecting = false;
    descend(r.global_namespace);
}

void mark_nodes_visitor::visit(include_node&) { }
void mark_nodes_visitor::visit(namespace_node &n)
{
    descend(n.namespaces);
    descend(n.group);
}

void mark_nodes_visitor::visit(group_node &n)
{
    if(collecting)
        n.ns->node_types[n.name] = n.sp_prov;
    else
        descend(n.default_members);
    descend(n.groups);
    descend(n.nodes);
}

void mark_nodes_visitor::visit(node_node &n)
{
    if(collecting)
        n.ns->node_types[n.name] = n.sp_prov;
    else
        descend(n.members);
}

void mark_nodes_visitor::visit(data_member_node &n)
{
    descend(n.type);
}

}
}