Namespaces
Variants

std::strstreambuf:: seekpos

From cppreference.net
protected :

virtual pos_type seekpos ( pos_type sp,
std:: ios_base :: openmode which =

std:: ios_base :: in | std:: ios_base :: out ) ;
(obsoleto en C++98)
(eliminado en C++26)

Reposiciona std::basic_streambuf::gptr y/o std::basic_streambuf::pptr , si es posible, a la posición indicada por sp .

Si std::ios_base::in está establecido en which , intenta reposicionar gptr() (el siguiente puntero en el área de obtención). Si std::ios_base::out está establecido en which , intenta reposicionar pptr() (el siguiente puntero en el área de escritura). Si ningún bit está establecido en which , la operación falla.

Cada puntero siguiente se reposiciona de la siguiente manera:

  • Si el siguiente puntero es nulo, la operación falla.
  • De lo contrario, el nuevo desplazamiento newoff (de tipo off_type ) se determina llamando a sp. offset ( ) . Si newoff es negativo, está fuera de los límites del búfer o es inválido, la operación falla.
  • De lo contrario, el siguiente puntero se asigna como si fuera mediante gptr ( ) = eback ( ) + newoff o pptr ( ) = pbase ( ) + newoff .

Contenidos

Parámetros

sp - posición del flujo, como una obtenida por seekoff() o seekpos()
which - define si la secuencia de entrada, la secuencia de salida, o ambas se ven afectadas. Puede ser una o una combinación de las siguientes constantes:
Constante Explicación
in afecta la secuencia de entrada
out afecta la secuencia de salida

Valor de retorno

El desplazamiento resultante convertido a pos_type en caso de éxito o pos_type ( off_type ( - 1 ) ) en caso de fallo.

Notas

seekpos() es llamado por std::basic_streambuf::pubseekpos() , que es llamado por las versiones de un solo argumento de std::basic_istream::seekg() y std::basic_ostream::seekp() .

Ejemplo

#include <cstring>
#include <iostream>
#include <strstream>
struct mybuf : std::strstreambuf
{
    mybuf(const char* str) : std::strstreambuf(str, std::strlen(str)) {}
    pos_type seekpos(pos_type sp, std::ios_base::openmode which)
    {
        std::cout << "Before seekpos(" << sp << "), size of the get area is "
                  << egptr() - eback() << " with "
                  << egptr() - gptr() << " read positions available.\n";
        pos_type rc = std::strstreambuf::seekpos(sp, which);
        std::cout << "seekpos() returns " << rc << ".\nAfter the call, "
                  << "size of the get area is "
                  << egptr() - eback() << " with "
                  << egptr() - gptr() << " read positions available.\n";
        return rc;
    }
};
int main()
{
    mybuf buf("12345");
    std::iostream stream(&buf);
    stream.seekg(2);
}

Salida:

Before seekpos(2), size of the get area is 5 with 5 read positions available.
seekpos() returns 2.
After the call, size of the get area is 5 with 3 read positions available.

Informes de defectos

Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.

DR Aplicado a Comportamiento publicado Comportamiento correcto
LWG 55 C++98 seekpos retornaba una posición de flujo
inválida indefinida en caso de fallo
pos_type ( off_type ( - 1 ) )
se retorna en caso de fallo

Véase también

[virtual]
reposiciona el siguiente puntero en la secuencia de entrada, secuencia de salida, o ambas, usando direccionamiento relativo
(función miembro protegida virtual)
[virtual]
reposiciona el siguiente puntero en la secuencia de entrada, secuencia de salida, o ambas usando direccionamiento absoluto
(función miembro protegida virtual de std::basic_streambuf<CharT,Traits> )
[virtual]
reposiciona el siguiente puntero en la secuencia de entrada, secuencia de salida, o ambas usando direccionamiento absoluto
(función miembro protegida virtual de std::basic_stringbuf<CharT,Traits,Allocator> )
[virtual]
reposiciona la posición del archivo, usando direccionamiento absoluto
(función miembro protegida virtual de std::basic_filebuf<CharT,Traits> )