/*
* ColumnsParser.java
*
* Copyright (c) 2002-2015 Alexei Drummond, Andrew Rambaut and Marc Suchard
*
* This file is part of BEAST.
* See the NOTICE file distributed with this work for additional
* information regarding copyright ownership and licensing.
*
* BEAST is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* BEAST 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with BEAST; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301 USA
*/
package dr.inferencexml.loggers;
import dr.inference.loggers.*;
import dr.util.Identifiable;
import dr.xml.*;
import java.util.ArrayList;
/**
*
*/
public class ColumnsParser extends AbstractXMLObjectParser {
public static final String COLUMN = "column";
public static final String LABEL = "label";
public static final String SIGNIFICANT_FIGURES = "sf";
public static final String DECIMAL_PLACES = "dp";
public static final String WIDTH = "width";
public static final String FORMAT = "format";
public static final String PERCENT = "percent";
public static final String BOOL = "boolean";
public String getParserName() {
return COLUMN;
}
public Object parseXMLObject(XMLObject xo) throws XMLParseException {
String label = xo.getAttribute(LABEL, "");
final int sf = xo.getAttribute(SIGNIFICANT_FIGURES, -1);
final int dp = xo.getAttribute(DECIMAL_PLACES, -1);
final int width = xo.getAttribute(WIDTH, -1);
String format = xo.getAttribute(FORMAT, "");
ArrayList colList = new ArrayList();
for (int i = 0; i < xo.getChildCount(); i++) {
Object child = xo.getChild(i);
LogColumn[] cols;
if (child instanceof Loggable) {
cols = ((Loggable) child).getColumns();
} else if (child instanceof Identifiable) {
cols = new LogColumn[]{new LogColumn.Default(((Identifiable) child).getId(), child)};
} else {
cols = new LogColumn[]{new LogColumn.Default(child.getClass().toString(), child)};
}
if (format.equals(PERCENT)) {
for (int k = 0; k < cols.length; ++k) {
if (cols[k] instanceof NumberColumn) {
cols[k] = new PercentColumn((NumberColumn) cols[k]);
}
}
} else if (format.equals(BOOL)) {
for (int k = 0; k < cols.length; ++k) {
if (cols[k] instanceof NumberColumn) {
cols[k] = new BooleanColumn((NumberColumn) cols[k]);
}
}
}
for (int j = 0; j < cols.length; j++) {
if (!label.equals("")) {
if (cols.length > 1) {
cols[j].setLabel(label + Integer.toString(j + 1));
} else {
cols[j].setLabel(label);
}
}
if (cols[j] instanceof NumberColumn) {
if (sf != -1) {
((NumberColumn) cols[j]).setSignificantFigures(sf);
}
if (dp != -1) {
((NumberColumn) cols[j]).setDecimalPlaces(dp);
}
}
if (width > 0) {
cols[j].setMinimumWidth(width);
}
colList.add(cols[j]);
}
}
LogColumn[] columns = new LogColumn[colList.size()];
colList.toArray(columns);
return new Columns(columns);
}
//************************************************************************
// AbstractXMLObjectParser implementation
//************************************************************************
public String getParserDescription() {
return "Specifies formating options for one or more columns in a log file.";
}
public Class getReturnType() {
return Columns.class;
}
public XMLSyntaxRule[] getSyntaxRules() {
return rules;
}
private XMLSyntaxRule[] rules = new XMLSyntaxRule[]{
new StringAttributeRule(LABEL,
"The label of the column. " +
"If this is specified and more than one statistic is in this column, " +
"then the label will be appended by the index of the statistic to create individual column names", true),
AttributeRule.newIntegerRule(SIGNIFICANT_FIGURES, true),
AttributeRule.newIntegerRule(DECIMAL_PLACES, true),
AttributeRule.newIntegerRule(WIDTH, true),
AttributeRule.newStringRule(FORMAT, true),
// Anything goes???
new ElementRule(Object.class, 1, Integer.MAX_VALUE),
};
}