2010-06-17 02:34:59 +02:00
|
|
|
// -*- C++ -*-
|
|
|
|
//===-------------------------- algorithm ---------------------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
// <regex>
|
|
|
|
|
|
|
|
// template <class charT> struct regex_traits;
|
|
|
|
|
|
|
|
// template <class ForwardIterator>
|
|
|
|
// string_type
|
|
|
|
// transform_primary(ForwardIterator first, ForwardIterator last) const;
|
|
|
|
|
|
|
|
#include <regex>
|
|
|
|
#include <cassert>
|
|
|
|
#include "iterators.h"
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::regex_traits<char> t;
|
|
|
|
const char A[] = "A";
|
|
|
|
const char Aacute[] = "\xC1";
|
|
|
|
typedef forward_iterator<const char*> F;
|
2010-08-22 02:45:01 +02:00
|
|
|
assert(t.transform_primary(F(A), F(A+1)) !=
|
2010-06-17 02:34:59 +02:00
|
|
|
t.transform_primary(F(Aacute), F(Aacute+1)));
|
|
|
|
t.imbue(std::locale("cs_CZ.ISO8859-2"));
|
|
|
|
assert(t.transform_primary(F(A), F(A+1)) ==
|
|
|
|
t.transform_primary(F(Aacute), F(Aacute+1)));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
std::regex_traits<wchar_t> t;
|
|
|
|
const wchar_t A[] = L"A";
|
|
|
|
const wchar_t Aacute[] = L"\xC1";
|
|
|
|
typedef forward_iterator<const wchar_t*> F;
|
|
|
|
assert(t.transform_primary(F(A), F(A+1)) !=
|
|
|
|
t.transform_primary(F(Aacute), F(Aacute+1)));
|
|
|
|
t.imbue(std::locale("cs_CZ.ISO8859-2"));
|
|
|
|
assert(t.transform_primary(F(A), F(A+1)) ==
|
|
|
|
t.transform_primary(F(Aacute), F(Aacute+1)));
|
|
|
|
}
|
|
|
|
}
|