Scroll to navigation

std::basic_ostream::seekp(3) C++ Standard Libary std::basic_ostream::seekp(3)

NAME

std::basic_ostream::seekp - std::basic_ostream::seekp

Synopsis


basic_ostream& seekp( pos_type pos ); (1)
basic_ostream& seekp( off_type off, std::ios_base::seekdir dir ); (2)


Sets the output position indicator of the current associated streambuf object.


Behaves as UnformattedOutputFunction (except without actually (since C++11)
performing output). After constructing and checking the sentry object,


1) if fail() != true, sets the output position indicator to absolute (relative to
the beginning of the file) value pos by calling rdbuf()->pubseekpos(pos,
std::ios_base::out). In case of failure, calls setstate(std::ios_base::failbit).
2) if fail() != true, sets the output position indicator to offset off relative to
dir by calling rdbuf()->pubseekoff(off, dir, std::ios_base::out). In case of
failure, calls setstate(std::ios_base::failbit).

Parameters


pos - absolute position to set the output position indicator to
off - relative position (positive or negative) to set the output position indicator
to
defines base position to apply the relative offset to. It can be one of the
following constants:


dir - Constant Explanation
beg the beginning of a stream
end the ending of a stream
cur the current position of stream position indicator

Return value


*this

Exceptions


1,2) May throw std::ios_base::failure in case of failure, if exceptions() & failbit
!= 0.

Example

// Run this code


#include <iostream>
#include <sstream>


int main()
{
std::ostringstream os("hello, world");
os.seekp(7);
os << 'W';
os.seekp(0, std::ios_base::end);
os << '!';
os.seekp(0);
os << 'H';
std::cout << os.str() << '\n';
}

Output:


Hello, World!


Defect reports


The following behavior-changing defect reports were applied retroactively to
previously published C++ standards.


DR Applied to Behavior as published Correct behavior
LWG 129 C++98 there was no way to indicate a failure sets failbit on failure
LWG 136 C++98 seekp could set the input stream only sets the output
stream
LWG 537 C++98 1. the type of pos was pos_type& 1. corrected to pos_type
2. the type of off was off_type& 2. corrected to off_type
LWG 2341 C++98 the resolution of LWG issue 129 for restored
overload (2) was removed

See also


tellp returns the output position indicator
(public member function)
tellg returns the input position indicator
(public member function of std::basic_istream<CharT,Traits>)
seekg sets the input position indicator
(public member function of std::basic_istream<CharT,Traits>)

2024.06.10 http://cppreference.com