minmax_init_list.pass.cpp revision b64f8b07c104c6cc986570ac8ee0ed16a9f23976
1bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===// 2bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 3f5256e16dfc425c1d466f6308d4026d529ce9e0bHoward Hinnant// The LLVM Compiler Infrastructure 4bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 5b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open 6b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// Source Licenses. See LICENSE.TXT for details. 7bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 8bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===// 9bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 10bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// <algorithm> 11bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 12eb564e76cc3904d811c981a50ecce0659f444cc9Howard Hinnant// template<class T> 1398e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant// pair<T, T> 14bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// minmax(initializer_list<T> t); 15bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 16bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <algorithm> 17bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <cassert> 18bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 19bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnantint main() 20bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant{ 2173d21a4f0774d3fadab98e690619a359cfb160a3Howard Hinnant#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2298e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({1, 2, 3}) == std::pair<int, int>(1, 3))); 2398e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({1, 3, 2}) == std::pair<int, int>(1, 3))); 2498e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({2, 1, 3}) == std::pair<int, int>(1, 3))); 2598e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({2, 3, 1}) == std::pair<int, int>(1, 3))); 2698e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({3, 1, 2}) == std::pair<int, int>(1, 3))); 2798e5d974006989c505d7b2ec7b9e4b20b0f01e26Howard Hinnant assert((std::minmax({3, 2, 1}) == std::pair<int, int>(1, 3))); 2873d21a4f0774d3fadab98e690619a359cfb160a3Howard Hinnant#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 29bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant} 30