All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.fau.cs.osr.utils.visitor.VisitorInterface Maven / Gradle / Ivy

/**
 * Copyright 2011 The Open Source Research Group,
 *                University of Erlangen-Nürnberg
 *
 * 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 de.fau.cs.osr.utils.visitor;

public abstract class VisitorInterface
{
	protected abstract Object dispatch(T node);
	
	/**
	 * Called before the visitation starts.
	 * 
	 * @param node
	 *            The node at which the visitation will start.
	 * @return Always returns the node. If an overridden version of
	 *         this method returns null the visitation will be
	 *         aborted.
	 */
	protected abstract T before(T node);
	
	/**
	 * Called after the visitation has finished. This method will not be called
	 * if before() returned null.
	 * 
	 * @param node
	 *            The node at which the visitation started.
	 * @param result
	 *            The result of the visitation. If the visit() method for the
	 *            given node doesn't return a value, null is
	 *            returned.
	 * @return Returns the result parameter.
	 */
	protected abstract Object after(T node, Object result);
	
	/**
	 * This method is called if no suitable visit() method could be found. If
	 * not overridden, this method will throw an UnvisitableException.
	 * 
	 * @param node
	 *            The node that should have been visited.
	 * @return The result of the visitation.
	 */
	protected abstract Object visitNotFound(T node);
	
	/**
	 * This method is called if a visit() method throws an exception. If not
	 * overriden, this method will wrap the thrown exception in tot a
	 * VisitingException.
	 * 
	 * @param node
	 *            The node that was visited when the exception was thrown.
	 * @param cause
	 *            The exception that was thrown.
	 * @return The result of the visitation.
	 */
	protected abstract Object handleVisitingException(T node, Throwable cause);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy