summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordgp <dgp@users.sourceforge.net>2014-01-24 21:45:39 (GMT)
committerdgp <dgp@users.sourceforge.net>2014-01-24 21:45:39 (GMT)
commitb6f970f792d9528b3ea467025e95d04e4b1b19f4 (patch)
tree47806a38c9d445ea76ce0943646a49caa819a7fe
parentc7ed456462861ff7aaef003c61d8fc526466017d (diff)
parent8af83eeffaedc4ee57ade8026a6f7166b86306d6 (diff)
downloadtcl-b6f970f792d9528b3ea467025e95d04e4b1b19f4.zip
tcl-b6f970f792d9528b3ea467025e95d04e4b1b19f4.tar.gz
tcl-b6f970f792d9528b3ea467025e95d04e4b1b19f4.tar.bz2
In WriteChars(), eliminate the copy step through a staging buffer when
it is not required for channel translation.
-rw-r--r--generic/tclIO.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/generic/tclIO.c b/generic/tclIO.c
index f1d8909..13494ca 100644
--- a/generic/tclIO.c
+++ b/generic/tclIO.c
@@ -3787,16 +3787,17 @@ WriteChars(
consumedSomething = 1;
while (consumedSomething && (srcLen + savedLF + endEncoding > 0)) {
consumedSomething = 0;
- stage = statePtr->outputStage;
- stageMax = statePtr->bufSize;
- stageLen = stageMax;
-
- toWrite = stageLen;
- if (toWrite > srcLen) {
- toWrite = srcLen;
- }
if (translate) {
+ stage = statePtr->outputStage;
+ stageMax = statePtr->bufSize;
+ stageLen = stageMax;
+
+ toWrite = stageLen;
+ if (toWrite > srcLen) {
+ toWrite = srcLen;
+ }
+
if (savedLF) {
/*
* A '\n' was left over from last call to TranslateOutputEOL()
@@ -3822,8 +3823,9 @@ WriteChars(
stageLen = stageMax;
}
} else {
- memcpy(stage, src, toWrite);
- stageLen = toWrite;
+ stage = (char *) src;
+ stageLen = srcLen;
+ toWrite = stageLen;
}
src += toWrite;
srcLen -= toWrite;