/* * Copyright (c) 2015 Cisco Systems, Inc. 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.controller.md.sal.dom.api; import static java.util.Objects.requireNonNull; import com.google.common.base.MoreObjects; import java.io.Serializable; import java.util.Iterator; import org.eclipse.jdt.annotation.NonNull; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; import org.opendaylight.yangtools.concepts.Immutable; import org.opendaylight.yangtools.concepts.Path; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; /** * A unique identifier for a particular subtree. It is composed of the logical * data store type and the instance identifier of the root node. * * @deprecated Use {@link org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier} instead. */ @Deprecated(forRemoval = true) public final class DOMDataTreeIdentifier implements Immutable, Path, Serializable, Comparable { private static final long serialVersionUID = 1L; private final @NonNull YangInstanceIdentifier rootIdentifier; private final @NonNull LogicalDatastoreType datastoreType; public DOMDataTreeIdentifier(final LogicalDatastoreType datastoreType, final YangInstanceIdentifier rootIdentifier) { this.datastoreType = requireNonNull(datastoreType); this.rootIdentifier = requireNonNull(rootIdentifier); } /** * Return a counterpart to an MD-SAL data tree identifier. * * @return Controller data tree identifier. */ public static DOMDataTreeIdentifier fromMdsal(final org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier mdsal) { return new DOMDataTreeIdentifier(LogicalDatastoreType.fromMdsal(mdsal.getDatastoreType()), mdsal.getRootIdentifier()); } /** * Return MD-SAL counterpart of this object. * * @return MD-SAL data tree identifier. */ public org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier toMdsal() { return new org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier(datastoreType.toMdsal(), rootIdentifier); } /** * Return the logical data store type. * * @return Logical data store type. Guaranteed to be non-null. */ public @NonNull LogicalDatastoreType getDatastoreType() { return datastoreType; } /** * Return the {@link YangInstanceIdentifier} of the root node. * * @return Instance identifier corresponding to the root node. */ public @NonNull YangInstanceIdentifier getRootIdentifier() { return rootIdentifier; } @Override public boolean contains(final DOMDataTreeIdentifier other) { return datastoreType == other.datastoreType && rootIdentifier.contains(other.rootIdentifier); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + datastoreType.hashCode(); result = prime * result + rootIdentifier.hashCode(); return result; } @Override public boolean equals(final Object obj) { if (this == obj) { return true; } if (!(obj instanceof DOMDataTreeIdentifier)) { return false; } DOMDataTreeIdentifier other = (DOMDataTreeIdentifier) obj; if (datastoreType != other.datastoreType) { return false; } return rootIdentifier.equals(other.rootIdentifier); } @Override public int compareTo(final DOMDataTreeIdentifier obj) { int cmp = datastoreType.compareTo(obj.datastoreType); if (cmp != 0) { return cmp; } final Iterator mi = rootIdentifier.getPathArguments().iterator(); final Iterator oi = obj.rootIdentifier.getPathArguments().iterator(); while (mi.hasNext()) { if (!oi.hasNext()) { return 1; } final PathArgument ma = mi.next(); final PathArgument oa = oi.next(); cmp = ma.compareTo(oa); if (cmp != 0) { return cmp; } } return oi.hasNext() ? -1 : 0; } @Override public String toString() { return MoreObjects.toStringHelper(this).add("datastore", datastoreType).add("root", rootIdentifier).toString(); } }