diff options
author | dgp@users.sourceforge.net <dgp> | 2014-12-23 17:26:07 (GMT) |
---|---|---|
committer | dgp@users.sourceforge.net <dgp> | 2014-12-23 17:26:07 (GMT) |
commit | 0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c (patch) | |
tree | 797b3c760758614ad840989e5d44200b5b75d003 | |
parent | ba3df90803cf86284bd11f8dc99881e0d29ee5be (diff) | |
download | tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.zip tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.tar.gz tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.tar.bz2 |
Support TCL_ENCODING_CHAR_LIMIT in the UtfToUtfProc driver.
-rw-r--r-- | generic/tclEncoding.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/generic/tclEncoding.c b/generic/tclEncoding.c index 5c5254b..f92cabb 100644 --- a/generic/tclEncoding.c +++ b/generic/tclEncoding.c @@ -2294,7 +2294,7 @@ UtfToUtfProc( { const char *srcStart, *srcEnd, *srcClose; const char *dstStart, *dstEnd; - int result, numChars; + int result, numChars, charLimit = INT_MAX; Tcl_UniChar ch; result = TCL_OK; @@ -2305,11 +2305,14 @@ UtfToUtfProc( if ((flags & TCL_ENCODING_END) == 0) { srcClose -= TCL_UTF_MAX; } + if (flags & TCL_ENCODING_CHAR_LIMIT) { + charLimit = *dstCharsPtr; + } dstStart = dst; dstEnd = dst + dstLen - TCL_UTF_MAX; - for (numChars = 0; src < srcEnd; numChars++) { + for (numChars = 0; src < srcEnd && numChars <= charLimit; numChars++) { if ((src > srcClose) && (!Tcl_UtfCharComplete(src, srcEnd - src))) { /* * If there is more string to follow, this will ensure that the |