/*******************************************************************************
* Copyright (c) 2009, 2010 SAP AG 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
*
* Contributors:
* SAP AG - initial API and implementation
******************************************************************************/
package org.eclipse.ocl.examples.impactanalyzer.debug.extraction;
import java.util.HashSet;
import java.util.Set;
import org.eclipse.ocl.examples.impactanalyzer.debug.GraphContext;
import org.eclipse.ocl.examples.impactanalyzer.instanceScope.AbstractNavigationStep;
import org.eclipse.ocl.examples.impactanalyzer.instanceScope.NavigationStep;
import y.base.Node;
public abstract class AbstractGraphExtractor implements GraphExtractor {
private NavigationStep navigationStepDelegate;
public AbstractGraphExtractor(NavigationStep delegate) {
this.navigationStepDelegate = delegate;
}
protected NavigationStep getNavigationStepDelegate() {
return navigationStepDelegate;
}
public Node buildGraph(GraphContext graphContext) {
// Create a new root group node
return buildGraph(graphContext, graphContext.createRootNode(), null);
}
public boolean hasBeenNavigated() {
if (((AbstractNavigationStep) getNavigationStepDelegate()).getNavigateCounter() > 0) {
return true;
} else {
return false;
}
}
public int getSumOfNavigateCounter(){
Set<NavigationStep> visited = new HashSet<NavigationStep>();
return visited.contains(this) ? 0 : getSumOfNavigateCounter(visited);
}
public int getSumOfNavigateCounter(Set<NavigationStep> visited){
return ((AbstractNavigationStep)getNavigationStepDelegate()).getNavigateCounter();
}
}