Chris@16
|
1 // Boost.Geometry Index
|
Chris@16
|
2 //
|
Chris@16
|
3 // R-tree ostreaming visitor implementation
|
Chris@16
|
4 //
|
Chris@16
|
5 // Copyright (c) 2011-2013 Adam Wulkiewicz, Lodz, Poland.
|
Chris@16
|
6 //
|
Chris@16
|
7 // Use, modification and distribution is subject to the Boost Software License,
|
Chris@16
|
8 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
9 // http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
10
|
Chris@16
|
11 #ifndef BOOST_GEOMETRY_INDEX_DETAIL_RTREE_UTILITIES_PRINT_HPP
|
Chris@16
|
12 #define BOOST_GEOMETRY_INDEX_DETAIL_RTREE_UTILITIES_PRINT_HPP
|
Chris@16
|
13
|
Chris@16
|
14 #include <iostream>
|
Chris@16
|
15
|
Chris@16
|
16 namespace boost { namespace geometry { namespace index { namespace detail {
|
Chris@16
|
17
|
Chris@16
|
18 namespace utilities {
|
Chris@16
|
19
|
Chris@16
|
20 namespace dispatch {
|
Chris@16
|
21
|
Chris@16
|
22 template <typename Point, size_t Dimension>
|
Chris@16
|
23 struct print_point
|
Chris@16
|
24 {
|
Chris@16
|
25 BOOST_STATIC_ASSERT(0 < Dimension);
|
Chris@16
|
26
|
Chris@16
|
27 static inline void apply(std::ostream & os, Point const& p)
|
Chris@16
|
28 {
|
Chris@16
|
29 print_point<Point, Dimension - 1>::apply(os, p);
|
Chris@16
|
30
|
Chris@16
|
31 os << ", " << geometry::get<Dimension - 1>(p);
|
Chris@16
|
32 }
|
Chris@16
|
33 };
|
Chris@16
|
34
|
Chris@16
|
35 template <typename Point>
|
Chris@16
|
36 struct print_point<Point, 1>
|
Chris@16
|
37 {
|
Chris@16
|
38 static inline void apply(std::ostream & os, Point const& p)
|
Chris@16
|
39 {
|
Chris@16
|
40 os << geometry::get<0>(p);
|
Chris@16
|
41 }
|
Chris@16
|
42 };
|
Chris@16
|
43
|
Chris@16
|
44 template <typename Box, size_t Corner, size_t Dimension>
|
Chris@16
|
45 struct print_corner
|
Chris@16
|
46 {
|
Chris@16
|
47 BOOST_STATIC_ASSERT(0 < Dimension);
|
Chris@16
|
48
|
Chris@16
|
49 static inline void apply(std::ostream & os, Box const& b)
|
Chris@16
|
50 {
|
Chris@16
|
51 print_corner<Box, Corner, Dimension - 1>::apply(os, b);
|
Chris@16
|
52
|
Chris@16
|
53 os << ", " << geometry::get<Corner, Dimension - 1>(b);
|
Chris@16
|
54 }
|
Chris@16
|
55 };
|
Chris@16
|
56
|
Chris@16
|
57 template <typename Box, size_t Corner>
|
Chris@16
|
58 struct print_corner<Box, Corner, 1>
|
Chris@16
|
59 {
|
Chris@16
|
60 static inline void apply(std::ostream & os, Box const& b)
|
Chris@16
|
61 {
|
Chris@16
|
62 os << geometry::get<Corner, 0>(b);
|
Chris@16
|
63 }
|
Chris@16
|
64 };
|
Chris@16
|
65
|
Chris@16
|
66 template <typename Indexable, typename Tag>
|
Chris@16
|
67 struct print_indexable
|
Chris@16
|
68 {
|
Chris@16
|
69 };
|
Chris@16
|
70
|
Chris@16
|
71 template <typename Indexable>
|
Chris@16
|
72 struct print_indexable<Indexable, box_tag>
|
Chris@16
|
73 {
|
Chris@16
|
74 static const size_t dimension = geometry::dimension<Indexable>::value;
|
Chris@16
|
75
|
Chris@16
|
76 static inline void apply(std::ostream &os, Indexable const& i)
|
Chris@16
|
77 {
|
Chris@16
|
78 os << '(';
|
Chris@16
|
79 print_corner<Indexable, min_corner, dimension>::apply(os, i);
|
Chris@16
|
80 os << ")x(";
|
Chris@16
|
81 print_corner<Indexable, max_corner, dimension>::apply(os, i);
|
Chris@16
|
82 os << ')';
|
Chris@16
|
83 }
|
Chris@16
|
84 };
|
Chris@16
|
85
|
Chris@16
|
86 template <typename Indexable>
|
Chris@16
|
87 struct print_indexable<Indexable, point_tag>
|
Chris@16
|
88 {
|
Chris@16
|
89 static const size_t dimension = geometry::dimension<Indexable>::value;
|
Chris@16
|
90
|
Chris@16
|
91 static inline void apply(std::ostream &os, Indexable const& i)
|
Chris@16
|
92 {
|
Chris@16
|
93 os << '(';
|
Chris@16
|
94 print_point<Indexable, dimension>::apply(os, i);
|
Chris@16
|
95 os << ')';
|
Chris@16
|
96 }
|
Chris@16
|
97 };
|
Chris@16
|
98
|
Chris@16
|
99 } // namespace dispatch
|
Chris@16
|
100
|
Chris@16
|
101 template <typename Indexable> inline
|
Chris@16
|
102 void print_indexable(std::ostream & os, Indexable const& i)
|
Chris@16
|
103 {
|
Chris@16
|
104 dispatch::print_indexable<
|
Chris@16
|
105 Indexable,
|
Chris@16
|
106 typename tag<Indexable>::type
|
Chris@16
|
107 >::apply(os, i);
|
Chris@16
|
108 }
|
Chris@16
|
109
|
Chris@16
|
110 } // namespace utilities
|
Chris@16
|
111
|
Chris@16
|
112 namespace rtree { namespace utilities {
|
Chris@16
|
113
|
Chris@16
|
114 namespace visitors {
|
Chris@16
|
115
|
Chris@16
|
116 template <typename Value, typename Options, typename Translator, typename Box, typename Allocators>
|
Chris@16
|
117 struct print : public rtree::visitor<Value, typename Options::parameters_type, Box, Allocators, typename Options::node_tag, true>::type
|
Chris@16
|
118 {
|
Chris@16
|
119 typedef typename rtree::internal_node<Value, typename Options::parameters_type, Box, Allocators, typename Options::node_tag>::type internal_node;
|
Chris@16
|
120 typedef typename rtree::leaf<Value, typename Options::parameters_type, Box, Allocators, typename Options::node_tag>::type leaf;
|
Chris@16
|
121
|
Chris@16
|
122 inline print(std::ostream & o, Translator const& t)
|
Chris@16
|
123 : os(o), tr(t), level(0)
|
Chris@16
|
124 {}
|
Chris@16
|
125
|
Chris@16
|
126 inline void operator()(internal_node const& n)
|
Chris@16
|
127 {
|
Chris@16
|
128 typedef typename rtree::elements_type<internal_node>::type elements_type;
|
Chris@16
|
129 elements_type const& elements = rtree::elements(n);
|
Chris@16
|
130
|
Chris@16
|
131 spaces(level) << "INTERNAL NODE - L:" << level << " Ch:" << elements.size() << " @:" << &n << '\n';
|
Chris@16
|
132
|
Chris@16
|
133 for (typename elements_type::const_iterator it = elements.begin();
|
Chris@16
|
134 it != elements.end(); ++it)
|
Chris@16
|
135 {
|
Chris@16
|
136 spaces(level);
|
Chris@16
|
137 detail::utilities::print_indexable(os, it->first);
|
Chris@16
|
138 os << " ->" << it->second << '\n';
|
Chris@16
|
139 }
|
Chris@16
|
140
|
Chris@16
|
141 size_t level_backup = level;
|
Chris@16
|
142 ++level;
|
Chris@16
|
143
|
Chris@16
|
144 for (typename elements_type::const_iterator it = elements.begin();
|
Chris@16
|
145 it != elements.end(); ++it)
|
Chris@16
|
146 {
|
Chris@16
|
147 rtree::apply_visitor(*this, *it->second);
|
Chris@16
|
148 }
|
Chris@16
|
149
|
Chris@16
|
150 level = level_backup;
|
Chris@16
|
151 }
|
Chris@16
|
152
|
Chris@16
|
153 inline void operator()(leaf const& n)
|
Chris@16
|
154 {
|
Chris@16
|
155 typedef typename rtree::elements_type<leaf>::type elements_type;
|
Chris@16
|
156 elements_type const& elements = rtree::elements(n);
|
Chris@16
|
157
|
Chris@16
|
158 spaces(level) << "LEAF - L:" << level << " V:" << elements.size() << " @:" << &n << '\n';
|
Chris@16
|
159 for (typename elements_type::const_iterator it = elements.begin();
|
Chris@16
|
160 it != elements.end(); ++it)
|
Chris@16
|
161 {
|
Chris@16
|
162 spaces(level);
|
Chris@16
|
163 detail::utilities::print_indexable(os, tr(*it));
|
Chris@16
|
164 os << '\n';
|
Chris@16
|
165 }
|
Chris@16
|
166 }
|
Chris@16
|
167
|
Chris@16
|
168 inline std::ostream & spaces(size_t level)
|
Chris@16
|
169 {
|
Chris@16
|
170 for ( size_t i = 0 ; i < 2 * level ; ++i )
|
Chris@16
|
171 os << ' ';
|
Chris@16
|
172 return os;
|
Chris@16
|
173 }
|
Chris@16
|
174
|
Chris@16
|
175 std::ostream & os;
|
Chris@16
|
176 Translator const& tr;
|
Chris@16
|
177
|
Chris@16
|
178 size_t level;
|
Chris@16
|
179 };
|
Chris@16
|
180
|
Chris@16
|
181 } // namespace visitors
|
Chris@16
|
182
|
Chris@16
|
183 template <typename Rtree> inline
|
Chris@16
|
184 void print(std::ostream & os, Rtree const& tree)
|
Chris@16
|
185 {
|
Chris@16
|
186 typedef utilities::view<Rtree> RTV;
|
Chris@16
|
187 RTV rtv(tree);
|
Chris@16
|
188
|
Chris@16
|
189 visitors::print<
|
Chris@16
|
190 typename RTV::value_type,
|
Chris@16
|
191 typename RTV::options_type,
|
Chris@16
|
192 typename RTV::translator_type,
|
Chris@16
|
193 typename RTV::box_type,
|
Chris@16
|
194 typename RTV::allocators_type
|
Chris@16
|
195 > print_v(os, rtv.translator());
|
Chris@16
|
196 rtv.apply_visitor(print_v);
|
Chris@16
|
197 }
|
Chris@16
|
198
|
Chris@16
|
199 }} // namespace rtree::utilities
|
Chris@16
|
200
|
Chris@16
|
201 }}}} // namespace boost::geometry::index::detail
|
Chris@16
|
202
|
Chris@16
|
203 #endif // BOOST_GEOMETRY_INDEX_DETAIL_RTREE_UTILITIES_PRINT_HPP
|