1 /*
2 *
3 * Copyright (c) 2004
4 * John Maddock
5 *
6 * Use, modification and distribution are subject to the
7 * Boost Software License, Version 1.0. (See accompanying file
8 * LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
9 *
10 */
11
12 /*
13 * LOCATION: see http://www.boost.org for most recent version.
14 * FILE cpp_regex_traits.cpp
15 * VERSION see <boost/version.hpp>
16 * DESCRIPTION: Implements cpp_regex_traits<char> (and associated helper classes).
17 */
18
19 #define BOOST_REGEX_SOURCE
20 #include <boost/config.hpp>
21 #ifndef BOOST_NO_STD_LOCALE
22 #include <boost/regex/regex_traits.hpp>
23 #include <boost/regex/pattern_except.hpp>
24
25 #ifdef BOOST_NO_STDC_NAMESPACE
26 namespace std{
27 using ::memset;
28 }
29 #endif
30
31 namespace boost{ namespace BOOST_REGEX_DETAIL_NS{
32
init()33 void cpp_regex_traits_char_layer<char>::init()
34 {
35 // we need to start by initialising our syntax map so we know which
36 // character is used for which purpose:
37 std::memset(m_char_map, 0, sizeof(m_char_map));
38 #ifndef BOOST_NO_STD_MESSAGES
39 #ifndef __IBMCPP__
40 std::messages<char>::catalog cat = static_cast<std::messages<char>::catalog>(-1);
41 #else
42 std::messages<char>::catalog cat = reinterpret_cast<std::messages<char>::catalog>(-1);
43 #endif
44 std::string cat_name(cpp_regex_traits<char>::get_catalog_name());
45 if(cat_name.size() && (m_pmessages != 0))
46 {
47 cat = this->m_pmessages->open(
48 cat_name,
49 this->m_locale);
50 if((int)cat < 0)
51 {
52 std::string m("Unable to open message catalog: ");
53 std::runtime_error err(m + cat_name);
54 boost::BOOST_REGEX_DETAIL_NS::raise_runtime_error(err);
55 }
56 }
57 //
58 // if we have a valid catalog then load our messages:
59 //
60 if((int)cat >= 0)
61 {
62 #ifndef BOOST_NO_EXCEPTIONS
63 try{
64 #endif
65 for(regex_constants::syntax_type i = 1; i < regex_constants::syntax_max; ++i)
66 {
67 string_type mss = this->m_pmessages->get(cat, 0, i, get_default_syntax(i));
68 for(string_type::size_type j = 0; j < mss.size(); ++j)
69 {
70 m_char_map[static_cast<unsigned char>(mss[j])] = i;
71 }
72 }
73 this->m_pmessages->close(cat);
74 #ifndef BOOST_NO_EXCEPTIONS
75 }
76 catch(...)
77 {
78 this->m_pmessages->close(cat);
79 throw;
80 }
81 #endif
82 }
83 else
84 {
85 #endif
86 for(regex_constants::syntax_type j = 1; j < regex_constants::syntax_max; ++j)
87 {
88 const char* ptr = get_default_syntax(j);
89 while(ptr && *ptr)
90 {
91 m_char_map[static_cast<unsigned char>(*ptr)] = j;
92 ++ptr;
93 }
94 }
95 #ifndef BOOST_NO_STD_MESSAGES
96 }
97 #endif
98 //
99 // finish off by calculating our escape types:
100 //
101 unsigned char i = 'A';
102 do
103 {
104 if(m_char_map[i] == 0)
105 {
106 if(this->m_pctype->is(std::ctype_base::lower, i))
107 m_char_map[i] = regex_constants::escape_type_class;
108 else if(this->m_pctype->is(std::ctype_base::upper, i))
109 m_char_map[i] = regex_constants::escape_type_not_class;
110 }
111 }while(0xFF != i++);
112 }
113
114 } // BOOST_REGEX_DETAIL_NS
115 } // boost
116 #endif
117
118