-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Ulrik Sverdrup
committed
Jan 21, 2015
1 parent
2a7a5fd
commit c10f8e5
Showing
1 changed file
with
57 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
- Start Date: 2015-01-21 | ||
- RFC PR: | ||
- Rust Issue: | ||
|
||
# Summary | ||
|
||
Add the syntax `..` for `std::ops::FullRange`. | ||
|
||
# Motivation | ||
|
||
Range expressions `a..b`, `a..` and `..b` all have dedicated syntax and | ||
produce first-class values. This means that they will be usable and | ||
useful in custom APIs, so for consistency, the fourth slicing range, | ||
`FullRange`, could have its own syntax `..` | ||
|
||
# Detailed design | ||
|
||
`..` will produce a `std::ops::FullRange` value when it is used in an | ||
expression. This means that slicing the whole range of a sliceable | ||
container is written `&foo[..]`. | ||
|
||
We should remove the old `&foo[]` syntax for consistency. Because of | ||
this breaking change, it would be best to change this before Rust 1.0. | ||
|
||
As previously stated, when we have range expressions in the language, | ||
they become convenient to use when stating ranges in an API. | ||
|
||
@Gankro fielded ideas where | ||
methods like for example `.remove(index) -> element` on a collection | ||
could be generalized by accepting either indices or ranges. Today's `.drain()` | ||
could be expressed as `.remove(..)`. | ||
|
||
Matrix or multidimensional array APIs can use the range expressions for | ||
indexing and/or generalized slicing and `..` represents selecting a full axis | ||
in a multidimensional slice, i.e. `(1..3, ..)` slices the first axis and | ||
preserves the second. | ||
|
||
Because of deref coercions, the very common conversions of String or Vec to | ||
slices don't need to use slicing syntax at all, so the change in verbosity from | ||
`[]` to `[..]` is not a concern. | ||
|
||
# Drawbacks | ||
|
||
Removing the slicing syntax `&foo[]` is a breaking change. | ||
|
||
# Alternatives | ||
|
||
* We could add this syntax later, but we would end up with duplicate | ||
slicing functionality using `&foo[]` and `&foo[..]`. | ||
|
||
* `0..` could replace `..` in many use cases (but not for ranges in | ||
ordered maps). | ||
|
||
# Unresolved questions | ||
|
||
Any parsing questions should already be mostly solved because of the | ||
`a..` and `..b` cases. |