diff options
author | alon@honor <none@none> | 2010-10-16 18:23:29 -0700 |
---|---|---|
committer | alon@honor <none@none> | 2010-10-16 18:23:29 -0700 |
commit | 9ebbd0f56793f35b33a9e8410f8573f6a59b71c5 (patch) | |
tree | 48db0273be866df5b5b219e5661ccd1b12431133 /src/jsifier.js | |
parent | 81eafc4df3de74e5366891476506bf3f6b0db61d (diff) |
steal branch2s into multiples; 1% speedup
Diffstat (limited to 'src/jsifier.js')
-rw-r--r-- | src/jsifier.js | 38 |
1 files changed, 32 insertions, 6 deletions
diff --git a/src/jsifier.js b/src/jsifier.js index 0395b5f9..13d2642d 100644 --- a/src/jsifier.js +++ b/src/jsifier.js @@ -348,12 +348,35 @@ function JSify(data) { ret += indent + ((block.entry in usedLabels) ? '' : (block.entry+':')) + ' do { \n'; multipleIdent = ' '; } - block.entryLabels.forEach(function(entryLabel) { - ret += indent + multipleIdent + (first ? '' : 'else ') + 'if (__label__ == ' + getLabelId(entryLabel.ident) + ') {\n'; - ret += walkBlock(entryLabel.block, indent + ' ' + multipleIdent); - ret += indent + multipleIdent + '}\n'; - first = false; - }); + var stolen = block.stolenCondition; + if (stolen) { + function getActualLabelId(labelId) { + return labelId.split('|').slice(-1)[0]; + } + var intendedTrueLabel = stolen.labelTrue; + assert(block.entryLabels.length <= 2); + [stolen.labelTrue, stolen.labelFalse].forEach(function(entry) { + var branch = makeBranch(entry); + entryLabel = block.entryLabels.filter(function(possible) { return possible.ident === getActualLabelId(entry) })[0]; + if (branch.length < 5 && !entryLabel) return; + //ret += indent + multipleIdent + (first ? '' : 'else ') + + // 'if (' + (entry == intendedTrueLabel ? '' : '!') + stolen.ident + ')' + ' {\n'; + ret += indent + multipleIdent + (first ? 'if (' + (entry == intendedTrueLabel ? '' : '!') + stolen.ident + ')' : 'else') + ' {\n'; + ret += indent + multipleIdent + ' ' + branch + '\n'; + if (entryLabel) { + ret += walkBlock(entryLabel.block, indent + ' ' + multipleIdent); + } + ret += indent + multipleIdent + '}\n'; + first = false; + }); + } else { + block.entryLabels.forEach(function(entryLabel) { + ret += indent + multipleIdent + (first ? '' : 'else ') + 'if (__label__ == ' + getLabelId(entryLabel.ident) + ') {\n'; + ret += walkBlock(entryLabel.block, indent + ' ' + multipleIdent); + ret += indent + multipleIdent + '}\n'; + first = false; + }); + } if (GUARD_LABELS) { ret += indent + multipleIdent + 'else { throw "Bad multiple branching: " + __label__ + " : " + (new Error().stack); }\n'; } @@ -477,12 +500,15 @@ function JSify(data) { } }); + makeFuncLineZyme('deleted', function(item) { return ';' }); + var LABEL_IDs = {}; var LABEL_ID_COUNTER = 0; function getLabelId(label) { label = label.substr(1); if (label === 'entry') return '-1'; if (label === parseInt(label)) return label; // clang + //return '"' + label + '"'; // XXX debugging label = toNiceIdent(label); if (label in LABEL_IDs) return LABEL_IDs[label]; return LABEL_IDs[label] = LABEL_ID_COUNTER ++; |