org.opendaylight.yangtools.binding.lib.AbstractOpaqueData Maven / Gradle / Ivy
/*
* Copyright (c) 2019 PANTHEON.tech, s.r.o. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.yangtools.binding.lib;
import com.google.common.annotations.Beta;
import com.google.common.base.MoreObjects;
import com.google.common.base.MoreObjects.ToStringHelper;
import org.eclipse.jdt.annotation.NonNull;
import org.opendaylight.yangtools.binding.OpaqueData;
/**
* Utility class for {@link OpaqueData} implementations. This class provides baseline implementation of
* {@link #hashCode()} and {@link #equals(Object)} as specified by {@link OpaqueData}. For cases where the object
* model's objects do not provide a usable implementation of hashCode/equals, this class is expected to be subclassed
* to provide alternative implementation of {@link #dataHashCode()} and {@link #dataEquals(Object)} methods. Such
* class should be made public in a convenient place. Note such customized methods are required to maintain consistency
* between hashCode and equals, as well as the reflexive, symmetric, transitive and
* consistent properties as detailed in {@link Object#equals(Object)}.
*
* @param Data object model type
*/
@Beta
public abstract class AbstractOpaqueData implements OpaqueData {
@Override
public final int hashCode() {
return 31 * getObjectModel().hashCode() + dataHashCode();
}
@Override
public final boolean equals(final Object obj) {
return this == obj || obj instanceof OpaqueData> other
&& getObjectModel().equals(other.getObjectModel()) && dataEquals(other.getData());
}
@Override
public final String toString() {
return addToStringAttributes(MoreObjects.toStringHelper(this).add("objectModel", getObjectModel())).toString();
}
protected ToStringHelper addToStringAttributes(final ToStringHelper helper) {
return helper.add("data", getData());
}
/**
* Determine hashCode of the data. The default implementation uses the data object's {@code hashCode} method.
*
* @return Hash code value of data
*/
protected int dataHashCode() {
return getData().hashCode();
}
protected boolean dataEquals(final @NonNull Object otherData) {
return getData().equals(otherData);
}
}