File: from_range_deduction.pass.cpp

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 1,998,492 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (55 lines) | stat: -rw-r--r-- 2,122 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

// <string>

// UNSUPPORTED: c++03, c++11, c++14, c++17, c++20
// To silence a GCC warning-turned-error re. `BadAlloc::value_type`.
// ADDITIONAL_COMPILE_FLAGS(gcc-style-warnings): -Wno-unused-local-typedefs

// template<ranges::input_range R,
//          class Allocator = allocator<ranges::range_value_t<R>>>
//   basic_string(from_range_t, R&&, Allocator = Allocator())
//     -> basic_string<ranges::range_value_t<R>, char_traits<ranges::range_value_t<R>>,
//                     Allocator>; // C++23
//
// The deduction guide shall not participate in overload resolution if Allocator
// is a type that does not qualify as an allocator (in addition to the `input_range` concept being satisfied by `R`).

#include <array>
#include <string>

#include "deduction_guides_sfinae_checks.h"
#include "test_allocator.h"
#include "asan_testing.h"

int main(int, char**) {
  using Char = char16_t;

  {
    std::basic_string c(std::from_range, std::array<Char, 0>());
    static_assert(std::is_same_v<decltype(c), std::basic_string<Char>>);
    LIBCPP_ASSERT(is_string_asan_correct(c));
  }

  {
    using Alloc = test_allocator<Char>;
    std::basic_string c(std::from_range, std::array<Char, 0>(), Alloc());
    static_assert(std::is_same_v<decltype(c), std::basic_string<Char, std::char_traits<Char>, Alloc>>);
    LIBCPP_ASSERT(is_string_asan_correct(c));
  }

  // Note: defining `value_type` is a workaround because one of the deduction guides will end up instantiating
  // `basic_string`, and that would fail with a hard error if the given allocator doesn't define `value_type`.
  struct BadAlloc {
    using value_type = char;
  };
  SequenceContainerDeductionGuidesSfinaeAway<std::basic_string, std::basic_string<char>, BadAlloc>();

  return 0;
}