/*
* 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 Type
s
*/
@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;
}
}
}