summaryrefslogtreecommitdiff
path: root/test/std/strings/string.conversions/stoull.pass.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/std/strings/string.conversions/stoull.pass.cpp')
-rw-r--r--test/std/strings/string.conversions/stoull.pass.cpp116
1 files changed, 0 insertions, 116 deletions
diff --git a/test/std/strings/string.conversions/stoull.pass.cpp b/test/std/strings/string.conversions/stoull.pass.cpp
deleted file mode 100644
index 2ac883ec09364..0000000000000
--- a/test/std/strings/string.conversions/stoull.pass.cpp
+++ /dev/null
@@ -1,116 +0,0 @@
-//===----------------------------------------------------------------------===//
-//
-// The LLVM Compiler Infrastructure
-//
-// This file is dual licensed under the MIT and the University of Illinois Open
-// Source Licenses. See LICENSE.TXT for details.
-//
-//===----------------------------------------------------------------------===//
-//
-// PR14919 was fixed in r172447, out_of_range wasn't thrown before.
-// XFAIL: with_system_cxx_lib=macosx10.7
-// XFAIL: with_system_cxx_lib=macosx10.8
-
-// <string>
-
-// unsigned long long stoull(const string& str, size_t *idx = 0, int base = 10);
-// unsigned long long stoull(const wstring& str, size_t *idx = 0, int base = 10);
-
-#include <string>
-#include <cassert>
-#include <stdexcept>
-
-#include "test_macros.h"
-
-int main()
-{
- assert(std::stoull("0") == 0);
- assert(std::stoull(L"0") == 0);
- assert(std::stoull("-0") == 0);
- assert(std::stoull(L"-0") == 0);
- assert(std::stoull(" 10") == 10);
- assert(std::stoull(L" 10") == 10);
- size_t idx = 0;
- assert(std::stoull("10g", &idx, 16) == 16);
- assert(idx == 2);
- idx = 0;
- assert(std::stoull(L"10g", &idx, 16) == 16);
- assert(idx == 2);
-#ifndef TEST_HAS_NO_EXCEPTIONS
- idx = 0;
- try
- {
- std::stoull("", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
- idx = 0;
- try
- {
- std::stoull(L"", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
- try
- {
- std::stoull(" - 8", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
- try
- {
- std::stoull(L" - 8", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
- try
- {
- std::stoull("a1", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
- try
- {
- std::stoull(L"a1", &idx);
- assert(false);
- }
- catch (const std::invalid_argument&)
- {
- assert(idx == 0);
- }
-// LWG issue #2009
- try
- {
- std::stoull("9999999999999999999999999999999999999999999999999", &idx);
- assert(false);
- }
- catch (const std::out_of_range&)
- {
- assert(idx == 0);
- }
- try
- {
- std::stoull(L"9999999999999999999999999999999999999999999999999", &idx);
- assert(false);
- }
- catch (const std::out_of_range&)
- {
- assert(idx == 0);
- }
-#endif
-}