Commit 47864728 authored by Dmitry Timoshkov's avatar Dmitry Timoshkov Committed by Alexandre Julliard

windowscodecs: GIF decoder should add header and trailer to extension blocks.

Metadata readers now have access to complete and correctly formatted data stream.
parent aaa68295
...@@ -857,8 +857,8 @@ static const void *get_GCE_data(GifFrameDecode *This) ...@@ -857,8 +857,8 @@ static const void *get_GCE_data(GifFrameDecode *This)
for (i = 0; i < This->frame->Extensions.ExtensionBlockCount; i++) for (i = 0; i < This->frame->Extensions.ExtensionBlockCount; i++)
{ {
if (This->frame->Extensions.ExtensionBlocks[i].Function == GRAPHICS_EXT_FUNC_CODE && if (This->frame->Extensions.ExtensionBlocks[i].Function == GRAPHICS_EXT_FUNC_CODE &&
This->frame->Extensions.ExtensionBlocks[i].ByteCount == 4) This->frame->Extensions.ExtensionBlocks[i].ByteCount == 8)
return This->frame->Extensions.ExtensionBlocks[i].Bytes; return This->frame->Extensions.ExtensionBlocks[i].Bytes + 3;
} }
return NULL; return NULL;
} }
......
...@@ -209,13 +209,18 @@ AddExtensionBlock(Extensions *New, ...@@ -209,13 +209,18 @@ AddExtensionBlock(Extensions *New,
ep = &New->ExtensionBlocks[New->ExtensionBlockCount++]; ep = &New->ExtensionBlocks[New->ExtensionBlockCount++];
ep->ByteCount=Len; ep->ByteCount=Len + 3;
ep->Bytes = ungif_alloc(ep->ByteCount); ep->Bytes = ungif_alloc(ep->ByteCount + 3);
if (ep->Bytes == NULL) if (ep->Bytes == NULL)
return (GIF_ERROR); return (GIF_ERROR);
/* Extension Header */
ep->Bytes[0] = 0x21;
ep->Bytes[1] = New->Function;
ep->Bytes[2] = Len;
if (ExtData) { if (ExtData) {
memcpy(ep->Bytes, ExtData, Len); memcpy(ep->Bytes + 3, ExtData, Len);
ep->Function = New->Function; ep->Function = New->Function;
} }
...@@ -238,12 +243,12 @@ AppendExtensionBlock(Extensions *New, ...@@ -238,12 +243,12 @@ AppendExtensionBlock(Extensions *New,
if (ep->Bytes == NULL) if (ep->Bytes == NULL)
return (GIF_ERROR); return (GIF_ERROR);
if (ExtData)
{
ep->Bytes[ep->ByteCount] = Len; ep->Bytes[ep->ByteCount] = Len;
if (ExtData)
memcpy(ep->Bytes + ep->ByteCount + 1, ExtData, Len); memcpy(ep->Bytes + ep->ByteCount + 1, ExtData, Len);
ep->ByteCount += Len + 1; ep->ByteCount += Len + 1;
}
return (GIF_OK); return (GIF_OK);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment