/* * Geotoolkit - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2010, Geomatys * * This library 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.1 of the License, or (at your option) any later version. * * This library 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. */ package org.geotoolkit.sml.xml.v101; import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; import java.util.Objects; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAnyAttribute; import javax.xml.bind.annotation.XmlValue; import javax.xml.namespace.QName; import org.geotoolkit.sml.xml.AbstractValues; import org.apache.sis.util.ComparisonMode; /** * <p>Java class for anonymous complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType> * <complexContent> * <extension base="{http://www.w3.org/2001/XMLSchema}anyType"> * </extension> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) public class Values extends SensorObject implements AbstractValues { /*@XmlAnyElement private List<Element> any; we need direct String value. TODO see how to handle both any xml and String value */ @XmlValue private String any; @XmlAnyAttribute private Map<QName, String> otherAttributes = new HashMap<QName, String>(); public Values() { } public Values(final AbstractValues v) { if (v != null) { this.any = v.getAny(); this.otherAttributes = v.getOtherAttributes(); } } /** * Gets the value of the any property. * */ public String getAny() { return this.any; } public void setAny(final String any) { this.any = any; } /** * Gets a map that contains attributes that aren't bound to any typed property on this class. * @return * always non-null */ public Map<QName, String> getOtherAttributes() { return otherAttributes; } /** * {@inheritDoc} */ @Override public boolean equals(final Object object, final ComparisonMode mode) { if (object == this) { return true; } if (object instanceof Values) { final Values that = (Values) object; return Objects.equals(this.any, that.any) && Objects.equals(this.otherAttributes, that.otherAttributes) ; } return false; } @Override public int hashCode() { int hash = 5; hash = 11 * hash + (this.any != null ? this.any.hashCode() : 0); hash = 11 * hash + (this.otherAttributes != null? this.otherAttributes.hashCode() : 0); return hash; } /** * Retourne une representation de l'objet (debug). */ @Override public String toString() { final StringBuilder sb = new StringBuilder("[Values]\n"); if (any != null) { sb.append("any=").append(any).append('\n'); } if (otherAttributes != null) { sb.append("otherAttributes:\n"); for (Entry<QName,String> entry : otherAttributes.entrySet()) { sb.append(entry.getKey()).append(" = ").append(entry.getValue()).append('\n'); } } return sb.toString(); } }