diff options
| author | dgp@users.sourceforge.net <dgp> | 2014-01-24 21:45:39 (GMT) |
|---|---|---|
| committer | dgp@users.sourceforge.net <dgp> | 2014-01-24 21:45:39 (GMT) |
| commit | 94cd6ec9a73e48c570d021ee740c26ed12d520c9 (patch) | |
| tree | 47806a38c9d445ea76ce0943646a49caa819a7fe /generic/tclIO.c | |
| parent | dd8ffb8d31e0a5c58cce9df30df8ce76cec5a21c (diff) | |
| parent | 9f7312618ef1e45aed3306e7f8c4bbd23ed1e08b (diff) | |
| download | tcl-94cd6ec9a73e48c570d021ee740c26ed12d520c9.zip tcl-94cd6ec9a73e48c570d021ee740c26ed12d520c9.tar.gz tcl-94cd6ec9a73e48c570d021ee740c26ed12d520c9.tar.bz2 | |
In WriteChars(), eliminate the copy step through a staging buffer when
it is not required for channel translation.
Diffstat (limited to 'generic/tclIO.c')
| -rw-r--r-- | generic/tclIO.c | 22 |
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; |
