//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // UNSUPPORTED: libcpp-has-no-localization // // template // class piecewise_linear_distribution // template // basic_ostream& // operator<<(basic_ostream& os, // const piecewise_linear_distribution& x); // // template // basic_istream& // operator>>(basic_istream& is, // piecewise_linear_distribution& x); #include #include #include #include "test_macros.h" int main(int, char**) { { typedef std::piecewise_linear_distribution<> D; double b[] = {10, 14, 16, 17}; double p[] = {25, 62.5, 12.5, 25}; const size_t Np = sizeof(p) / sizeof(p[0]); D d1(b, b+Np, p); std::ostringstream os; os << d1; std::istringstream is(os.str()); D d2; is >> d2; assert(d1 == d2); } return 0; }