File tree Expand file tree Collapse file tree 2 files changed +9
-3
lines changed Expand file tree Collapse file tree 2 files changed +9
-3
lines changed Original file line number Diff line number Diff line change 1
1
---
2
2
refs/heads/master: cd6f24f9d14ac90d167386a56e7a6ac1f0318195
3
3
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4
- refs/heads/snap-stage3: 42095221f496a4df47c3aee502a3509d969d268e
4
+ refs/heads/snap-stage3: 08275826ca44e736dab4925ea0450aeb731f1d80
5
5
refs/heads/try: d324a424d8f84b1eb049b12cf34182bda91b0024
6
6
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
7
7
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
Original file line number Diff line number Diff line change @@ -562,7 +562,12 @@ Structs are quite similar to C structs and are even laid out the same way in
562
562
memory (so you can read from a Rust struct in C, and vice-versa). Use the dot
563
563
operator to access struct fields, as in ` mypoint.x ` .
564
564
565
- Fields that you want to mutate must be explicitly marked ` mut ` .
565
+ Inherited mutability means that any field of a struct may be mutable, if the
566
+ struct is in a mutable slot (or a field of a struct in a mutable slot, and
567
+ so forth).
568
+
569
+ A struct that is not mutable due to inherited mutability may declare some
570
+ of its fields nevertheless mutable, using the ` mut ` keyword.
566
571
567
572
~~~~
568
573
struct Stack {
@@ -572,7 +577,8 @@ struct Stack {
572
577
~~~~
573
578
574
579
With a value of such a type, you can do ` mystack.head += 1 ` . If ` mut ` were
575
- omitted from the type, such an assignment would result in a type error.
580
+ omitted from the type, such an assignment to a struct without inherited
581
+ mutability would result in a type error.
576
582
577
583
` match ` patterns destructure structs. The basic syntax is
578
584
` Name { fieldname: pattern, ... } ` :
You can’t perform that action at this time.
0 commit comments