/*
* 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.mkgmap.typ;
import uk.me.parabola.imgfmt.app.typ.TypData;
import uk.me.parabola.imgfmt.app.typ.TypPoint;
import uk.me.parabola.imgfmt.app.typ.Xpm;
import uk.me.parabola.mkgmap.scan.TokenScanner;
/**
* Process lines from the point section.
*
* @author Steve Ratcliffe
*/
class PointSection extends CommonSection implements ProcessSection {
private final TypPoint current = new TypPoint();
protected PointSection(TypData data) {
super(data);
}
public void processLine(TokenScanner scanner, String name, String value) {
if (commonKey(scanner, current, name, value))
return;
if (name.equalsIgnoreCase("DayXpm")) {
Xpm xpm = readXpm(scanner, value, current.simpleBitmap());
current.setXpm(xpm);
} else if (name.equalsIgnoreCase("NightXpm")) {
Xpm xpm = readXpm(scanner, value, current.simpleBitmap());
current.setNightXpm(xpm);
} else {
warnUnknown(name);
}
}
public void finish(TokenScanner scanner) {
validate(scanner);
data.addPoint(current);
}
}