
Linux has a lot of failures caused by not having support for certain locales. Since these come out as a lot of noise in the test results, have lit.cfg detect the presence of the various locales used in the tests and add them to config.available_features as locale.LOCALE_NAME. This patch also adds REQUIRES: locale.REQUIRED_LOCALE to every test that I saw failing in this manner. We probably need to add more for all the tests requiring en_US.UTF-8, but we can do that on an as-needed basis. One thing that concerns me is how many tests get skipped because of missing locales (especially in regex/). We should make a point of splitting up any tests that test default behavior _and_ behavior under a given locale so that we aren't losing coverage for default behavior. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@214753 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
1.3 KiB
C++
45 lines
1.3 KiB
C++
// -*- C++ -*-
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// REQUIRES: locale.cs_CZ.ISO8859-2
|
|
|
|
// <regex>
|
|
|
|
// template <class charT> struct regex_traits;
|
|
|
|
// template <class ForwardIterator>
|
|
// string_type transform(ForwardIterator first, ForwardIterator last) const;
|
|
|
|
#include <regex>
|
|
#include <cassert>
|
|
#include "test_iterators.h"
|
|
|
|
int main()
|
|
{
|
|
{
|
|
std::regex_traits<char> t;
|
|
const char a[] = "a";
|
|
const char B[] = "B";
|
|
typedef forward_iterator<const char*> F;
|
|
assert(t.transform(F(a), F(a+1)) > t.transform(F(B), F(B+1)));
|
|
t.imbue(std::locale("cs_CZ.ISO8859-2"));
|
|
assert(t.transform(F(a), F(a+1)) < t.transform(F(B), F(B+1)));
|
|
}
|
|
{
|
|
std::regex_traits<wchar_t> t;
|
|
const wchar_t a[] = L"a";
|
|
const wchar_t B[] = L"B";
|
|
typedef forward_iterator<const wchar_t*> F;
|
|
assert(t.transform(F(a), F(a+1)) > t.transform(F(B), F(B+1)));
|
|
t.imbue(std::locale("cs_CZ.ISO8859-2"));
|
|
assert(t.transform(F(a), F(a+1)) < t.transform(F(B), F(B+1)));
|
|
}
|
|
}
|