std::strstreambuf:: seekpos
|
protected
:
virtual
pos_type seekpos
(
pos_type sp,
|
(obsolète en C++98)
(supprimé en C++26) |
|
Repositionne std::basic_streambuf::gptr et/ou std::basic_streambuf::pptr , si possible, à la position indiquée par sp .
Si
std::ios_base::in
est défini dans
which
, tente de repositionner
gptr()
(le pointeur suivant dans la zone de lecture). Si
std::ios_base::out
est défini dans
which
, tente de repositionner
pptr()
(le pointeur suivant dans la zone d'écriture). Si aucun bit n'est défini dans
which
, l'opération échoue.
Chaque pointeur suivant est repositionné comme suit :
- Si le pointeur suivant est nul, l'opération échoue.
-
Sinon, le nouvel offset
newoff
(de type
off_type) est déterminé en appelant sp. offset ( ) . Si newoff est négatif, hors des limites du tampon, ou invalide, l'opération échoue. - Sinon, le pointeur suivant est assigné comme par gptr ( ) = eback ( ) + newoff ou pptr ( ) = pbase ( ) + newoff .
Table des matières |
Paramètres
| sp | - |
position du flux, telle qu'obtenue par
seekoff()
ou
seekpos()
|
||||||
| which | - |
définit si la séquence d'entrée, la séquence de sortie, ou les deux sont affectées. Il peut s'agir d'une ou d'une combinaison des constantes suivantes :
|
Valeur de retour
L'offset résultant converti en
pos_type
en cas de succès ou
pos_type
(
off_type
(
-
1
)
)
en cas d'échec.
Notes
seekpos()
est appelée par
std::basic_streambuf::pubseekpos()
, qui est appelée par les versions à un seul argument de
std::basic_istream::seekg()
et
std::basic_ostream::seekp()
.
Exemple
#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); }
Sortie :
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.
Rapports de défauts
Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.
| DR | Appliqué à | Comportement publié | Comportement corrigé |
|---|---|---|---|
| LWG 55 | C++98 |
seekpos
renvoyait une position de flux
invalide non définie en cas d'échec |
pos_type
(
off_type
(
-
1
)
)
est renvoyé en cas d'échec |
Voir aussi
|
[virtual]
|
repositionne le pointeur suivant dans la séquence d'entrée, la séquence de sortie, ou les deux, en utilisant l'adressage relatif
(fonction membre protégée virtuelle) |
|
[virtual]
|
repositionne le pointeur suivant dans la séquence d'entrée, la séquence de sortie, ou les deux en utilisant l'adressage absolu
(fonction membre protégée virtuelle de
std::basic_streambuf<CharT,Traits>
)
|
|
[virtual]
|
repositionne le pointeur suivant dans la séquence d'entrée, la séquence de sortie, ou les deux en utilisant l'adressage absolu
(fonction membre protégée virtuelle de
std::basic_stringbuf<CharT,Traits,Allocator>
)
|
|
[virtual]
|
repositionne la position du fichier, en utilisant l'adressage absolu
(fonction membre protégée virtuelle de
std::basic_filebuf<CharT,Traits>
)
|