org.xmlcml.stml.attribute.DoubleArraySTAttribute Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of euclid Show documentation
Show all versions of euclid Show documentation
A Java library for 2D and 3D geometric calculations
/**
* Copyright 2011 Peter Murray-Rust
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.xmlcml.stml.attribute;
import java.text.ParseException;
import nu.xom.Attribute;
import nu.xom.Node;
import org.xmlcml.euclid.Util;
import org.xmlcml.stml.STMLAttribute;
/**
* attribute representing an array of doubles.
*/
public class DoubleArraySTAttribute extends STMLAttribute {
/** dewisott */
public final static String JAVA_TYPE = "double[]";
/** dewisott */
public final static String JAVA_GET_METHOD = "getDoubleArray";
/** dewisott */
public final static String JAVA_SHORT_CLASS = "DoubleArraySTAttribute";
protected double[] dd = null;
protected int length = -1;
/**
* constructor.
*
* @param name
*/
public DoubleArraySTAttribute(String name) {
super(name);
}
/**
* construct from existing attribute.
*
* @param att
*/
public DoubleArraySTAttribute(Attribute att) {
this(att.getLocalName());
this.setSTMLValue(att.getValue());
}
/**
* from DOM.
*
* @param att
* to copy, except value
* @param value
*/
public DoubleArraySTAttribute(Attribute att, String value) {
super(att, value.trim().replace(S_WHITEREGEX, S_SPACE));
}
/**
* copy constructor
*
* @param att
*/
public DoubleArraySTAttribute(DoubleArraySTAttribute att) {
super(att);
if (att.dd != null) {
this.dd = new double[att.dd.length];
for (int i = 0; i < dd.length; i++) {
this.dd[i] = att.dd[i];
}
}
this.length = att.length;
}
/**
* copy. uses copy constructor.
*
* @return copy
*/
public Attribute copy() {
return new DoubleArraySTAttribute(this);
}
/**
* sets value. throws exception if of wrong type or violates restriction
*
* @param s
* the value
*/
public void setSTMLValue(String s) {
if (s != null && !s.trim().equals(S_EMPTY)) {
double[] dd = split(s.trim().replace(S_WHITEREGEX, S_SPACE),
S_WHITEREGEX);
this.setSTMLValue(dd);
}
}
/**
* set and check value.
*
* @param dd
* @throws RuntimeException
*/
public void setSTMLValue(double[] dd) throws RuntimeException {
checkValue(dd);
this.dd = new double[dd.length];
for (int i = 0; i < dd.length; i++) {
this.dd[i] = dd[i];
}
this.setValue(Util.concatenate(dd, S_SPACE));
}
/**
* checks value of simpleType. if value does not check
* against SimpleType uses STMLType.checkvalue() fails if type is String or
* int or is not a list
*
* @param dd
* the double array
* @throws RuntimeException
* wrong type or value fails
*/
public void checkValue(double[] dd) throws RuntimeException {
if (cmlType != null) {
cmlType.checkValue(dd);
}
}
/**
* splits string into doubles.
*
* @param s
* the string
* @param delim
* delimiter (if null defaults to S_SPACE);
* @throws RuntimeException
* If the doubles have bad values.
* @return split doubles
*/
public static double[] split(String s, String delim) {
String sss = s;
if (delim == null || delim.trim().equals(S_EMPTY)
|| delim.equals(S_WHITEREGEX)) {
delim = S_WHITEREGEX;
sss = sss.trim();
} else {
}
String[] ss = sss.split(delim);
double[] dd = new double[ss.length];
for (int i = 0; i < ss.length; i++) {
try {
dd[i] = (Util.parseFlexibleDouble(ss[i]));
} catch (NumberFormatException nfe) {
throw new RuntimeException(S_EMPTY + nfe);
} catch (ParseException e) {
throw new RuntimeException("Bad double value: " + ss[i]
+ " at " + i +" in "+ sss, e);
}
}
return dd;
}
/**
* get array.
*
* @return null if not set
*/
public Object getSTMLValue() {
return dd;
}
/**
* get array.
*
* @return null if not set
*/
public double[] getDoubleArray() {
return dd;
}
/**
* get Java type.
*
* @return type
*/
public String getJavaType() {
return JAVA_TYPE;
}
/**
* get method.
*
* @return method
*/
public String getJavaGetMethod() {
return JAVA_GET_METHOD;
}
/**
* get short class name.
*
* @return classname
*/
public String getJavaShortClassName() {
return JAVA_SHORT_CLASS;
}
};