diff options
Diffstat (limited to 'generic/tclUtf.c')
| -rw-r--r-- | generic/tclUtf.c | 144 | 
1 files changed, 93 insertions, 51 deletions
| diff --git a/generic/tclUtf.c b/generic/tclUtf.c index ff1f120..15529c7 100644 --- a/generic/tclUtf.c +++ b/generic/tclUtf.c @@ -59,7 +59,7 @@   * UTF-8.   */ -static CONST unsigned char totalBytes[256] = { +static const unsigned char totalBytes[256] = {      1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,      1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,      1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, @@ -231,13 +231,13 @@ Tcl_UniCharToUtf(  char *  Tcl_UniCharToUtfDString( -    CONST Tcl_UniChar *uniStr,	/* Unicode string to convert to UTF-8. */ +    const Tcl_UniChar *uniStr,	/* Unicode string to convert to UTF-8. */      int uniLength,		/* Length of Unicode string in Tcl_UniChars  				 * (must be >= 0). */      Tcl_DString *dsPtr)		/* UTF-8 representation of string is appended  				 * to this previously initialized DString. */  { -    CONST Tcl_UniChar *w, *wEnd; +    const Tcl_UniChar *w, *wEnd;      char *p, *string;      int oldLength; @@ -289,7 +289,7 @@ Tcl_UniCharToUtfDString(  int  Tcl_UtfToUniChar( -    register CONST char *src,	/* The UTF-8 string. */ +    register const char *src,	/* The UTF-8 string. */      register Tcl_UniChar *chPtr)/* Filled with the Tcl_UniChar represented by  				 * the UTF-8 string. */  { @@ -393,7 +393,7 @@ Tcl_UtfToUniChar(  Tcl_UniChar *  Tcl_UtfToUniCharDString( -    CONST char *src,		/* UTF-8 string to convert to Unicode. */ +    const char *src,		/* UTF-8 string to convert to Unicode. */      int length,			/* Length of UTF-8 string in bytes, or -1 for  				 * strlen(). */      Tcl_DString *dsPtr)		/* Unicode representation of string is @@ -401,7 +401,7 @@ Tcl_UtfToUniCharDString(  				 * DString. */  {      Tcl_UniChar *w, *wString; -    CONST char *p, *end; +    const char *p, *end;      int oldLength;      if (length < 0) { @@ -414,6 +414,7 @@ Tcl_UtfToUniCharDString(       */      oldLength = Tcl_DStringLength(dsPtr); +/* TODO: fix overreach! */      Tcl_DStringSetLength(dsPtr,  	    (int) ((oldLength + length + 1) * sizeof(Tcl_UniChar)));      wString = (Tcl_UniChar *) (Tcl_DStringValue(dsPtr) + oldLength); @@ -452,7 +453,7 @@ Tcl_UtfToUniCharDString(  int  Tcl_UtfCharComplete( -    CONST char *src,		/* String to check if first few bytes contain +    const char *src,		/* String to check if first few bytes contain  				 * a complete UTF-8 character. */      int length)			/* Length of above string in bytes. */  { @@ -482,7 +483,7 @@ Tcl_UtfCharComplete(  int  Tcl_NumUtfChars( -    register CONST char *src,	/* The UTF-8 string to measure. */ +    register const char *src,	/* The UTF-8 string to measure. */      int length)			/* The length of the string in bytes, or -1  				 * for strlen(string). */  { @@ -540,9 +541,9 @@ Tcl_NumUtfChars(   *---------------------------------------------------------------------------   */ -CONST char * +const char *  Tcl_UtfFindFirst( -    CONST char *src,		/* The UTF-8 string to be searched. */ +    const char *src,		/* The UTF-8 string to be searched. */      int ch)			/* The Tcl_UniChar to search for. */  {      int len; @@ -579,14 +580,14 @@ Tcl_UtfFindFirst(   *---------------------------------------------------------------------------   */ -CONST char * +const char *  Tcl_UtfFindLast( -    CONST char *src,		/* The UTF-8 string to be searched. */ +    const char *src,		/* The UTF-8 string to be searched. */      int ch)			/* The Tcl_UniChar to search for. */  {      int len;      Tcl_UniChar find; -    CONST char *last; +    const char *last;      last = NULL;      while (1) { @@ -621,9 +622,9 @@ Tcl_UtfFindLast(   *---------------------------------------------------------------------------   */ -CONST char * +const char *  Tcl_UtfNext( -    CONST char *src)		/* The current location in the string. */ +    const char *src)		/* The current location in the string. */  {      Tcl_UniChar ch; @@ -651,13 +652,13 @@ Tcl_UtfNext(   *---------------------------------------------------------------------------   */ -CONST char * +const char *  Tcl_UtfPrev( -    CONST char *src,		/* The current location in the string. */ -    CONST char *start)		/* Pointer to the beginning of the string, to +    const char *src,		/* The current location in the string. */ +    const char *start)		/* Pointer to the beginning of the string, to  				 * avoid going backwards too far. */  { -    CONST char *look; +    const char *look;      int i, byte;      src--; @@ -700,10 +701,10 @@ Tcl_UtfPrev(  Tcl_UniChar  Tcl_UniCharAtIndex( -    register CONST char *src,	/* The UTF-8 string to dereference. */ +    register const char *src,	/* The UTF-8 string to dereference. */      register int index)		/* The position of the desired character. */  { -    Tcl_UniChar ch; +    Tcl_UniChar ch = 0;      while (index >= 0) {  	index--; @@ -729,9 +730,9 @@ Tcl_UniCharAtIndex(   *---------------------------------------------------------------------------   */ -CONST char * +const char *  Tcl_UtfAtIndex( -    register CONST char *src,	/* The UTF-8 string. */ +    register const char *src,	/* The UTF-8 string. */      register int index)		/* The position of the desired character. */  {      Tcl_UniChar ch; @@ -771,7 +772,7 @@ Tcl_UtfAtIndex(  int  Tcl_UtfBackslash( -    CONST char *src,		/* Points to the backslash character of a +    const char *src,		/* Points to the backslash character of a  				 * backslash sequence. */      int *readPtr,		/* Fill in with number of characters read from  				 * src, unless NULL. */ @@ -983,8 +984,8 @@ Tcl_UtfToTitle(  int  TclpUtfNcmp2( -    CONST char *cs,		/* UTF string to compare to ct. */ -    CONST char *ct,		/* UTF string cs is compared to. */ +    const char *cs,		/* UTF string to compare to ct. */ +    const char *ct,		/* UTF string cs is compared to. */      unsigned long numBytes)	/* Number of *bytes* to compare. */  {      /* @@ -1030,8 +1031,8 @@ TclpUtfNcmp2(  int  Tcl_UtfNcmp( -    CONST char *cs,		/* UTF string to compare to ct. */ -    CONST char *ct,		/* UTF string cs is compared to. */ +    const char *cs,		/* UTF string to compare to ct. */ +    const char *ct,		/* UTF string cs is compared to. */      unsigned long numChars)	/* Number of UTF chars to compare. */  {      Tcl_UniChar ch1, ch2; @@ -1078,8 +1079,8 @@ Tcl_UtfNcmp(  int  Tcl_UtfNcasecmp( -    CONST char *cs,		/* UTF string to compare to ct. */ -    CONST char *ct,		/* UTF string cs is compared to. */ +    const char *cs,		/* UTF string to compare to ct. */ +    const char *ct,		/* UTF string cs is compared to. */      unsigned long numChars)	/* Number of UTF chars to compare. */  {      Tcl_UniChar ch1, ch2; @@ -1105,6 +1106,46 @@ Tcl_UtfNcasecmp(  /*   *----------------------------------------------------------------------   * + * Tcl_UtfNcasecmp -- + * + *	Compare UTF chars of string cs to string ct case insensitively. + *	Replacement for strcasecmp in Tcl core, in places where UTF-8 should + *	be handled. + * + * Results: + *	Return <0 if cs < ct, 0 if cs == ct, or >0 if cs > ct. + * + * Side effects: + *	None. + * + *---------------------------------------------------------------------- + */ + +int +TclUtfCasecmp( +    const char *cs,		/* UTF string to compare to ct. */ +    const char *ct)		/* UTF string cs is compared to. */ +{ +    while (*cs && *ct) { +	Tcl_UniChar ch1, ch2; + +	cs += TclUtfToUniChar(cs, &ch1); +	ct += TclUtfToUniChar(ct, &ch2); +	if (ch1 != ch2) { +	    ch1 = Tcl_UniCharToLower(ch1); +	    ch2 = Tcl_UniCharToLower(ch2); +	    if (ch1 != ch2) { +		return ch1 - ch2; +	    } +	} +    } +    return UCHAR(*cs) - UCHAR(*ct); +} + + +/* + *---------------------------------------------------------------------- + *   * Tcl_UniCharToUpper --   *   *	Compute the uppercase equivalent of the given Unicode character. @@ -1125,10 +1166,9 @@ Tcl_UniCharToUpper(      int info = GetUniCharInfo(ch);      if (GetCaseType(info) & 0x04) { -	return (Tcl_UniChar) (ch - GetDelta(info)); -    } else { -	return ch; +	ch -= GetDelta(info);      } +    return (Tcl_UniChar) ch;  }  /* @@ -1154,10 +1194,9 @@ Tcl_UniCharToLower(      int info = GetUniCharInfo(ch);      if (GetCaseType(info) & 0x02) { -	return (Tcl_UniChar) (ch + GetDelta(info)); -    } else { -	return ch; +	ch += GetDelta(info);      } +    return (Tcl_UniChar) ch;  }  /* @@ -1188,12 +1227,11 @@ Tcl_UniCharToTitle(  	 * Subtract or add one depending on the original case.  	 */ -	return (Tcl_UniChar) (ch + ((mode & 0x4) ? -1 : 1)); +	ch += ((mode & 0x4) ? -1 : 1);      } else if (mode == 0x4) { -	return (Tcl_UniChar) (ch - GetDelta(info)); -    } else { -	return ch; +	ch -= GetDelta(info);      } +    return (Tcl_UniChar) ch;  }  /* @@ -1215,7 +1253,7 @@ Tcl_UniCharToTitle(  int  Tcl_UniCharLen( -    CONST Tcl_UniChar *uniStr)	/* Unicode string to find length of. */ +    const Tcl_UniChar *uniStr)	/* Unicode string to find length of. */  {      int len = 0; @@ -1245,8 +1283,8 @@ Tcl_UniCharLen(  int  Tcl_UniCharNcmp( -    CONST Tcl_UniChar *ucs,	/* Unicode string to compare to uct. */ -    CONST Tcl_UniChar *uct,	/* Unicode string ucs is compared to. */ +    const Tcl_UniChar *ucs,	/* Unicode string to compare to uct. */ +    const Tcl_UniChar *uct,	/* Unicode string ucs is compared to. */      unsigned long numChars)	/* Number of unichars to compare. */  {  #ifdef WORDS_BIGENDIAN @@ -1290,8 +1328,8 @@ Tcl_UniCharNcmp(  int  Tcl_UniCharNcasecmp( -    CONST Tcl_UniChar *ucs,	/* Unicode string to compare to uct. */ -    CONST Tcl_UniChar *uct,	/* Unicode string ucs is compared to. */ +    const Tcl_UniChar *ucs,	/* Unicode string to compare to uct. */ +    const Tcl_UniChar *uct,	/* Unicode string ucs is compared to. */      unsigned long numChars)	/* Number of unichars to compare. */  {      for ( ; numChars != 0; numChars--, ucs++, uct++) { @@ -1517,7 +1555,11 @@ Tcl_UniCharIsSpace(       */      if (((Tcl_UniChar) ch) < ((Tcl_UniChar) 0x80)) { -	return isspace(UCHAR(ch)); /* INTL: ISO space */ +	return TclIsSpaceProc((char) ch); +    } else if ((Tcl_UniChar) ch == 0x0085 || (Tcl_UniChar) ch == 0x180e +	    || (Tcl_UniChar) ch == 0x200b || (Tcl_UniChar) ch == 0x2060 +	    || (Tcl_UniChar) ch == 0x202f || (Tcl_UniChar) ch == 0xfeff) { +	return 1;      } else {  	return ((SPACE_BITS >> GetCategory(ch)) & 1);      } @@ -1594,8 +1636,8 @@ Tcl_UniCharIsWordChar(  int  Tcl_UniCharCaseMatch( -    CONST Tcl_UniChar *uniStr,	/* Unicode String. */ -    CONST Tcl_UniChar *uniPattern, +    const Tcl_UniChar *uniStr,	/* Unicode String. */ +    const Tcl_UniChar *uniPattern,  				/* Pattern, which may contain special  				 * characters. */      int nocase)			/* 0 for case sensitive, 1 for insensitive */ @@ -1782,14 +1824,14 @@ Tcl_UniCharCaseMatch(  int  TclUniCharMatch( -    CONST Tcl_UniChar *string,	/* Unicode String. */ +    const Tcl_UniChar *string,	/* Unicode String. */      int strLen,			/* Length of String */ -    CONST Tcl_UniChar *pattern,	/* Pattern, which may contain special +    const Tcl_UniChar *pattern,	/* Pattern, which may contain special  				 * characters. */      int ptnLen,			/* Length of Pattern */      int nocase)			/* 0 for case sensitive, 1 for insensitive */  { -    CONST Tcl_UniChar *stringEnd, *patternEnd; +    const Tcl_UniChar *stringEnd, *patternEnd;      Tcl_UniChar p;      stringEnd = string + strLen; | 
