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

org.eclipse.emf.databinding.FeaturePath Maven / Gradle / Ivy

The newest version!
/**
 * 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 v2.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v20.html
 * 
 * Contributors: 
 *   Tom Schindl  - port to EMF in 262160
 */
package org.eclipse.emf.databinding;

import org.eclipse.emf.ecore.EStructuralFeature;


/**
 * 

PROVISIONAL: This API is subject to arbitrary change, including renaming or removal.

* * 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); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy