1 #ifndef BOOST_ARCHIVE_ITERATORS_XML_ESCAPE_HPP
2 #define BOOST_ARCHIVE_ITERATORS_XML_ESCAPE_HPP
3
4 // MS compatible compilers support #pragma once
5 #if defined(_MSC_VER)
6 # pragma once
7 #endif
8
9 /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
10 // xml_escape.hpp
11
12 // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com .
13 // Use, modification and distribution is subject to the Boost Software
14 // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
15 // http://www.boost.org/LICENSE_1_0.txt)
16
17 // See http://www.boost.org for updates, documentation, and revision history.
18
19 #include <boost/assert.hpp>
20 #include <boost/archive/iterators/escape.hpp>
21
22 namespace boost {
23 namespace archive {
24 namespace iterators {
25
26 /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
27 // insert escapes into xml text
28
29 template<class Base>
30 class xml_escape
31 : public escape<xml_escape<Base>, Base>
32 {
33 friend class boost::iterator_core_access;
34
35 typedef escape<xml_escape<Base>, Base> super_t;
36
37 public:
38 char fill(const char * & bstart, const char * & bend);
39 wchar_t fill(const wchar_t * & bstart, const wchar_t * & bend);
40
41 template<class T>
xml_escape(T start)42 xml_escape(T start) :
43 super_t(Base(static_cast< T >(start)))
44 {}
45 // intel 7.1 doesn't like default copy constructor
xml_escape(const xml_escape & rhs)46 xml_escape(const xml_escape & rhs) :
47 super_t(rhs.base_reference())
48 {}
49 };
50
51 template<class Base>
fill(const char * & bstart,const char * & bend)52 char xml_escape<Base>::fill(
53 const char * & bstart,
54 const char * & bend
55 ){
56 char current_value = * this->base_reference();
57 switch(current_value){
58 case '<':
59 bstart = "<";
60 bend = bstart + 4;
61 break;
62 case '>':
63 bstart = ">";
64 bend = bstart + 4;
65 break;
66 case '&':
67 bstart = "&";
68 bend = bstart + 5;
69 break;
70 case '"':
71 bstart = """;
72 bend = bstart + 6;
73 break;
74 case '\'':
75 bstart = "'";
76 bend = bstart + 6;
77 break;
78 default:
79 return current_value;
80 }
81 return *bstart;
82 }
83
84 template<class Base>
fill(const wchar_t * & bstart,const wchar_t * & bend)85 wchar_t xml_escape<Base>::fill(
86 const wchar_t * & bstart,
87 const wchar_t * & bend
88 ){
89 wchar_t current_value = * this->base_reference();
90 switch(current_value){
91 case '<':
92 bstart = L"<";
93 bend = bstart + 4;
94 break;
95 case '>':
96 bstart = L">";
97 bend = bstart + 4;
98 break;
99 case '&':
100 bstart = L"&";
101 bend = bstart + 5;
102 break;
103 case '"':
104 bstart = L""";
105 bend = bstart + 6;
106 break;
107 case '\'':
108 bstart = L"'";
109 bend = bstart + 6;
110 break;
111 default:
112 return current_value;
113 }
114 return *bstart;
115 }
116
117 } // namespace iterators
118 } // namespace archive
119 } // namespace boost
120
121 #endif // BOOST_ARCHIVE_ITERATORS_XML_ESCAPE_HPP
122