Boolean: Some code and comment cleanup.

This commit is contained in:
Jürg Lehni 2017-02-26 01:11:33 +01:00
parent 5c86330d6e
commit 32db1eb005

View file

@ -754,7 +754,6 @@ PathItem.inject(new function() {
*/ */
function tracePaths(segments, operator) { function tracePaths(segments, operator) {
var paths = [], var paths = [],
branches = [],
starts; starts;
function isValid(seg) { function isValid(seg) {
@ -863,6 +862,7 @@ PathItem.inject(new function() {
path = null, path = null,
finished = false, finished = false,
closed = true, closed = true,
branches = [],
branch, branch,
visited, visited,
handleIn; handleIn;
@ -928,8 +928,8 @@ PathItem.inject(new function() {
if (cross) if (cross)
seg = other; seg = other;
// If an invalid segment is encountered, go back to the last // If an invalid segment is encountered, go back to the last
// crossing and try the other direction by not crossing at the // crossing and try other possible crossings, as well as not
// intersection. // crossing at the branch's root.
if (!isValid(seg)) { if (!isValid(seg)) {
// Remove the already added segments, and mark them as not // Remove the already added segments, and mark them as not
// visited so they become available again as options. // visited so they become available again as options.
@ -938,11 +938,10 @@ PathItem.inject(new function() {
visited[j]._visited = false; visited[j]._visited = false;
} }
visited.length = 0; visited.length = 0;
// Go back to the branch's root segment at which the // Go back to the branch's root segment where the crossing
// crossing happened, and try other crossings. // happened, and try other crossings. Note that this also
// NOTE: This also tries the root segment without crossing, // tests the root segment without crossing as it is added to
// because it is added to the list of crossings when the // the list of crossings when the branch is created above.
// branch is created above.
do { do {
seg = branch && branch.crossings.shift(); seg = branch && branch.crossings.shift();
if (!seg) { if (!seg) {
@ -983,8 +982,6 @@ PathItem.inject(new function() {
if (path.getArea() !== 0) { if (path.getArea() !== 0) {
paths.push(path); paths.push(path);
} }
// Clear branches.
branches = [];
} }
} }
return paths; return paths;