blob: b0c05f36b8004cd279068e266579c1b418bfb9cb (
plain)
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
|
// file : CCF/IDL2/Traversal/Interface.hpp
// author : Boris Kolpackov <boris@dre.vanderbilt.edu>
// cvs-id : $Id$
#ifndef CCF_IDL2_TRAVERSAL_INTERFACE_HPP
#define CCF_IDL2_TRAVERSAL_INTERFACE_HPP
#include "CCF/IDL2/Traversal/Elements.hpp"
#include "CCF/IDL2/SemanticGraph/Interface.hpp"
namespace CCF
{
namespace IDL2
{
namespace Traversal
{
struct Supports : Edge<SemanticGraph::Supports>
{
virtual void
traverse (Type& e)
{
node_traverser ().traverse (e.supportee ());
}
};
template <typename T>
struct InterfaceTemplate : ScopeTemplate<T>
{
/* GCC#13590/DR#39
using ScopeTemplate<T>::edge_traverser;
*/
virtual void
traverse (T&);
virtual void
pre (T&);
virtual void
name (T&);
virtual void
inherits (T&, EdgeDispatcherBase& d);
virtual void
inherits (T&);
virtual void
inherits_pre (T&);
virtual void
inherits_post (T&);
virtual void
inherits_none (T&);
virtual void
post (T&);
virtual void
comma (T&);
};
typedef
InterfaceTemplate<SemanticGraph::Interface>
Interface;
typedef
InterfaceTemplate<SemanticGraph::AbstractInterface>
AbstractInterface;
typedef
InterfaceTemplate<SemanticGraph::LocalInterface>
LocalInterface;
typedef
InterfaceTemplate<SemanticGraph::UnconstrainedInterface>
UnconstrainedInterface;
}
}
}
#include "CCF/IDL2/Traversal/Interface.tpp"
#endif // CCF_IDL2_TRAVERSAL_INTERFACE_HPP
|