Browse Source

Added a call to checkForReads in computed member expressions. Tests pass.

contingency-plan
Oskar Segersvärd 10 years ago
parent
commit
7c9bba40e6
  1. 14
      src/Statement.js

14
src/Statement.js

@ -175,10 +175,24 @@ export default class Statement {
} }
checkForWrites ( scope, node ) { checkForWrites ( scope, node ) {
const parent = node;
const addNode = ( node, isAssignment ) => { const addNode = ( node, isAssignment ) => {
let depth = 0; // determine whether we're illegally modifying a binding or namespace let depth = 0; // determine whether we're illegally modifying a binding or namespace
while ( node.type === 'MemberExpression' ) { while ( node.type === 'MemberExpression' ) {
// In a situation like that below, make sure the assignments
// depend on `a` and `b`.
//
// var a = 1, b = 0;
//
// arr[a] = arr[b] = true;
//
if ( node.computed ) {
this.checkForReads( scope, node.property, parent, true );
}
node = node.object; node = node.object;
depth += 1; depth += 1;
} }

Loading…
Cancel
Save