This commit is contained in:
hsutter 2015-12-21 16:38:42 -08:00
parent 9c93ba6c5f
commit 9e0b9f435e

View File

@ -7360,6 +7360,7 @@ Statement rules:
* [ES.78: Always end a non-empty `case` with a `break`](#Res-break) * [ES.78: Always end a non-empty `case` with a `break`](#Res-break)
* [ES.79: ??? `default`](#Res-default) * [ES.79: ??? `default`](#Res-default)
* [ES.85: Make empty statements visible](#Res-empty) * [ES.85: Make empty statements visible](#Res-empty)
* [ES.86: Avoid modifying loop control variables inside the body of raw for-loops](#Res-loop-counter)
Arithmetic rules: Arithmetic rules:
@ -8611,6 +8612,31 @@ Readability.
Flag empty statements that are not blocks and doesn't "contain" comments. Flag empty statements that are not blocks and doesn't "contain" comments.
### <a name="Res-loop-counter"></a> ES.86: Avoid modifying loop control variables inside the body of raw for-loops
##### Reason
The loop control up front should enable correct reasoning about what is happening inside the loop. Modifying loop counters in both the iteration-expression and inside the body of the loop is a perennial psource of suprises and bugs.
##### Example
for (int i=0; i<10; ++i) {
// no updates to i -- ok
}
for (int i=0; i<10; ++i) {
//
if (/* something */) ++i; // BAD
//
}
##### Enforcement
Flag variables that are potentially updated (have a non-const use) in both the loop control iteration-expression and the loop body.
## ES.expr: Expressions ## ES.expr: Expressions
Expressions manipulate values. Expressions manipulate values.