/* * Copyright (c) 2016 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.mdsal.binding2.generator.util; import com.google.common.annotations.Beta; import com.google.common.base.Preconditions; import java.util.Objects; import org.opendaylight.mdsal.binding2.model.api.Type; /** * This class represents ancestor for other Types */ @Beta abstract public class AbstractBaseType implements Type { /** * Name of the package to which this Type belongs. */ private final String packageName; /** * Name of this Type. */ private final String name; /** * Constructs the instance of this class with the concrete package name type * name. * * @param pkName * string with the package name to which this Type * belongs * @param name * string with the name for this Type */ protected AbstractBaseType(final String pkName, final String name) { this.packageName = Preconditions.checkNotNull(pkName, "Package Name for Generated Type cannot be null!"); this.name = Preconditions.checkNotNull(name, "Name of Generated Type cannot be null!"); } @Override public int hashCode() { return Objects.hash(name, packageName); } @Override public boolean equals(final Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } Type other = (Type) obj; return Objects.equals(this, other); } @Override public String toString() { if (packageName.isEmpty()) { return "Type (" + name + ")"; } return "Type (" + packageName + "." + name + ")"; } @Override public String getPackageName() { return packageName; } @Override public String getName() { return name; } @Override public String getFullyQualifiedName() { if (packageName.isEmpty()) { return name; } else { return packageName + "." + name; } } }