Home | History | Annotate | Download | only in re.traits
      1 // -*- C++ -*-
      2 //===----------------------------------------------------------------------===//
      3 //
      4 //                     The LLVM Compiler Infrastructure
      5 //
      6 // This file is dual licensed under the MIT and the University of Illinois Open
      7 // Source Licenses. See LICENSE.TXT for details.
      8 //
      9 //===----------------------------------------------------------------------===//
     10 
     11 // REQUIRES: locale.cs_CZ.ISO8859-2
     12 
     13 // <regex>
     14 
     15 // template <class charT> struct regex_traits;
     16 
     17 // template <class ForwardIterator>
     18 //   string_type
     19 //   transform_primary(ForwardIterator first, ForwardIterator last) const;
     20 
     21 #include <regex>
     22 #include <cassert>
     23 
     24 #include "test_macros.h"
     25 #include "test_iterators.h"
     26 #include "platform_support.h" // locale name macros
     27 
     28 int main()
     29 {
     30     {
     31         std::regex_traits<char> t;
     32         const char A[] = "A";
     33         const char Aacute[] = "\xC1";
     34         typedef forward_iterator<const char*> F;
     35         assert(t.transform_primary(F(A), F(A+1)) !=
     36                t.transform_primary(F(Aacute), F(Aacute+1)));
     37         t.imbue(std::locale(LOCALE_cs_CZ_ISO8859_2));
     38         assert(t.transform_primary(F(A), F(A+1)) ==
     39                t.transform_primary(F(Aacute), F(Aacute+1)));
     40     }
     41     {
     42         std::regex_traits<wchar_t> t;
     43         const wchar_t A[] = L"A";
     44         const wchar_t Aacute[] = L"\xC1";
     45         typedef forward_iterator<const wchar_t*> F;
     46         assert(t.transform_primary(F(A), F(A+1)) !=
     47                t.transform_primary(F(Aacute), F(Aacute+1)));
     48         t.imbue(std::locale(LOCALE_cs_CZ_ISO8859_2));
     49         assert(t.transform_primary(F(A), F(A+1)) ==
     50                t.transform_primary(F(Aacute), F(Aacute+1)));
     51     }
     52 }
     53