Namespaces
Variants
Views
Actions

std::ws

From cppreference.com
< cpp‎ | io‎ | manip
Revision as of 15:40, 5 April 2013 by SuperBoi45 (Talk | contribs)

Defined in header <istream>
template< class CharT, class Traits >
std::basic_istream<CharT,Traits>& ws( std::basic_istream<CharT, Traits>& is );

Discards leading whitespace from an input stream.

Behaves as an UnformattedInputFunction, except that is.gcount() is not modified. After constructing and checking the sentry object, extracts characters from the stream and discards them until any one of the following conditions occurs:

  • end of file condition occurs in the input sequence (in which case the function calls setstate(eofbit) but does not set failbit.
  • the next available character c in the input sequence is not whitespace as determined by std::isspace(c, is.getloc()). The non-whitespace character is not extracted.

This is an input-only I/O manipulator, it may be called with an expression such as in << std::ws for any in of type std::basic_istream.

Contents

Parameters

is - reference to input stream

Return value

is (reference to the stream after extraction of consecutive whitespace)

Example

#include <iostream>
#include <sstream>
 
int main()
{
    std::istringstream s("     this is a test");
    std::string line;
    s >> std::ws;
    getline(s, line);
    std::cout << "ws + getline returns: \"" << line << "\"\n";
}

Output:

ws + getline returns: "this is a test"

See also

Template:cpp/io/basic istream/dcl list ignore