/**
* <copyright>
* </copyright>
*
*
*/
package org.dresdenocl.language.ocl.resource.ocl.grammar;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.EStructuralFeature;
/**
* A OclContainmentTrace represents a specific path to a structural feature by
* navigating over a set of a structural feature from a start class.
* OclContainmentTraces are used during code completion to reconstruct containment
* trees that are not created by the parser, for example, if the first character
* of the contained object has not been typed yet.
*/
public class OclContainmentTrace {
/**
* The class where the trace starts.
*/
private EClass startClass;
/**
* The path of contained features.
*/
private org.dresdenocl.language.ocl.resource.ocl.mopp.OclContainedFeature[] path;
public OclContainmentTrace(EClass startClass, org.dresdenocl.language.ocl.resource.ocl.mopp.OclContainedFeature[] path) {
super();
// Verify arguments
if (startClass != null) {
if (path.length > 0) {
EStructuralFeature feature = path[path.length - 1].getFeature();
if (!startClass.getEAllStructuralFeatures().contains(feature)) {
throw new RuntimeException("Metaclass " + startClass.getName() + " must contain feature " + feature.getName());
}
}
}
this.startClass = startClass;
this.path = path;
}
public EClass getStartClass() {
return startClass;
}
public org.dresdenocl.language.ocl.resource.ocl.mopp.OclContainedFeature[] getPath() {
return path;
}
public String toString() {
return (startClass == null ? "null" : startClass.getName()) + "->" + org.dresdenocl.language.ocl.resource.ocl.util.OclStringUtil.explode(path, "->");
}
}