about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorMatthew Piziak <matthew.piziak@gmail.com>2016-08-11 19:42:17 -0400
committerMatthew Piziak <matthew.piziak@gmail.com>2016-08-12 12:12:54 -0400
commite173ead68458da5c4cb241f3d105abc87c529071 (patch)
treea0a9f980c2a0d79b114f65d96c1d31a5929ce2c4 /src/libstd
parent11f880588791930cb130071c2cb972fc3c3354ed (diff)
downloadrust-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.rs11
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
 ///
 /// ```