xref: /llvm-project/libcxx/test/std/numerics/rand/rand.adapt/rand.adapt.shuf/seed_sseq.pass.cpp (revision 7fc6a55688c816f5fc1a5481ae7af25be7500356)
15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <random>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template<class Engine, size_t k>
125a83710eSEric Fiselier // class shuffle_order_engine
135a83710eSEric Fiselier 
145a83710eSEric Fiselier // template<class Sseq> void seed(Sseq& q);
155a83710eSEric Fiselier 
165a83710eSEric Fiselier #include <random>
175a83710eSEric Fiselier #include <cassert>
185a83710eSEric Fiselier 
19*7fc6a556SMarshall Clow #include "test_macros.h"
20*7fc6a556SMarshall Clow 
215a83710eSEric Fiselier void
test1()225a83710eSEric Fiselier test1()
235a83710eSEric Fiselier {
245a83710eSEric Fiselier     unsigned a[] = {3, 5, 7};
255a83710eSEric Fiselier     std::seed_seq sseq(a, a+3);
265a83710eSEric Fiselier     std::knuth_b e1;
275a83710eSEric Fiselier     std::knuth_b e2(sseq);
285a83710eSEric Fiselier     assert(e1 != e2);
295a83710eSEric Fiselier     e1.seed(sseq);
305a83710eSEric Fiselier     assert(e1 == e2);
315a83710eSEric Fiselier }
325a83710eSEric Fiselier 
main(int,char **)332df59c50SJF Bastien int main(int, char**)
345a83710eSEric Fiselier {
355a83710eSEric Fiselier     test1();
362df59c50SJF Bastien 
372df59c50SJF Bastien   return 0;
385a83710eSEric Fiselier }
39