/** * Copyright (C) 2012-2017 52°North Initiative for Geospatial Open Source * Software GmbH * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published * by the Free Software Foundation. * * If the program is linked with libraries which are licensed under one of * the following licenses, the combination of the program with the linked * library is not considered a "derivative work" of the program: * * - Apache License, version 2.0 * - Apache Software License, version 1.0 * - GNU Lesser General Public License, version 3 * - Mozilla Public License, versions 1.0, 1.1 and 2.0 * - Common Development and Distribution License (CDDL), version 1.0 * * Therefore the distribution of the program linked with libraries licensed * under the aforementioned licenses, is permitted by the copyright holders * if the distribution is compliant with both the GNU General Public * License version 2 and the aforementioned licenses. * * 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 org.n52.sos.i18n.metadata; import java.util.Locale; import java.util.Set; import org.n52.sos.i18n.MultilingualString; import com.google.common.base.Objects; import com.google.common.base.Objects.ToStringHelper; import com.google.common.collect.Sets; public abstract class AbstractI18NMetadata { private final String identifier; private final MultilingualString name; private final MultilingualString description; /** * constructor * * @param id The identifier of this object * @param name The multilingual name of this object * @param description the multilingual description of this object */ public AbstractI18NMetadata(String id, MultilingualString name, MultilingualString description) { this.identifier = id; this.name = newIfNull(name); this.description = newIfNull(description); } /** * constructor * * @param id The identifier of this object */ public AbstractI18NMetadata(String id) { this(id, null, null); } /** * The the identifier of this object * * @return The object identifier */ public String getIdentifier() { return identifier; } /** * @return the multilingual name of this object */ public MultilingualString getName() { return this.name; } /** * @return the multilingual description of this object */ public MultilingualString getDescription() { return this.description; } /** * @return a {@link ToStringHelper} filled with the state of this class */ protected ToStringHelper toStringHelper() { return Objects.toStringHelper(this) .add("identifier", getIdentifier()) .add("name", getName()) .add("description", getDescription()); } @Override public String toString() { return toStringHelper().toString(); } @Override public int hashCode() { return Objects.hashCode(getIdentifier(), getName(), getDescription()); } @Override public boolean equals(Object o) { if (o instanceof AbstractI18NMetadata) { AbstractI18NMetadata that = (AbstractI18NMetadata) o; return Objects.equal(this.getIdentifier(), that.getIdentifier()) && Objects.equal(this.getName(), that.getName()) && Objects.equal(this.getDescription(), that.getDescription()); } return false; } /** * @return a unmodifiable set of all {@link Locale}s present in this object. */ public Set<Locale> getLocales() { return Sets.union(getName().getLocales(), getDescription().getLocales()); } /** * Creates a new {@link MultilingualString} if the supplied string is * {@code null}. * * @param string the string * * @return either {@code string} or a new {@code MultilingualString} */ protected static MultilingualString newIfNull(MultilingualString string) { return string == null ? new MultilingualString() : string; } }