std::quoted
| Defined in header <iomanip>
|
||
| template< class CharT > /*unspecified*/ quoted( const CharT* s, |
(1) | (since C++14) |
| template< class CharT, class Traits, class Allocator > /*unspecified*/ quoted( const std::basic_string<CharT, Traits, Allocator>& s, |
(2) | (since C++14) |
| template< class CharT, class Traits> /*unspecified*/ quoted( std::basic_string_view<CharT, Traits> s, |
(3) | (since C++17) |
| template< class CharT, class Traits, class Allocator > /*unspecified*/ quoted( std::basic_string<CharT, Traits, Allocator>& s, |
(4) | (since C++14) |
Allows insertion and extraction of quoted strings, such as the ones found in CSV or XML.
When used in an expression out << quoted(s, delim, escape), where out is an output stream with char_type equal to CharT and, for overloads 2-4, traits_type equal to Traits, behaves as a FormattedOutputFunction, which inserts into out a sequence of characters seq constructed as follows:
delim is added to the sequences, except if the next character to output equals delim or equals escape (as determined by the stream's traits_type::eq), then first appends an extra copy of escapedelim is appended to seq once moreThen, if seq.size() < out.width(), adds out.width()-seq.size() copies of the fill character out.fill() either at the end of the sequence (if ios_base::left is set in out.flags()) or at the beginning of the sequence (in all other cases).
Finally, outputs each character from the resulting sequence as if by calling out.rdbuf()->sputn(seq, n), where n=std::max(out.width(), seq.size()) and out.width(0) to cancel the effects of std::setw, if any.
in is an input stream with char_type equal to CharT and traits_type equal to Traits, extracts characters from in, using std::basic_istream::operator>>, according to the following rules:delim (as determined by the stream's traits_type::eq), then simply performs in >> s.in and appends them to s, except that whenever an escape character is extracted, it is ignored and the next character is appended to s. Extraction stops when !in == true or when an unescaped delim character is found.delim character.Parameters
| s | - | the string to insert or extract |
| delim | - | the character to use as the delimiter, defaults to "
|
| escape | - | the character to use as the escape character, defaults to \
|
Return value
Returns an object of unspecified type such that the described behavior takes place.
Exceptions
Throws std::ios_base::failure if operator>> or operator<< throws.
Notes
Feature testing macro: __cpp_lib_quoted_string_io
Example
#include <iostream> #include <iomanip> #include <sstream> int main() { std::stringstream ss; std::string in = "String with spaces, and embedded \"quotes\" too"; std::string out; auto show = [&](const auto& what) { &what == &in ? std::cout << "read in [" << in << "]\n" << "stored as [" << ss.str() << "]\n" : std::cout << "written out [" << out << "]\n\n"; }; ss << quoted(in); // uses ADL, so `std::` can be omitted show(in); ss >> quoted(out); show(out); ss.str(""); // clear the stream buffer in = "String with spaces, and embedded $quotes$ too"; const char delim {'$'}; const char escape {'%'}; ss << std::quoted(in, delim, escape); show(in); ss >> std::quoted(out, delim, escape); show(out); }
Output:
read in [String with spaces, and embedded "quotes" too] stored as ["String with spaces, and embedded \"quotes\" too"] written out [String with spaces, and embedded "quotes" too] read in [String with spaces, and embedded $quotes$ too] stored as [$String with spaces, and embedded %$quotes%$ too$] written out [String with spaces, and embedded $quotes$ too]