Skip to content
Snippets Groups Projects
Commit 0fda18dd authored by Paolo Carlini's avatar Paolo Carlini Committed by Paolo Carlini
Browse files

bitset (bitset<>::bitset(const char*)): Add per DR 778.

2008-05-21  Paolo Carlini  <paolo.carlini@oracle.com>

	* include/std/bitset (bitset<>::bitset(const char*)): Add per DR 778.
	(bitset<>::_M_copy_from_ptr): Add.
	(bitset<>::_M_copy_from_string): Forward to the latter.
	* doc/xml/manual/intro.xml: Add an entry for DR 778.
	* testsuite/23_containers/bitset/cons/2.cc: Add.

From-SVN: r135738
parent 301a9fb2
No related branches found
No related tags found
No related merge requests found
2008-05-21 Paolo Carlini <paolo.carlini@oracle.com>
* include/std/bitset (bitset<>::bitset(const char*)): Add per DR 778.
(bitset<>::_M_copy_from_ptr): Add.
(bitset<>::_M_copy_from_string): Forward to the latter.
* doc/xml/manual/intro.xml: Add an entry for DR 778.
* testsuite/23_containers/bitset/cons/2.cc: Add.
2008-05-21 Paolo Carlini <paolo.carlini@oracle.com> 2008-05-21 Paolo Carlini <paolo.carlini@oracle.com>
* doc/html/ext/lwg-active.html: Update to Revision R56. * doc/html/ext/lwg-active.html: Update to Revision R56.
......
...@@ -628,6 +628,12 @@ ...@@ -628,6 +628,12 @@
</term> </term>
<listitem><para>Make the member functions table and classic_table public. <listitem><para>Make the member functions table and classic_table public.
</para></listitem></varlistentry> </para></listitem></varlistentry>
<varlistentry><term><ulink url="lwg-active.html#778">778</ulink>:
<emphasis>std::bitset does not have any constructor taking a string literal</emphasis>
</term>
<listitem><para>Add it.
</para></listitem></varlistentry>
</variablelist> </variablelist>
</sect2> </sect2>
......
...@@ -786,7 +786,14 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) ...@@ -786,7 +786,14 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
"not valid")); "not valid"));
_M_copy_from_string(__s, __position, __n); _M_copy_from_string(__s, __position, __n);
} }
// _GLIBCXX_RESOLVE_LIB_DEFECTS
// 778. std::bitset does not have any constructor taking a string literal
explicit
bitset(const char* __s)
: _Base()
{ _M_copy_from_ptr(__s, char_traits<char>::length(__s), 0, size_t(-1)); }
// 23.3.5.2 bitset operations: // 23.3.5.2 bitset operations:
//@{ //@{
/** /**
...@@ -1049,11 +1056,15 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) ...@@ -1049,11 +1056,15 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
} }
// Helper functions for string operations. // Helper functions for string operations.
template<class _CharT>
void
_M_copy_from_ptr(const _CharT*, size_t, size_t, size_t);
template<class _CharT, class _Traits, class _Alloc> template<class _CharT, class _Traits, class _Alloc>
void void
_M_copy_from_string(const std::basic_string<_CharT, _M_copy_from_string(const std::basic_string<_CharT,
_Traits, _Alloc>& __s, _Traits, _Alloc>& __s, size_t __pos, size_t __n)
size_t, size_t); { _M_copy_from_ptr(__s.data(), __s.size(), __pos, __n); }
template<class _CharT, class _Traits, class _Alloc> template<class _CharT, class _Traits, class _Alloc>
void void
...@@ -1155,14 +1166,14 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) ...@@ -1155,14 +1166,14 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
// Definitions of non-inline member functions. // Definitions of non-inline member functions.
template<size_t _Nb> template<size_t _Nb>
template<class _CharT, class _Traits, class _Alloc> template<class _CharT>
void void
bitset<_Nb>:: bitset<_Nb>::
_M_copy_from_string(const std::basic_string<_CharT, _Traits, _M_copy_from_ptr(const _CharT* __s, size_t __len,
_Alloc>& __s, size_t __pos, size_t __n) size_t __pos, size_t __n)
{ {
reset(); reset();
const size_t __nbits = std::min(_Nb, std::min(__n, __s.size() - __pos)); const size_t __nbits = std::min(_Nb, std::min(__n, __len - __pos));
for (size_t __i = __nbits; __i > 0; --__i) for (size_t __i = __nbits; __i > 0; --__i)
{ {
switch(__s[__pos + __nbits - __i]) switch(__s[__pos + __nbits - __i])
...@@ -1173,7 +1184,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) ...@@ -1173,7 +1184,7 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D)
_Unchecked_set(__i - 1); _Unchecked_set(__i - 1);
break; break;
default: default:
__throw_invalid_argument(__N("bitset::_M_copy_from_string")); __throw_invalid_argument(__N("bitset::_M_copy_from_ptr"));
} }
} }
} }
......
// 2008-05-21 Paolo Carlini <paolo.carlini@oracle.com>
// Copyright (C) 2008 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 2, 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 COPYING. If not, write to the Free
// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
// USA.
#include <bitset>
#include <testsuite_hooks.h>
// DR 778. std::bitset does not have any constructor taking a string literal.
void test01()
{
bool test __attribute__((unused)) = true;
std::bitset<4> z1("1101");
std::bitset<4> z1_ref(std::string("1101"));
VERIFY( z1.to_string() == "1101" );
VERIFY( z1 == z1_ref );
std::bitset<8> z2("1011");
std::bitset<8> z2_ref(std::string("1011"));
VERIFY( z2.to_string() == "00001011" );
VERIFY( z2 == z2_ref );
std::bitset<2> z3("1101");
std::bitset<2> z3_ref(std::string("1101"));
VERIFY( z3.to_string() == "11" );
VERIFY( z3 == z3_ref );
}
int main()
{
test01();
return 0;
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment