Commit 8a0cb930 authored by Nigel Tao's avatar Nigel Tao

When decoding a paletted PNG, require that a PLTE chunk is seen before

the first IDAT chunk.

R=rsc
APPROVED=rsc
DELTA=7  (2 added, 0 deleted, 5 changed)
OCL=34583
CL=34585
parent d3013d8a
...@@ -65,6 +65,8 @@ func (e FormatError) String() string { ...@@ -65,6 +65,8 @@ func (e FormatError) String() string {
return "invalid PNG format: " + e; return "invalid PNG format: " + e;
} }
var chunkOrderError = FormatError("chunk out of order")
// An IDATDecodingError wraps an inner error (such as a ZLIB decoding error) encountered while processing an IDAT chunk. // An IDATDecodingError wraps an inner error (such as a ZLIB decoding error) encountered while processing an IDAT chunk.
type IDATDecodingError struct { type IDATDecodingError struct {
Err os.Error; Err os.Error;
...@@ -347,25 +349,25 @@ func (d *decoder) parseChunk(r io.Reader) os.Error { ...@@ -347,25 +349,25 @@ func (d *decoder) parseChunk(r io.Reader) os.Error {
switch string(d.scratch[0:4]) { switch string(d.scratch[0:4]) {
case "IHDR": case "IHDR":
if d.stage != dsStart { if d.stage != dsStart {
return FormatError("chunk out of order"); return chunkOrderError;
} }
d.stage = dsSeenIHDR; d.stage = dsSeenIHDR;
err = d.parseIHDR(r, crc, length); err = d.parseIHDR(r, crc, length);
case "PLTE": case "PLTE":
if d.stage != dsSeenIHDR { if d.stage != dsSeenIHDR {
return FormatError("chunk out of order"); return chunkOrderError;
} }
d.stage = dsSeenPLTE; d.stage = dsSeenPLTE;
err = d.parsePLTE(r, crc, length); err = d.parsePLTE(r, crc, length);
case "IDAT": case "IDAT":
if d.stage < dsSeenIHDR || d.stage > dsSeenIDAT { if d.stage < dsSeenIHDR || d.stage > dsSeenIDAT || (d.colorType == ctPaletted && d.stage == dsSeenIHDR) {
return FormatError("chunk out of order"); return chunkOrderError;
} }
d.stage = dsSeenIDAT; d.stage = dsSeenIDAT;
err = d.parseIDAT(r, crc, length); err = d.parseIDAT(r, crc, length);
case "IEND": case "IEND":
if d.stage != dsSeenIDAT { if d.stage != dsSeenIDAT {
return FormatError("chunk out of order"); return chunkOrderError;
} }
d.stage = dsSeenIEND; d.stage = dsSeenIEND;
err = d.parseIEND(r, crc, length); err = d.parseIEND(r, crc, length);
......
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