std::strstreambuf:: seekpos
|
protected
:
virtual
pos_type seekpos
(
pos_type sp,
|
(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:
|
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>
)
|