UVL (Universal Variability Language) is a concise and extensible language for modeling variability in software product lines. It supports multiple programming languages and provides a grammar-based foundation for building tools and parsers.
This repository contains the ANTLR4 grammar files for UVL. With these, you can generate parsers for UVL tailored to specific programming languages like Java, JavaScript, and Python.
- Language-level modularity
- Namespaces and imports
- Feature trees with attributes and cardinalities
- Cross-tree constraints
- Extensible for different target languages
uvl/UVLParser.g4– Base grammar in EBNF formuvl/UVLLexer.g4– Base lexer grammar for UVLuvl/Java/UVLJava*.g4,uvl/Python/UVLPython*.g4, etc. – Language-specific grammar filesjava/– Java-based parser implementation using Mavenpython/– Python-based parser implementationjavascript/– JavaScript-based parser implementationtests/– UVL test cases for validation
UVL uses ANTLR4 as its parser generator.
Each UVL model may consist of five optional sections:
- Language levels: Enable optional concepts via
includekeyword. - Namespace: Allows referencing the model from other UVL models.
- Imports: Include other feature models (e.g.,
subdir.filename as fn). - Feature tree: Hierarchical features with cardinalities, attributes, and group types (
mandatory,optional,or,alternative). - Cross-tree constraints: Logical and arithmetic constraints among features.
namespace Server
features
Server {abstract}
mandatory
FileSystem
or
NTFS
APFS
EXT4
OperatingSystem {abstract}
alternative
Windows
macOS
Debian
optional
Logging {
default,
log_level "warn"
}
constraints
Windows => NTFS
macOS => APFS
Explanation:
Serveris an abstract feature.- It must include a
FileSystemand anOperatingSystem. Loggingis optional and includes an attribute.- Logical constraints define dependencies between features.
🔗 More examples: https://github.com/Universal-Variability-Language/uvl-models/tree/main/Feature_Models
To use UVL in your projects, you can either:
- Use the pre-built parsers
Include the following dependency in your Maven project:
Install the package via pip:
<dependency> <groupId>io.github.universal-variability-language</groupId> <artifactId>uvl-parser</artifactId> <version>0.3</version> </dependency>
Install the package via npm:pip install uvlparser
npm install uvl-parser
- Build the parser manually See the sections below for details.
- Clone the repository:
git clone https://github.com/Universal-Variability-Language/uvl-parser- Build the parser:
cd java
mvn clean package- Include the generated JAR in your Java project.
UVL Models & Tools
Tooling Ecosystem
- https://github.com/FeatureIDE/FeatureIDE
- https://ide.flamapy.org/
- https://github.com/Universal-Variability-Language/uvl-lsp
- https://github.com/SECPS/TraVarT
- https://github.com/AlexCortinas/spl-js-engine
If you use UVL in your research, please cite:
@article{UVL2024,
title = {UVL: Feature modelling with the Universal Variability Language},
journal = {Journal of Systems and Software},
volume = {225},
pages = {112326},
year = {2025},
issn = {0164-1212},
doi = {https://doi.org/10.1016/j.jss.2024.112326},
url = {https://www.sciencedirect.com/science/article/pii/S0164121224003704},
author = {David Benavides and Chico Sundermann and Kevin Feichtinger and José A. Galindo and Rick Rabiser and Thomas Thüm},
keywords = {Feature model, Software product lines, Variability}
}Feel free to open issues or pull requests if you have suggestions or improvements. For questions or collaboration inquiries, visit the UVL Website: https://universal-variability-language.github.io/