• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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