diff options
| author | Matthew Piziak <matthew.piziak@gmail.com> | 2016-08-11 19:42:17 -0400 |
|---|---|---|
| committer | Matthew Piziak <matthew.piziak@gmail.com> | 2016-08-12 12:12:54 -0400 |
| commit | e173ead68458da5c4cb241f3d105abc87c529071 (patch) | |
| tree | a0a9f980c2a0d79b114f65d96c1d31a5929ce2c4 /src/libstd | |
| parent | 11f880588791930cb130071c2cb972fc3c3354ed (diff) | |
| download | rust-e173ead68458da5c4cb241f3d105abc87c529071.tar.gz rust-e173ead68458da5c4cb241f3d105abc87c529071.zip | |
provide additional justification for array interface design
Explain why Rust does not implement traits for large arrays. Explain why most methods are implemented on slices rather than arrays.
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/primitive_docs.rs | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/libstd/primitive_docs.rs b/src/libstd/primitive_docs.rs index de891ea8918..fc838768322 100644 --- a/src/libstd/primitive_docs.rs +++ b/src/libstd/primitive_docs.rs @@ -269,13 +269,18 @@ mod prim_pointer { } /// - `Borrow`, `BorrowMut` /// - `Default` /// +/// This limitation to `N in 0..33` exists because Rust does not yet support +/// generics over the size of an array type. `[Foo; 3]` and `[Bar; 3]` are +/// instances of same generic type `[T; 3]`, but `[Foo; 3]` and `[Foo; 5]` are +/// entirely different types. As a stopgap, trait implementations are +/// statically generated for `N in 0..33`. +/// /// Arrays coerce to [slices (`[T]`)][slice], so their methods can be called on -/// arrays. +/// arrays. Slices are dynamic and do not coerce to arrays; consequently more +/// methods are defined on `slice` where they support both types. /// /// [slice]: primitive.slice.html /// -/// Rust does not currently support generics over the size of an array type. -/// /// # Examples /// /// ``` |
