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 // <queue>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // priority_queue();
125a83710eSEric Fiselier
135a83710eSEric Fiselier // template <class T, class Container, class Compare>
145a83710eSEric Fiselier // void swap(priority_queue<T, Container, Compare>& x,
155a83710eSEric Fiselier // priority_queue<T, Container, Compare>& y);
165a83710eSEric Fiselier
175a83710eSEric Fiselier #include <queue>
185a83710eSEric Fiselier #include <cassert>
195a83710eSEric Fiselier
20*7fc6a556SMarshall Clow #include "test_macros.h"
21*7fc6a556SMarshall Clow
main(int,char **)222df59c50SJF Bastien int main(int, char**)
235a83710eSEric Fiselier {
245a83710eSEric Fiselier std::priority_queue<int> q1;
255a83710eSEric Fiselier std::priority_queue<int> q2;
265a83710eSEric Fiselier q1.push(1);
275a83710eSEric Fiselier q1.push(3);
285a83710eSEric Fiselier q1.push(2);
295a83710eSEric Fiselier swap(q1, q2);
305a83710eSEric Fiselier assert(q1.empty());
315a83710eSEric Fiselier assert(q2.size() == 3);
325a83710eSEric Fiselier assert(q2.top() == 3);
332df59c50SJF Bastien
342df59c50SJF Bastien return 0;
355a83710eSEric Fiselier }
36