39671f
--- freetype-2.4.11/src/base/ftstream.c
39671f
+++ freetype-2.4.11/src/base/ftstream.c
39671f
@@ -373,6 +373,25 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Short )
39671f
+  FT_Stream_GetShort( FT_Stream  stream )
39671f
+  {
39671f
+    FT_Byte*  p;
39671f
+    FT_Short  result;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream && stream->cursor );
39671f
+
39671f
+    result         = 0;
39671f
+    p              = stream->cursor;
39671f
+    if ( p + 1 < stream->limit )
39671f
+      result       = FT_NEXT_SHORT( p );
39671f
+    stream->cursor = p;
39671f
+
39671f
+    return result;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_UShort )
39671f
   FT_Stream_GetUShortLE( FT_Stream  stream )
39671f
   {
39671f
@@ -392,6 +411,25 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Short )
39671f
+  FT_Stream_GetShortLE( FT_Stream  stream )
39671f
+  {
39671f
+    FT_Byte*  p;
39671f
+    FT_Short  result;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream && stream->cursor );
39671f
+
39671f
+    result         = 0;
39671f
+    p              = stream->cursor;
39671f
+    if ( p + 1 < stream->limit )
39671f
+      result       = FT_NEXT_SHORT_LE( p );
39671f
+    stream->cursor = p;
39671f
+
39671f
+    return result;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_GetUOffset( FT_Stream  stream )
39671f
   {
39671f
@@ -410,6 +448,24 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_GetOffset( FT_Stream  stream )
39671f
+  {
39671f
+    FT_Byte*  p;
39671f
+    FT_Long   result;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream && stream->cursor );
39671f
+
39671f
+    result         = 0;
39671f
+    p              = stream->cursor;
39671f
+    if ( p + 2 < stream->limit )
39671f
+      result       = FT_NEXT_OFF3( p );
39671f
+    stream->cursor = p;
39671f
+    return result;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_GetULong( FT_Stream  stream )
39671f
   {
39671f
@@ -428,6 +484,24 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_GetLong( FT_Stream  stream )
39671f
+  {
39671f
+    FT_Byte*  p;
39671f
+    FT_Long   result;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream && stream->cursor );
39671f
+
39671f
+    result         = 0;
39671f
+    p              = stream->cursor;
39671f
+    if ( p + 3 < stream->limit )
39671f
+      result       = FT_NEXT_LONG( p );
39671f
+    stream->cursor = p;
39671f
+    return result;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_GetULongLE( FT_Stream  stream )
39671f
   {
39671f
@@ -446,6 +520,24 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_GetLongLE( FT_Stream  stream )
39671f
+  {
39671f
+    FT_Byte*  p;
39671f
+    FT_Long   result;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream && stream->cursor );
39671f
+
39671f
+    result         = 0;
39671f
+    p              = stream->cursor;
39671f
+    if ( p + 3 < stream->limit )
39671f
+      result       = FT_NEXT_LONG_LE( p );
39671f
+    stream->cursor = p;
39671f
+    return result;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_Char )
39671f
   FT_Stream_ReadChar( FT_Stream  stream,
39671f
                       FT_Error*  error )
39671f
@@ -530,6 +622,53 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Short )
39671f
+  FT_Stream_ReadShort( FT_Stream  stream,
39671f
+                       FT_Error*  error )
39671f
+  {
39671f
+    FT_Byte   reads[2];
39671f
+    FT_Byte*  p = 0;
39671f
+    FT_Short  result = 0;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream );
39671f
+
39671f
+    *error = FT_Err_Ok;
39671f
+
39671f
+    if ( stream->pos + 1 < stream->size )
39671f
+    {
39671f
+      if ( stream->read )
39671f
+      {
39671f
+        if ( stream->read( stream, stream->pos, reads, 2L ) != 2L )
39671f
+          goto Fail;
39671f
+
39671f
+        p = reads;
39671f
+      }
39671f
+      else
39671f
+      {
39671f
+        p = stream->base + stream->pos;
39671f
+      }
39671f
+
39671f
+      if ( p )
39671f
+        result = FT_NEXT_SHORT( p );
39671f
+    }
39671f
+    else
39671f
+      goto Fail;
39671f
+
39671f
+    stream->pos += 2;
39671f
+
39671f
+    return result;
39671f
+
39671f
+  Fail:
39671f
+    *error = FT_Err_Invalid_Stream_Operation;
39671f
+    FT_ERROR(( "FT_Stream_ReadShort:"
39671f
+               " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
+               stream->pos, stream->size ));
39671f
+
39671f
+    return 0;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_UShort )
39671f
   FT_Stream_ReadUShortLE( FT_Stream  stream,
b3c194
                           FT_Error*  error )
39671f
@@ -577,6 +716,53 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Short )
39671f
+  FT_Stream_ReadShortLE( FT_Stream  stream,
39671f
+                         FT_Error*  error )
39671f
+  {
39671f
+    FT_Byte   reads[2];
39671f
+    FT_Byte*  p = 0;
39671f
+    FT_Short  result = 0;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream );
39671f
+
39671f
+    *error = FT_Err_Ok;
39671f
+
39671f
+    if ( stream->pos + 1 < stream->size )
39671f
+    {
39671f
+      if ( stream->read )
39671f
+      {
39671f
+        if ( stream->read( stream, stream->pos, reads, 2L ) != 2L )
39671f
+          goto Fail;
39671f
+
39671f
+        p = reads;
39671f
+      }
39671f
+      else
39671f
+      {
39671f
+        p = stream->base + stream->pos;
39671f
+      }
39671f
+
39671f
+      if ( p )
39671f
+        result = FT_NEXT_SHORT_LE( p );
39671f
+    }
39671f
+    else
39671f
+      goto Fail;
39671f
+
39671f
+    stream->pos += 2;
39671f
+
39671f
+    return result;
39671f
+
39671f
+  Fail:
39671f
+    *error = FT_Err_Invalid_Stream_Operation;
39671f
+    FT_ERROR(( "FT_Stream_ReadShortLE:"
39671f
+               " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
+               stream->pos, stream->size ));
39671f
+
39671f
+    return 0;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_ReadUOffset( FT_Stream  stream,
b3c194
                          FT_Error*  error )
