de.rhocas.featuregen.ap.FeatureIDEFeatures.xtend Maven / Gradle / Ivy
////////////////////////////////////////////////////////////////////////////////////
// //
// MIT License //
// //
// Copyright (c) 2018 Nils Christian Ehmke //
// //
// Permission is hereby granted, free of charge, to any person obtaining a copy //
// of this software and associated documentation files (the "Software"), to deal //
// in the Software without restriction, including without limitation the rights //
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell //
// copies of the Software, and to permit persons to whom the Software is //
// furnished to do so, subject to the following conditions: //
// //
// The above copyright notice and this permission notice shall be included in all //
// copies or substantial portions of the Software. //
// //
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR //
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, //
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE //
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER //
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, //
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE //
// SOFTWARE. //
// //
////////////////////////////////////////////////////////////////////////////////////
package de.rhocas.featuregen.ap
import java.lang.annotation.Retention
import java.lang.annotation.Target
import org.eclipse.xtend.lib.macro.Active
/**
* This active annotation is used to generate the features from a FeatureIDE model file.
*
* @author Nils Christian Ehmke
*
* @since 1.0.0
*/
@Target(TYPE)
@Retention(CLASS)
@Active(FeatureIDEFeaturesProcessor)
annotation FeatureIDEFeatures {
/**
* The path to a feature model file from the {@code FeatureIDE} containing the available features. The file path is relative to the annotated class.
* If the file path starts with a slash ({@code /}), the file path is absolute to the project source folder. If this value is not given, it is
* assumed that the feature model is contained in a file {@code model.xml} next to the annotated class. Please note: Due to restrictions of the
* active annotations, the file must be contained in the same project and the same source folder as the annotated class.
*
* @since 1.0.0
*/
String value = ''
/**
* This prefix is prepended to each feature.
*
* @since 1.0.0
*/
String prefix = ''
/**
* This suffix is appended to each feature. This is set to {@code _FEATURE} by default.
*
* @since 1.0.0
*/
String suffix = '_FEATURE'
}