Rollup merge of #70904 - LukasKalbertodt:stabilize-seek-convenience, r=m-ou-se

Stabilize `Seek::stream_position` (feature `seek_convenience`)

Tracking issue: #59359

Unresolved questions from tracking issue:
- "Override `stream_len` for `File`?" → we can do that in the future, this does not block stabilization.
- "Rename to `len` and `position`?" → as noted in the tracking issue, both of these shorter names have problems (`len` is usually a cheap getter, `position` clashes with `Cursor`). I do think the current names are perfectly fine.
- "Rename `stream_position` to `tell`?" → as mentioned in [the comment bringing this up](https://github.com/rust-lang/rust/issues/59359#issuecomment-559541545), `stream_position` is more descriptive. I don't think `tell` would be a good name.

What remains to decide, is whether or not adding these methods is worth it.
This commit is contained in:
Yuki Okushi 2021-01-28 15:09:00 +09:00 committed by GitHub
commit 025a850d21
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 3 additions and 5 deletions

View File

@ -410,7 +410,6 @@ impl<R: Seek> Seek for BufReader<R> {
/// # Example /// # Example
/// ///
/// ```no_run /// ```no_run
/// #![feature(seek_convenience)]
/// use std::{ /// use std::{
/// io::{self, BufRead, BufReader, Seek}, /// io::{self, BufRead, BufReader, Seek},
/// fs::File, /// fs::File,

View File

@ -1671,7 +1671,7 @@ pub trait Seek {
/// # Example /// # Example
/// ///
/// ```no_run /// ```no_run
/// #![feature(seek_convenience)] /// #![feature(seek_stream_len)]
/// use std::{ /// use std::{
/// io::{self, Seek}, /// io::{self, Seek},
/// fs::File, /// fs::File,
@ -1685,7 +1685,7 @@ pub trait Seek {
/// Ok(()) /// Ok(())
/// } /// }
/// ``` /// ```
#[unstable(feature = "seek_convenience", issue = "59359")] #[unstable(feature = "seek_stream_len", issue = "59359")]
fn stream_len(&mut self) -> Result<u64> { fn stream_len(&mut self) -> Result<u64> {
let old_pos = self.stream_position()?; let old_pos = self.stream_position()?;
let len = self.seek(SeekFrom::End(0))?; let len = self.seek(SeekFrom::End(0))?;
@ -1706,7 +1706,6 @@ pub trait Seek {
/// # Example /// # Example
/// ///
/// ```no_run /// ```no_run
/// #![feature(seek_convenience)]
/// use std::{ /// use std::{
/// io::{self, BufRead, BufReader, Seek}, /// io::{self, BufRead, BufReader, Seek},
/// fs::File, /// fs::File,
@ -1723,7 +1722,7 @@ pub trait Seek {
/// Ok(()) /// Ok(())
/// } /// }
/// ``` /// ```
#[unstable(feature = "seek_convenience", issue = "59359")] #[stable(feature = "seek_convenience", since = "1.51.0")]
fn stream_position(&mut self) -> Result<u64> { fn stream_position(&mut self) -> Result<u64> {
self.seek(SeekFrom::Current(0)) self.seek(SeekFrom::Current(0))
} }