diff options
| author | dgp <dgp@users.sourceforge.net> | 2016-06-22 18:59:18 (GMT) |
|---|---|---|
| committer | dgp <dgp@users.sourceforge.net> | 2016-06-22 18:59:18 (GMT) |
| commit | a9aed18760696a33af72db20fc32081d7f3c1c61 (patch) | |
| tree | b97fbed9c51a7e9e72547e8aeed858b08387809e /generic/tclUtil.c | |
| parent | 50dbacbaf0ff59f71412f0c272a8d78dc33aff52 (diff) | |
| parent | 5207d2fe71df636d14b4416e65fd051e3669517b (diff) | |
| download | tcl-a9aed18760696a33af72db20fc32081d7f3c1c61.zip tcl-a9aed18760696a33af72db20fc32081d7f3c1c61.tar.gz tcl-a9aed18760696a33af72db20fc32081d7f3c1c61.tar.bz2 | |
merge trunk
Diffstat (limited to 'generic/tclUtil.c')
| -rw-r--r-- | generic/tclUtil.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/generic/tclUtil.c b/generic/tclUtil.c index 08fc735..9c86839 100644 --- a/generic/tclUtil.c +++ b/generic/tclUtil.c @@ -2633,7 +2633,19 @@ Tcl_DStringAppend( memcpy(newString, dsPtr->string, (size_t) dsPtr->length); dsPtr->string = newString; } else { + int offset = -1; + + /* See [16896d49fd] */ + if (bytes >= dsPtr->string + && bytes <= dsPtr->string + dsPtr->length) { + offset = bytes - dsPtr->string; + } + dsPtr->string = ckrealloc(dsPtr->string, dsPtr->spaceAvl); + + if (offset >= 0) { + bytes = dsPtr->string + offset; + } } } @@ -2724,7 +2736,19 @@ Tcl_DStringAppendElement( memcpy(newString, dsPtr->string, (size_t) dsPtr->length); dsPtr->string = newString; } else { + int offset = -1; + + /* See [16896d49fd] */ + if (element >= dsPtr->string + && element <= dsPtr->string + dsPtr->length) { + offset = element - dsPtr->string; + } + dsPtr->string = ckrealloc(dsPtr->string, dsPtr->spaceAvl); + + if (offset >= 0) { + element = dsPtr->string + offset; + } } dst = dsPtr->string + dsPtr->length; } |
