view dwt/internal/image/PngIendChunk.d @ 59:8cec8f536af3

All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
author Frank Benoit <benoit@tionex.de>
date Sat, 12 Jan 2008 08:44:23 +0100
parents 7b1ca4eb5763
children 295b29fc7d13
line wrap: on
line source

/*******************************************************************************
 * Copyright (c) 2000, 2006 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
module dwt.internal.image.PngIendChunk;


import dwt.SWT;
import dwt.internal.image.PngFileReadState;
import dwt.internal.image.PngIhdrChunk;
import dwt.internal.image.PngChunk;

class PngIendChunk : PngChunk {

this() {
    super(0);
    setType(TYPE_IEND);
    setCRC(computeCRC());
}

this(byte[] reference){
    super(reference);
}

int getChunkType() {
    return CHUNK_IEND;
}

/**
 * Answer whether the chunk is a valid IEND chunk.
 */
void validate(PngFileReadState readState, PngIhdrChunk headerChunk) {
    // An IEND chunk is invalid if no IHDR has been read.
    // Or if a palette is required and has not been read.
    // Or if no IDAT chunk has been read.
    if (!readState.readIHDR
        || (headerChunk.getMustHavePalette() && !readState.readPLTE)
        || !readState.readIDAT
        || readState.readIEND)
    {
        SWT.error(SWT.ERROR_INVALID_IMAGE);
    } else {
        readState.readIEND = true;
    }

    super.validate(readState, headerChunk);

    // IEND chunks are not allowed to have any data.
    if (getLength() > 0) SWT.error(SWT.ERROR_INVALID_IMAGE);
}

}