/** * Copyright (c) 2009 BestSolution.at 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: * Tom Schindl <tom.schindl@bestsolution.at> - port to EMF in 262160 */ package org.eclipse.emf.databinding; import org.eclipse.emf.ecore.EStructuralFeature; /** * <p><b>PROVISIONAL:</b> This API is subject to arbitrary change, including renaming or removal.</p> * * Encapsulate a path to features also known as nested feature like person.name * * @since 2.5 * @noextend This interface is not intended to be extended by clients. * @noimplement This interface is not intended to be implemented by clients. */ public class FeaturePath { private EStructuralFeature[] featurePath; private FeaturePath(EStructuralFeature[] featurePath) { this.featurePath = featurePath; for (int i = 0; i < featurePath.length - 1; i++) { if (featurePath[i].isMany()) { throw new IllegalArgumentException("The feature " + featurePath[i].getName() + " is multi valued."); } } } /** * @return the path to the feature from the local position */ public EStructuralFeature[] getFeaturePath() { return featurePath; } /** * Create a feature path from the list of given features * * @param featurePath * the list of feature to go from the local instance to the * requested instance. The features all have to be single valued ones. * @return the path constructed * @throws IllegalArgumentException if one of the features beside the last one is a list */ public static FeaturePath fromList(EStructuralFeature... featurePath) { return new FeaturePath(featurePath); } }