2009-12-31 Paolo Carlini <paolo.carlini@oracle.com>
authorpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 31 Dec 2009 17:31:28 +0000 (17:31 +0000)
committerpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 31 Dec 2009 17:31:28 +0000 (17:31 +0000)
* include/std/bitset (bitset<>::bitset(unsigned long long),
_Base_bitset<>::_Base_bitset(unsigned long long)): Add
in C++0x mode.
* testsuite/23_containers/bitset/cons/3.cc: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@155539 138bc75d-0d04-0410-961f-82ee72b054a4

libstdc++-v3/ChangeLog
libstdc++-v3/include/std/bitset
libstdc++-v3/testsuite/23_containers/bitset/cons/3.cc [new file with mode: 0644]

index 6f2969f..def5105 100644 (file)
@@ -1,5 +1,12 @@
 2009-12-31  Paolo Carlini  <paolo.carlini@oracle.com>
 
+       * include/std/bitset (bitset<>::bitset(unsigned long long),
+       _Base_bitset<>::_Base_bitset(unsigned long long)): Add
+       in C++0x mode.
+       * testsuite/23_containers/bitset/cons/3.cc: New.
+
+2009-12-31  Paolo Carlini  <paolo.carlini@oracle.com>
+
        * include/std/type_traits: Fix minor stylistic nit.
 
 2009-12-31  Paolo Carlini  <paolo.carlini@oracle.com>
index 7884355..06fdd3f 100644 (file)
@@ -76,10 +76,18 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
       _Base_bitset()
       { _M_do_reset(); }
 
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+      _Base_bitset(unsigned long long __val)
+#else
       _Base_bitset(unsigned long __val)
+#endif
       {
        _M_do_reset();
        _M_w[0] = __val;
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+       if (sizeof(unsigned long long) > sizeof(unsigned long))
+         _M_w[1] = __val >> _GLIBCXX_BITSET_BITS_PER_WORD;
+#endif
       }
 
       static size_t
@@ -359,7 +367,11 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
       : _M_w(0)
       { }
 
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+      _Base_bitset(unsigned long long __val)
+#else
       _Base_bitset(unsigned long __val)
+#endif
       : _M_w(__val)
       { }
 
@@ -491,7 +503,11 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
       _Base_bitset()
       { }
 
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+      _Base_bitset(unsigned long long)
+#else
       _Base_bitset(unsigned long)
+#endif
       { }
 
       static size_t
@@ -771,7 +787,11 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
       { }
 
       /// Initial bits bitwise-copied from a single word (others set to zero).
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+      bitset(unsigned long long __val)
+#else
       bitset(unsigned long __val)
+#endif
       : _Base(__val)
       { _M_do_sanitize(); }
 
diff --git a/libstdc++-v3/testsuite/23_containers/bitset/cons/3.cc b/libstdc++-v3/testsuite/23_containers/bitset/cons/3.cc
new file mode 100644 (file)
index 0000000..b908068
--- /dev/null
@@ -0,0 +1,62 @@
+// { dg-options "-std=gnu++0x" }
+
+// 2009-12-31  Paolo Carlini  <paolo.carlini@oracle.com>
+
+// Copyright (C) 2009 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library.  This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3.  If not see
+// <http://www.gnu.org/licenses/>.
+
+#include <bitset>
+#include <testsuite_hooks.h>
+
+void test01()
+{
+  bool test __attribute__((unused)) = true;
+
+  const unsigned long long num0 = 0ULL;
+  std::bitset<0> bs0(num0);
+  VERIFY( bs0.to_ullong() == num0 );
+
+  const unsigned long long num1 = 215ULL;
+  std::bitset<32> bs1(num1);
+  VERIFY( bs1.to_ullong() == num1 );
+
+  const unsigned long long num2 = 215ULL;
+  std::bitset<64> bs2(num2);
+  VERIFY( bs2.to_ullong() == num2 );
+
+  const unsigned long long num3 = 343353215ULL;
+  std::bitset<32> bs3(num3);
+  VERIFY( bs3.to_ullong() == num3 );
+
+  const unsigned long long num4 = 343353215ULL;
+  std::bitset<64> bs4(num4);
+  VERIFY( bs4.to_ullong() == num4 );
+
+  const unsigned long long num5 = 13008719539498589283ULL;
+  std::bitset<64> bs5(num5);
+  VERIFY( bs5.to_ullong() == num5 );
+
+  const unsigned long long num6 = 13008719539498589283ULL;
+  std::bitset<128> bs6(num6);
+  VERIFY( bs6.to_ullong() == num6 );
+}
+
+int main()
+{
+  test01();
+  return 0;
+}