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 /generic/tclEncoding.c | |
| parent | ba3df90803cf86284bd11f8dc99881e0d29ee5be (diff) | |
| download | tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.zip tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.tar.gz tcl-0c8d6f5fda8fb777ac700ee3eb67d9982bb0d94c.tar.bz2 | |
Support TCL_ENCODING_CHAR_LIMIT in the UtfToUtfProc driver.
Diffstat (limited to 'generic/tclEncoding.c')
| -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 | 