39671f
@@ -624,6 +810,53 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_ReadOffset( FT_Stream  stream,
39671f
+                        FT_Error*  error )
39671f
+  {
39671f
+    FT_Byte   reads[3];
39671f
+    FT_Byte*  p = 0;
39671f
+    FT_Long   result = 0;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream );
39671f
+
39671f
+    *error = FT_Err_Ok;
39671f
+
39671f
+    if ( stream->pos + 2 < stream->size )
39671f
+    {
39671f
+      if ( stream->read )
39671f
+      {
39671f
+        if (stream->read( stream, stream->pos, reads, 3L ) != 3L )
39671f
+          goto Fail;
39671f
+
39671f
+        p = reads;
39671f
+      }
39671f
+      else
39671f
+      {
39671f
+        p = stream->base + stream->pos;
39671f
+      }
39671f
+
39671f
+      if ( p )
39671f
+        result = FT_NEXT_OFF3( p );
39671f
+    }
39671f
+    else
39671f
+      goto Fail;
39671f
+
39671f
+    stream->pos += 3;
39671f
+
39671f
+    return result;
39671f
+
39671f
+  Fail:
39671f
+    *error = FT_Err_Invalid_Stream_Operation;
39671f
+    FT_ERROR(( "FT_Stream_ReadOffset:"
39671f
+               " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
+               stream->pos, stream->size ));
39671f
+
39671f
+    return 0;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_ReadULong( FT_Stream  stream,
b3c194
                        FT_Error*  error )
39671f
@@ -671,6 +904,53 @@
39671f
   }
39671f
 
39671f
 
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_ReadLong( FT_Stream  stream,
39671f
+                      FT_Error*  error )
39671f
+  {
39671f
+    FT_Byte   reads[4];
39671f
+    FT_Byte*  p = 0;
39671f
+    FT_Long   result = 0;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream );
39671f
+
39671f
+    *error = FT_Err_Ok;
39671f
+
39671f
+    if ( stream->pos + 3 < stream->size )
39671f
+    {
39671f
+      if ( stream->read )
39671f
+      {
39671f
+        if ( stream->read( stream, stream->pos, reads, 4L ) != 4L )
39671f
+          goto Fail;
39671f
+
39671f
+        p = reads;
39671f
+      }
39671f
+      else
39671f
+      {
39671f
+        p = stream->base + stream->pos;
39671f
+      }
39671f
+
39671f
+      if ( p )
39671f
+        result = FT_NEXT_LONG( p );
39671f
+    }
39671f
+    else
39671f
+      goto Fail;
39671f
+
39671f
+    stream->pos += 4;
39671f
+
39671f
+    return result;
39671f
+
39671f
+  Fail:
39671f
+    *error = FT_Err_Invalid_Stream_Operation;
39671f
+    FT_ERROR(( "FT_Stream_ReadLong:"
39671f
+               " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
+               stream->pos, stream->size ));
39671f
+
39671f
+    return 0;
39671f
+  }
39671f
+
39671f
+
39671f
   FT_BASE_DEF( FT_ULong )
39671f
   FT_Stream_ReadULongLE( FT_Stream  stream,
b3c194
                          FT_Error*  error )
39671f
@@ -714,6 +994,53 @@
39671f
                " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
                stream->pos, stream->size ));
39671f
 
39671f
+    return 0;
39671f
+  }
39671f
+
39671f
+
39671f
+  FT_BASE_DEF( FT_Long )
39671f
+  FT_Stream_ReadLongLE( FT_Stream  stream,
39671f
+                        FT_Error*  error )
39671f
+  {
39671f
+    FT_Byte   reads[4];
39671f
+    FT_Byte*  p = 0;
39671f
+    FT_Long   result = 0;
39671f
+
39671f
+
39671f
+    FT_ASSERT( stream );
39671f
+
39671f
+    *error = FT_Err_Ok;
39671f
+
39671f
+    if ( stream->pos + 3 < stream->size )
39671f
+    {
39671f
+      if ( stream->read )
39671f
+      {
39671f
+        if ( stream->read( stream, stream->pos, reads, 4L ) != 4L )
39671f
+          goto Fail;
39671f
+
39671f
+        p = reads;
39671f
+      }
39671f
+      else
39671f
+      {
39671f
+        p = stream->base + stream->pos;
39671f
+      }
39671f
+
39671f
+      if ( p )
39671f
+        result = FT_NEXT_LONG_LE( p );
39671f
+    }
39671f
+    else
39671f
+      goto Fail;
39671f
+
39671f
+    stream->pos += 4;
39671f
+
39671f
+    return result;
39671f
+
39671f
+  Fail:
39671f
+    *error = FT_Err_Invalid_Stream_Operation;
39671f
+    FT_ERROR(( "FT_Stream_ReadLongLE:"
39671f
+               " invalid i/o; pos = 0x%lx, size = 0x%lx\n",
39671f
+               stream->pos, stream->size ));
39671f
+
39671f
     return 0;
39671f
   }
39671f