/**
* Copyright 2012-2017 Gunnar Morling (http://www.gunnarmorling.de/)
* and/or other contributors as indicated by the @authors tag. See the
* copyright.txt file in the distribution for a full listing of all
* contributors.
*
* 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.
*/
package org.mapstruct.ap.internal.model.dependency;
import java.util.ArrayList;
import java.util.List;
/**
* A node of a directed graph.
*
* @author Gunnar Morling
*/
class Node {
private final String name;
private boolean visited;
private int traversalSequence = -1;
/**
* The direct descendants of this node.
*/
private final List<Node> descendants;
Node(String name) {
this.name = name;
descendants = new ArrayList<Node>();
}
public String getName() {
return name;
}
public boolean isVisited() {
return visited;
}
public void setVisited(boolean visited) {
this.visited = visited;
}
public boolean isProcessed() {
return traversalSequence >= 0;
}
public int getTraversalSequence() {
return traversalSequence;
}
public void setTraversalSequence(int traversalSequence) {
this.traversalSequence = traversalSequence;
}
public void addDescendant(Node node) {
descendants.add( node );
}
public List<Node> getDescendants() {
return descendants;
}
@Override
public String toString() {
return name;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ( ( name == null ) ? 0 : name.hashCode() );
return result;
}
@Override
public boolean equals(Object obj) {
if ( this == obj ) {
return true;
}
if ( obj == null ) {
return false;
}
if ( getClass() != obj.getClass() ) {
return false;
}
Node other = (Node) obj;
if ( name == null ) {
if ( other.name != null ) {
return false;
}
}
else if ( !name.equals( other.name ) ) {
return false;
}
return true;
}
}