]> git.lizzy.rs Git - rust.git/commitdiff
Update description to reflect language changes
authorZach Pomerantz <zmp@umich.edu>
Wed, 11 Jun 2014 00:36:02 +0000 (17:36 -0700)
committerZach Pomerantz <zmp@umich.edu>
Wed, 11 Jun 2014 00:36:02 +0000 (17:36 -0700)
Previously, the type system's restrictions on borrowing were summarized as

> The previous example showed that the type system forbids any borrowing of owned boxes found in aliasable, mutable memory

This did not jive with the example, which allowed mutations so long as the borrowed reference had been returned. Also, the language has changed to no longer allow aliasable mutable locations. This changes the summary to read

> The previous example showed that the type system forbids mutations of owned boxed values while they are being borrowed. In general, the type system also forbids borrowing a value as mutable if it is already being borrowed - either as a mutable reference or an immutable one.

This adds more general information for the experienced reader as well, to offer a more complete understanding.

src/doc/guide-lifetimes.md

index 65f37031674c7caf637b6c067c5179a7fe4af95c..552ecaf49cd71de248e2ac17b4d06eaea43b6d9a 100644 (file)
@@ -275,8 +275,10 @@ invalidate the pointer `owner_age`.
 
 # Borrowing and enums
 
-The previous example showed that the type system forbids any borrowing
-of owned boxes found in aliasable, mutable memory. This restriction
+The previous example showed that the type system forbids any mutations
+of owned boxed values while they are being borrowed. In general, the type
+system also forbids borrowing a value as mutable if it is already being
+borrowed - either as a mutable reference or an immutable one. This restriction
 prevents pointers from pointing into freed memory. There is one other
 case where the compiler must be very careful to ensure that pointers
 remain valid: pointers into the interior of an `enum`.