/* * #%L * ===================================================== * _____ _ ____ _ _ _ _ * |_ _|_ __ _ _ ___| |_ / __ \| | | | ___ | | | | * | | | '__| | | / __| __|/ / _` | |_| |/ __|| |_| | * | | | | | |_| \__ \ |_| | (_| | _ |\__ \| _ | * |_| |_| \__,_|___/\__|\ \__,_|_| |_||___/|_| |_| * \____/ * * ===================================================== * * Hochschule Hannover * (University of Applied Sciences and Arts, Hannover) * Faculty IV, Dept. of Computer Science * Ricklinger Stadtweg 118, 30459 Hannover, Germany * * Email: trust@f4-i.fh-hannover.de * Website: http://trust.f4.hs-hannover.de/ * * This file is part of visitmeta-visualization, version 0.6.0, * implemented by the Trust@HsH research group at the Hochschule Hannover. * %% * Copyright (C) 2012 - 2016 Trust@HsH * %% * 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. * #L% */ package de.hshannover.f4.trust.visitmeta.datawrapper; import org.apache.log4j.Logger; import de.hshannover.f4.trust.visitmeta.interfaces.Identifier; import de.hshannover.f4.trust.visitmeta.interfaces.Link; import de.hshannover.f4.trust.visitmeta.interfaces.Metadata; /** * A container class holding a metadata entity together with the corresponding * identifier or link (depending on metatdata type). * Necessary for unique identification of metadata. */ public class RichMetadata { private static final Logger LOGGER = Logger.getLogger(RichMetadata.class); /* * mMetadata and either mIdentifier or mLink must be set (depending on metadata type). * Setting mMetadata alone without mIdentifier or mLink is only provided for compatibility. */ private Metadata mMetadata; private Identifier mIdentifier; private Link mLink; /** * Deprecated; set either identifier or link (depending on metatdata type). */ @Deprecated public RichMetadata(Metadata metadata) { mMetadata = metadata; mIdentifier = null; mLink = null; } public RichMetadata(Metadata metadata, Identifier identifier) { mMetadata = metadata; mIdentifier = identifier; mLink = null; } public RichMetadata(Metadata metadata, Link link) { mMetadata = metadata; mIdentifier = null; mLink = link; } public Metadata getMetadata() { return mMetadata; } public Identifier getIdentifier() { return mIdentifier; } public Link getLink() { return mLink; } @Override public boolean equals(Object o) { LOGGER.trace("Method equals(" + o + ") called for this = " + this + "."); if (o == null) { return false; } if (! (o instanceof RichMetadata)) { return false; } RichMetadata other = (RichMetadata) o; if (! mMetadata.equals(other.mMetadata)) { return false; } if (mIdentifier != null) { if (other.mIdentifier == null) { return false; } if (! mIdentifier.equals(other.mIdentifier)) { return false; } } else { if (other.mIdentifier != null) { return false; } } if (mLink != null) { if (other.mLink == null) { return false; } if (! mLink.equals(other.mLink)) { return false; } } else { if (other.mLink != null) { return false; } } return true; } @Override public int hashCode() { LOGGER.trace("Method hashCode() called."); final int prime = 31; int result = 1; result = prime * result + mMetadata.hashCode(); result = prime * result + (mIdentifier == null ? 0 : mIdentifier.hashCode()); result = prime * result + (mLink == null ? 0 : mLink.hashCode()); return result; } @Override public String toString(){ LOGGER.trace("Method toString() called."); String result = ""; if (mMetadata != null) { result += "metadata = " + mMetadata.hashCode(); } if (mIdentifier != null) { result += ", identifier = " + mIdentifier.hashCode(); } if (mLink != null) { result += ", link = " + mLink.hashCode(); } return result; } }