⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ftstream.c

📁 qt-embedded-2.3.8.tar.gz源码
💻 C
📖 第 1 页 / 共 2 页
字号:
      else        goto Fail;    }    stream->pos++;    return result;  Fail:    *error = FT_Err_Invalid_Stream_Operation;    FT_ERROR(( "FT_Read_Char:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    return 0;  }  FT_BASE_DEF( FT_Short )  FT_Read_Short( FT_Stream  stream,                                          FT_Error*  error )  {    FT_Byte   reads[2];    FT_Byte*  p = 0;    FT_Short  result = 0;    FT_Assert( stream );    *error = FT_Err_Ok;    if ( stream->pos + 1 < stream->size )    {      if ( stream->read )      {        if ( stream->read( stream, stream->pos, reads, 2L ) != 2L )          goto Fail;        p = reads;      }      else      {        p = stream->base + stream->pos;      }      if ( p )        result = NEXT_Short( p );    }    else      goto Fail;    stream->pos += 2;    return result;  Fail:    *error = FT_Err_Invalid_Stream_Operation;    FT_ERROR(( "FT_Read_Short:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    return 0;  }  FT_BASE_DEF( FT_Short )  FT_Read_ShortLE( FT_Stream  stream,                                            FT_Error*  error )  {    FT_Byte   reads[2];    FT_Byte*  p = 0;    FT_Short  result = 0;    FT_Assert( stream );    *error = FT_Err_Ok;    if ( stream->pos + 1 < stream->size )    {      if ( stream->read )      {        if ( stream->read( stream, stream->pos, reads, 2L ) != 2L )          goto Fail;        p = reads;      }      else      {        p = stream->base + stream->pos;      }      if ( p )        result = NEXT_ShortLE( p );    }    else      goto Fail;    stream->pos += 2;    return result;  Fail:    *error = FT_Err_Invalid_Stream_Operation;    FT_ERROR(( "FT_Read_Short:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    return 0;  }  FT_BASE_DEF( FT_Long )  FT_Read_Offset( FT_Stream  stream,                                          FT_Error*  error )  {    FT_Byte   reads[3];    FT_Byte*  p = 0;    FT_Long   result = 0;    FT_Assert( stream );    *error = FT_Err_Ok;    if ( stream->pos + 2 < stream->size )    {      if ( stream->read )      {        if (stream->read( stream, stream->pos, reads, 3L ) != 3L )          goto Fail;        p = reads;      }      else      {        p = stream->base + stream->pos;      }      if ( p )        result = NEXT_Offset( p );    }    else      goto Fail;    stream->pos += 3;    return result;  Fail:    *error = FT_Err_Invalid_Stream_Operation;    FT_ERROR(( "FT_Read_Offset:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    return 0;  }  FT_BASE_DEF( FT_Long )  FT_Read_Long( FT_Stream  stream,                                        FT_Error*  error )  {    FT_Byte   reads[4];    FT_Byte*  p = 0;    FT_Long   result = 0;    FT_Assert( stream );    *error = FT_Err_Ok;    if ( stream->pos + 3 < stream->size )    {      if ( stream->read )      {        if ( stream->read( stream, stream->pos, reads, 4L ) != 4L )          goto Fail;        p = reads;      }      else      {        p = stream->base + stream->pos;      }      if ( p )        result = NEXT_Long( p );    }    else      goto Fail;    stream->pos += 4;    return result;  Fail:    FT_ERROR(( "FT_Read_Long:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    *error = FT_Err_Invalid_Stream_Operation;    return 0;  }  FT_BASE_DEF( FT_Long )  FT_Read_LongLE( FT_Stream  stream,                                          FT_Error*  error )  {    FT_Byte   reads[4];    FT_Byte*  p = 0;    FT_Long   result = 0;    FT_Assert( stream );    *error = FT_Err_Ok;    if ( stream->pos + 3 < stream->size )    {      if ( stream->read )      {        if ( stream->read( stream, stream->pos, reads, 4L ) != 4L )          goto Fail;        p = reads;      }      else      {        p = stream->base + stream->pos;      }      if ( p )        result = NEXT_LongLE( p );    }    else      goto Fail;    stream->pos += 4;    return result;  Fail:    FT_ERROR(( "FT_Read_Long:" ));    FT_ERROR(( " invalid i/o; pos = 0x%lx, size = 0x%lx\n",               stream->pos, stream->size ));    *error = FT_Err_Invalid_Stream_Operation;    return 0;  }  FT_BASE_DEF( FT_Error )  FT_Read_Fields( FT_Stream              stream,                                           const FT_Frame_Field*  fields,                                           void*                  structure )  {    FT_Error  error;    FT_Bool   frame_accessed = 0;    FT_Byte*  cursor = stream->cursor;    if ( !fields || !stream )      return FT_Err_Invalid_Argument;    error = FT_Err_Ok;    do    {      FT_ULong  value;      FT_Int    sign_shift;      FT_Byte*  p;      switch ( fields->value )      {      case ft_frame_start:  /* access a new frame */        error = FT_Access_Frame( stream, fields->offset );        if ( error )          goto Exit;        frame_accessed = 1;        cursor         = stream->cursor;        fields++;        continue;  /* loop! */      case ft_frame_bytes:  /* read a byte sequence */      case ft_frame_skip:   /* skip some bytes      */        {          FT_UInt  len = fields->size;          if ( cursor + len > stream->limit )          {            error = FT_Err_Invalid_Stream_Operation;            goto Exit;          }          if ( fields->value == ft_frame_bytes )          {            p = (FT_Byte*)structure + fields->offset;            MEM_Copy( p, cursor, len );          }          cursor += len;          fields++;          continue;        }      case ft_frame_byte:      case ft_frame_schar:  /* read a single byte */        value = NEXT_Byte(cursor);        sign_shift = 24;        break;      case ft_frame_short_be:      case ft_frame_ushort_be:  /* read a 2-byte big-endian short */        value = NEXT_UShort(cursor);        sign_shift = 16;        break;      case ft_frame_short_le:      case ft_frame_ushort_le:  /* read a 2-byte little-endian short */        value = NEXT_UShortLE(cursor);        sign_shift = 16;        break;      case ft_frame_long_be:      case ft_frame_ulong_be:  /* read a 4-byte big-endian long */        value = NEXT_ULong(cursor);        sign_shift = 0;        break;      case ft_frame_long_le:      case ft_frame_ulong_le:  /* read a 4-byte little-endian long */        value = NEXT_ULongLE(cursor);        sign_shift = 0;        break;      case ft_frame_off3_be:      case ft_frame_uoff3_be:  /* read a 3-byte big-endian long */        value = NEXT_UOffset(cursor);        sign_shift = 8;        break;      case ft_frame_off3_le:      case ft_frame_uoff3_le:  /* read a 3-byte little-endian long */        value = NEXT_UOffsetLE(cursor);        sign_shift = 8;        break;      default:        /* otherwise, exit the loop */        stream->cursor = cursor;        goto Exit;      }      /* now, compute the signed value is necessary */      if ( fields->value & FT_FRAME_OP_SIGNED )        value = (FT_ULong)( (FT_Int32)( value << sign_shift ) >> sign_shift );      /* finally, store the value in the object */      p = (FT_Byte*)structure + fields->offset;      switch ( fields->size )      {      case 1:        *(FT_Byte*)p = (FT_Byte)value;        break;      case 2:        *(FT_UShort*)p = (FT_UShort)value;        break;      case 4:        *(FT_UInt32*)p = (FT_UInt32)value;        break;      default:  /* for 64-bit systems */        *(FT_ULong*)p = (FT_ULong)value;      }      /* go to next field */      fields++;    }    while ( 1 );  Exit:    /* close the frame if it was opened by this read */    if ( frame_accessed )      FT_Forget_Frame( stream );    return error;  }/* END */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -