[pcf] Use unsigned types.

* src/pcf/pcf.h (PCF_Encoding): Use unsigned `enc'.
* src/pcf/pcfdrivr.c (pcf_cmap_char_{index,next}): Ditto.
* src/pcf/pcfread.c (pcf_get_encodings): Use unsigned types.
color
Alexei Podtelezhnikov 7 years ago
parent 86e7385342
commit f24dbb2811
  1. 8
      ChangeLog
  2. 2
      src/pcf/pcf.h
  3. 6
      src/pcf/pcfdrivr.c
  4. 47
      src/pcf/pcfread.c

@ -1,3 +1,11 @@
2018-08-06 Alexei Podtelezhnikov <apodtele@gmail.com>
[pcf] Use unsigned types.
* src/pcf/pcf.h (PCF_Encoding): Use unsigned `enc'.
* src/pcf/pcfdrivr.c (pcf_cmap_char_{index,next}): Ditto.
* src/pcf/pcfread.c (pcf_get_encodings): Use unsigned types.
2018-08-05 Werner Lemberg <wl@gnu.org>
* src/truetype/ttgload.c (compute_glyph_metrics): Fix overflow.

@ -130,7 +130,7 @@ FT_BEGIN_HEADER
*/
typedef struct PCF_EncodingRec_
{
FT_Long enc;
FT_ULong enc;
FT_UShort glyph; /* an index into PCF_Face's `metrics' array */
} PCF_EncodingRec, *PCF_Encoding;

@ -123,7 +123,7 @@ THE SOFTWARE.
mid = ( min + max ) >> 1;
code = (FT_ULong)encodings[mid].enc;
code = encodings[mid].enc;
if ( charcode == code )
{
@ -161,7 +161,7 @@ THE SOFTWARE.
mid = ( min + max ) >> 1;
code = (FT_ULong)encodings[mid].enc;
code = encodings[mid].enc;
if ( charcode == code )
{
@ -178,7 +178,7 @@ THE SOFTWARE.
charcode = 0;
if ( min < cmap->num_encodings )
{
charcode = (FT_ULong)encodings[min].enc;
charcode = encodings[min].enc;
result = encodings[min].glyph;
}

@ -944,12 +944,12 @@ THE SOFTWARE.
FT_Error error;
FT_Memory memory = FT_FACE( face )->memory;
FT_ULong format, size;
FT_Short firstCol, lastCol;
FT_Short firstRow, lastRow;
FT_UShort firstCol, lastCol;
FT_UShort firstRow, lastRow;
FT_ULong nencoding;
FT_UShort defaultCharRow, defaultCharCol;
FT_UShort encodingOffset, defaultCharEncodingOffset;
FT_Short i, j;
FT_UShort i, j;
FT_Byte* pos;
FT_ULong k;
PCF_Encoding encoding = NULL;
@ -975,18 +975,18 @@ THE SOFTWARE.
/* make sense for most encodings. */
if ( PCF_BYTE_ORDER( format ) == MSBFirst )
{
firstCol = FT_GET_SHORT();
lastCol = FT_GET_SHORT();
firstRow = FT_GET_SHORT();
lastRow = FT_GET_SHORT();
firstCol = FT_GET_USHORT();
lastCol = FT_GET_USHORT();
firstRow = FT_GET_USHORT();
lastRow = FT_GET_USHORT();
face->defaultChar = FT_GET_USHORT();
}
else
{
firstCol = FT_GET_SHORT_LE();
lastCol = FT_GET_SHORT_LE();
firstRow = FT_GET_SHORT_LE();
lastRow = FT_GET_SHORT_LE();
firstCol = FT_GET_USHORT_LE();
lastCol = FT_GET_USHORT_LE();
firstRow = FT_GET_USHORT_LE();
lastRow = FT_GET_USHORT_LE();
face->defaultChar = FT_GET_USHORT_LE();
}
@ -1008,10 +1008,8 @@ THE SOFTWARE.
face->defaultChar ));
/* sanity checks; we limit numbers of rows and columns to 256 */
if ( firstCol < 0 ||
firstCol > lastCol ||
if ( firstCol > lastCol ||
lastCol > 0xFF ||
firstRow < 0 ||
firstRow > lastRow ||
lastRow > 0xFF )
return FT_THROW( Invalid_Table );
@ -1032,14 +1030,14 @@ THE SOFTWARE.
defaultCharCol = face->defaultChar & 0xFF;
/* validate default character */
if ( defaultCharRow < (FT_UShort)firstRow ||
defaultCharRow > (FT_UShort)lastRow ||
defaultCharCol < (FT_UShort)firstCol ||
defaultCharCol > (FT_UShort)lastCol )
if ( defaultCharRow < firstRow ||
defaultCharRow > lastRow ||
defaultCharCol < firstCol ||
defaultCharCol > lastCol )
{
face->defaultChar = (FT_UShort)firstRow * 256U + (FT_UShort)firstCol;
face->defaultChar = firstRow * 256U + firstCol;
FT_TRACE0(( "pcf_get_encodings:"
" Invalid default character set to %d\n",
" Invalid default character set to %u\n",
face->defaultChar ));
defaultCharRow = face->defaultChar >> 8;
@ -1054,9 +1052,8 @@ THE SOFTWARE.
/* `stream->cursor' still points at the beginning of the frame; */
/* we can thus easily get the offset to the default character */
pos = stream->cursor +
2 * ( ( defaultCharRow - (FT_UShort)firstRow ) *
( lastCol - firstCol + 1 ) +
defaultCharCol - (FT_UShort)firstCol );
2 * ( ( defaultCharRow - firstRow ) * ( lastCol - firstCol + 1 ) +
defaultCharCol - firstCol );
if ( PCF_BYTE_ORDER( format ) == MSBFirst )
defaultCharEncodingOffset = FT_PEEK_USHORT( pos );
@ -1102,10 +1099,10 @@ THE SOFTWARE.
else if ( encodingOffset == 0 )
encodingOffset = defaultCharEncodingOffset;
encoding[k].enc = i * 256 + j;
encoding[k].enc = i * 256U + j;
encoding[k].glyph = encodingOffset;
FT_TRACE5(( " code %d (0x%04X): idx %d\n",
FT_TRACE5(( " code %u (0x%04X): idx %u\n",
encoding[k].enc, encoding[k].enc, encoding[k].glyph ));
k++;

Loading…
Cancel
Save