Created on 2018-06-30.00:00:00 last changed 44 months ago
Proposed resolution:
This wording is relative to N4750.
Change [basic.ios.members] p16 as indicated:
basic_ios& copyfmt(const basic_ios& rhs);-16- Effects: If (this ==
&addressof(rhs)) does nothing. […]
Change [istringstream.cons] as indicated:
explicit basic_istringstream(ios_base::openmode which);-1- Effects: Constructs an object of class basic_istringstream<charT, traits>, initializing the base class with basic_istream<charT, traits>(
&addressof(sb)) ([istream]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(which | ios_base::in) ([stringbuf.cons]).explicit basic_istringstream( const basic_string<charT, traits, Allocator>& str, ios_base::openmode which = ios_base::in);-2- Effects: Constructs an object of class basic_istringstream<charT, traits>, initializing the base class with basic_istream<charT, traits>(
&addressof(sb)) ([istream]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(str, which | ios_base::in) ([stringbuf.cons]).basic_istringstream(basic_istringstream&& rhs);-3- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_stringbuf. Next basic_istream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_stringbuf.
Change [istringstream.members] p1 as indicated:
basic_stringbuf<charT, traits, Allocator>* rdbuf() const;-1- Returns: const_cast<basic_stringbuf<charT, traits, Allocator>*>(
&addressof(sb)).
Change [ostringstream.cons] as indicated:
explicit basic_ostringstream(ios_base::openmode which);-1- Effects: Constructs an object of class basic_ostringstream<charT, traits>, initializing the base class with basic_ostream<charT, traits>(
&addressof(sb)) ([ostream]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(which | ios_base::out) ([stringbuf.cons]).explicit basic_ostringstream( const basic_string<charT, traits, Allocator>& str, ios_base::openmode which = ios_base::out);-2- Effects: Constructs an object of class basic_ostringstream<charT, traits>, initializing the base class with basic_ostream<charT, traits>(
&addressof(sb)) ([ostream]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(str, which | ios_base::out) ([stringbuf.cons]).basic_ostringstream(basic_ostringstream&& rhs);-3- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_stringbuf. Next basic_ostream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_stringbuf.
Change [ostringstream.members] p1 as indicated:
basic_stringbuf<charT, traits, Allocator>* rdbuf() const;-1- Returns: const_cast<basic_stringbuf<charT, traits, Allocator>*>(
&addressof(sb)).
Change [stringstream.cons] as indicated:
explicit basic_stringstream(ios_base::openmode which);-1- Effects: Constructs an object of class basic_stringstream<charT, traits>, initializing the base class with basic_iostream<charT, traits>(
&addressof(sb)) ([iostream.cons]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(which).explicit basic_stringstream( const basic_string<charT, traits, Allocator>& str, ios_base::openmode which = ios_base::out | ios_base::in);-2- Effects: Constructs an object of class basic_stringstream<charT, traits>, initializing the base class with basic_iostream<charT, traits>(
&addressof(sb)) ([iostream.cons]) and initializing sb with basic_stringbuf<charT, traits, Allocator>(str, which).basic_stringstream(basic_stringstream&& rhs);-3- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_stringbuf. Next basic_istream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_stringbuf.
Change [stringstream.members] p1 as indicated:
basic_stringbuf<charT, traits, Allocator>* rdbuf() const;-1- Returns: const_cast<basic_stringbuf<charT, traits, Allocator>*>(
&addressof(sb)).
Change [ifstream.cons] as indicated:
basic_ifstream();-1- Effects: Constructs an object of class basic_ifstream<charT, traits>, initializing the base class with basic_istream<charT, traits>(
&addressof(sb)) ([istream.cons]) and initializing sb with basic_filebuf<charT, traits>() ([filebuf.cons]).explicit basic_ifstream(const char* s, ios_base::openmode mode = ios_base::in); explicit basic_ifstream(const filesystem::path::value_type* s, ios_base::openmode mode = ios_base::in); // wide systems only; see [fstream.syn]
-2- Effects: Constructs an object of class basic_ifstream<charT, traits>, initializing the base class with basic_istream<charT, traits>(
&addressof(sb)) ([istream.cons]) and initializing sb with basic_filebuf<charT, traits>() ([filebuf.cons]), then calls rdbuf()->open(s, mode | ios_base::in). If that function returns a null pointer, calls setstate(failbit).[…]
basic_ifstream(basic_ifstream&& rhs);-4- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_filebuf. Next basic_istream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_filebuf.
Change [ifstream.members] p1 as indicated:
basic_filebuf<charT, traits>* rdbuf() const;-1- Returns: const_cast<basic_filebuf<charT, traits>*>(
&addressof(sb)).
Change [ofstream.cons] as indicated:
basic_ofstream();-1- Effects: Constructs an object of class basic_ofstream<charT, traits>, initializing the base class with basic_ostream<charT, traits>(
&addressof(sb)) ([ostream.cons]) and initializing sb with basic_filebuf<charT, traits>() ([filebuf.cons]).explicit basic_ofstream(const char* s, ios_base::openmode mode = ios_base::out); explicit basic_ofstream(const filesystem::path::value_type* s, ios_base::openmode mode = ios_base::out); // wide systems only; see [fstream.syn]
-2- Effects: Constructs an object of class basic_ofstream<charT, traits>, initializing the base class with basic_ostream<charT, traits>(
&addressof(sb)) ([ostream.cons]) and initializing sb with basic_filebuf<charT, traits>() ([filebuf.cons]), then calls rdbuf()->open(s, mode | ios_base::out). If that function returns a null pointer, calls setstate(failbit).[…]
basic_ofstream(basic_ofstream&& rhs);-4- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_filebuf. Next basic_ostream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_filebuf.
Change [ofstream.members] p1 as indicated:
basic_filebuf<charT, traits>* rdbuf() const;-1- Returns: const_cast<basic_filebuf<charT, traits>*>(
&addressof(sb)).
Change [fstream.cons] as indicated:
basic_fstream();-1- Effects: Constructs an object of class basic_fstream<charT, traits>, initializing the base class with basic_iostream<charT, traits>(
&addressof(sb)) ([iostream.cons]) and initializing sb with basic_filebuf<charT, traits>().explicit basic_fstream( const char* s, ios_base::openmode mode = ios_base::in | ios_base::out); explicit basic_fstream( const filesystem::path::value_type* s, ios_base::openmode mode = ios_base::in | ios_base::out); // wide systems only; see [fstream.syn]
-2- Effects: Constructs an object of class basic_fstream<charT, traits>, initializing the base class with basic_iostream<charT, traits>(
&addressof(sb)) ([iostream.cons]) and initializing sb with basic_filebuf<charT, traits>(), then calls rdbuf()->open(s, mode). If that function returns a null pointer, calls setstate(failbit).[…]
basic_fstream(basic_fstream&& rhs);-4- Effects: Move constructs from the rvalue rhs. This is accomplished by move constructing the base class, and the contained basic_filebuf. Next basic_istream<charT, traits>::set_rdbuf(
&addressof(sb)) is called to install the contained basic_filebuf.
Change [fstream.members] p1 as indicated:
basic_filebuf<charT, traits>* rdbuf() const;-1- Returns: const_cast<basic_filebuf<charT, traits>*>(
&addressof(sb)).
Change [syncstream.osyncstream.overview], class template basic_osyncstream synopsis, as indicated:
[Drafting note: The text shown below assumes the application of the proposed resolution of issue 3127.]
namespace std { template<class charT, class traits, class Allocator> class basic_osyncstream : public basic_ostream<charT, traits> { public: […] // [syncstream.osyncstream.members], member functions void emit(); streambuf_type* get_wrapped() const noexcept; syncbuf_type* rdbuf() const noexcept { return const_cast<syncbuf_type*>(&addressof(sb)); } […] }; }
Change [syncstream.osyncstream.cons] p1 and p4 as indicated:
basic_osyncstream(streambuf_type* buf, const Allocator& allocator);-1- Effects: Initializes sb from buf and allocator. Initializes the base class with basic_ostream<charT, traits>(
-2- […] -3- […]&addressof(sb)).basic_osyncstream(basic_osyncstream&& other) noexcept;-4- Effects: Move constructs the base class and sb from the corresponding subobjects of other, and calls basic_ostream<charT, traits>::set_rdbuf(
-5- […]&addressof(sb)).
[ 2018-11, Adopted in San Diego ]
[ 2018-07-20 Status to Tentatively Ready after five positive votes on the reflector. ]
There are 27 instances of &sb and one instance of &rhs in Clause [input.output], each of which needs to use addressof because the operand has a user-provided template type parameter as an associated class and so the use of unary & is subject to ADL hijacking.
History | |||
---|---|---|---|
Date | User | Action | Args |
2021-02-25 10:48:01 | admin | set | status: wp -> c++20 |
2018-11-12 04:39:29 | admin | set | messages: + msg10199 |
2018-11-12 04:39:29 | admin | set | status: voting -> wp |
2018-10-08 05:13:59 | admin | set | status: ready -> voting |
2018-07-20 21:06:57 | admin | set | messages: + msg10037 |
2018-07-20 21:06:57 | admin | set | status: new -> ready |
2018-06-30 08:19:58 | admin | set | messages: + msg10004 |
2018-06-30 00:00:00 | admin | create |