Rev 3408 |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
/*
* Copyright (C) 2011.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 or
* version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*/
package uk.me.parabola.imgfmt.mdxfmt;
import java.util.ArrayList;
import java.util.List;
import uk.me.parabola.imgfmt.app.BufferedImgFileReader;
import uk.me.parabola.imgfmt.app.ImgFileReader;
import uk.me.parabola.imgfmt.fs.ImgChannel;
/**
* For reading the MDX file.
*
* @author Steve Ratcliffe
*/
public class MdxFileReader
{
private final ImgFileReader reader
;
private int numberOfMaps
;
private final List<MapInfo
> maps =
new ArrayList<MapInfo
>();
public MdxFileReader
(ImgChannel chan
) {
this.
reader =
new BufferedImgFileReader
(chan
);
readHeader
();
readMaps
();
}
private void readMaps
() {
for (int i =
0; i
< numberOfMaps
; i++
) {
MapInfo info =
new MapInfo
();
info.
setHexMapname(reader.
getInt());
info.
setProductId(reader.
getChar());
info.
setFamilyId(reader.
getChar());
info.
setMapname(reader.
getInt());
maps.
add(info
);
}
}
private void readHeader
() {
reader.
getInt();
reader.
getChar();
reader.
getInt();
numberOfMaps = reader.
getInt();
}
public List<MapInfo
> getMaps
() {
return maps
;
}
}