Skip to content
This repository has been archived by the owner on Mar 23, 2024. It is now read-only.

Commit

Permalink
[Performance] Fix spaces between assert
Browse files Browse the repository at this point in the history
  • Loading branch information
mdevils committed Apr 12, 2016
1 parent 83a1647 commit b4bf41a
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 3 deletions.
23 changes: 21 additions & 2 deletions lib/js-file.js
Original file line number Diff line number Diff line change
Expand Up @@ -632,8 +632,8 @@ JsFile.prototype = {
if (tokenBefore === tokenAfter) {
return true;
}
tokenBefore = tokenBefore.getLastToken();
tokenAfter = tokenAfter.getFirstToken();
tokenBefore = tokenBefore instanceof Token ? tokenBefore : tokenBefore.getLastToken();
tokenAfter = tokenAfter instanceof Token ? tokenAfter : tokenAfter.getFirstToken();
var currentToken = tokenBefore;
while (currentToken) {
if (currentToken === tokenAfter) {
Expand All @@ -647,6 +647,25 @@ JsFile.prototype = {
return false;
},

getDistanceBetween(tokenBefore, tokenAfter) {
if (tokenBefore === tokenAfter) {
return 0;
}
tokenBefore = tokenBefore instanceof Token ? tokenBefore : tokenBefore.getLastToken();
tokenAfter = tokenAfter instanceof Token ? tokenAfter : tokenAfter.getFirstToken();
var currentToken = tokenBefore.getNextToken();
var distance = 0;
while (currentToken) {
if (currentToken === tokenAfter) {
break;
}

distance += currentToken.getSourceCodeLength();
currentToken = currentToken.getNextToken();
}
return distance;
},

/**
* Returns array of source lines for the file with comments removed.
*
Expand Down
2 changes: 1 addition & 1 deletion lib/token-assert.js
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ TokenAssert.prototype.spacesBetween = function(options) {
});
}.bind(this);

var spacesBetween = Math.abs(nextToken.getRange()[0] - token.getRange()[1]);
var spacesBetween = this._file.getDistanceBetween(token, nextToken);
if (atLeast !== undefined && spacesBetween < atLeast) {
emitError('at least', atLeast);
} else if (atMost !== undefined && spacesBetween > atMost) {
Expand Down

0 comments on commit b4bf41a

Please sign in to comment.