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
|
// file : xsd-frontend/semantic-graph/compositor.cxx
// copyright : Copyright (c) 2006-2014 Code Synthesis Tools CC
// license : GNU GPL v2 + exceptions; see accompanying LICENSE file
#include <cutl/compiler/type-info.hxx>
#include <xsd-frontend/semantic-graph/compositors.hxx>
namespace XSDFrontend
{
namespace SemanticGraph
{
// ContainsCompositor
//
ContainsCompositor::
ContainsCompositor (unsigned long min, unsigned long max)
: compositor_ (0), container_ (0), min_ (min), max_ (max)
{
}
// All
//
All::
All (Path const& file, unsigned long line, unsigned long column)
: Node (file, line, column)
{
}
// Choice
//
Choice::
Choice (Path const& file, unsigned long line, unsigned long column)
: Node (file, line, column)
{
}
// Sequence
//
Sequence::
Sequence (Path const& file, unsigned long line, unsigned long column)
: Node (file, line, column)
{
}
namespace
{
using compiler::type_info;
struct ContainsCompositorInit
{
ContainsCompositorInit ()
{
type_info ti (typeid (ContainsCompositor));
ti.add_base (typeid (Edge));
insert (ti);
}
} contains_compositor_init_;
struct CompositorInit
{
CompositorInit ()
{
type_info ti (typeid (Compositor));
ti.add_base (typeid (Particle));
insert (ti);
}
} compositor_init_;
struct AllInit
{
AllInit ()
{
type_info ti (typeid (All));
ti.add_base (typeid (Compositor));
insert (ti);
}
} all_init_;
struct ChoiceInit
{
ChoiceInit ()
{
type_info ti (typeid (Choice));
ti.add_base (typeid (Compositor));
insert (ti);
}
} choice_init_;
struct SequenceInit
{
SequenceInit ()
{
type_info ti (typeid (Sequence));
ti.add_base (typeid (Compositor));
insert (ti);
}
} sequence_init_;
}
}
}
|