summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorferrieux@users.sourceforge.net <ferrieux>2014-09-27 20:28:47 (GMT)
committerferrieux@users.sourceforge.net <ferrieux>2014-09-27 20:28:47 (GMT)
commit5f55e639be0620a51dc2496ee42f9bf6dc5f55f7 (patch)
tree894a164f60db049455d487ab557fb6f2a02cc2ad
parent2d826a696acf94c7c54e9649ea0a7ff1859b2f08 (diff)
downloadtcl-5f55e639be0620a51dc2496ee42f9bf6dc5f55f7.zip
tcl-5f55e639be0620a51dc2496ee42f9bf6dc5f55f7.tar.gz
tcl-5f55e639be0620a51dc2496ee42f9bf6dc5f55f7.tar.bz2
Applied patch by Andreas Leitgeb so that [string cat]'s compiled bytecode optimally groups args by 255 for INSTR_STR_CONCAT1.
-rw-r--r--generic/tclCompCmdsSZ.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/generic/tclCompCmdsSZ.c b/generic/tclCompCmdsSZ.c
index 2b83fd2..617a520 100644
--- a/generic/tclCompCmdsSZ.c
+++ b/generic/tclCompCmdsSZ.c
@@ -322,8 +322,8 @@ TclCompileStringCatCmd(
CompileWord(envPtr, wordTokenPtr, interp, i);
numArgs ++;
if (numArgs >= 254) { /* 254 to take care of the possible +1 of "folded" above */
- TclEmitInstInt1(INST_STR_CONCAT1, 254, envPtr);
- numArgs -= 253; /* concat pushes 1 obj, the result */
+ TclEmitInstInt1(INST_STR_CONCAT1, numArgs, envPtr);
+ numArgs = 1; /* concat pushes 1 obj, the result */
}
}
wordTokenPtr = TokenAfter(wordTokenPtr);