ekuiter / feature-php
Feature-oriented programming with PHP and FeatureIDE
Requires
- php: >=5.3.0
- ekuiter/feature-schema: ^1.0
- nikic/php-parser: ^3.1
This package is not auto-updated.
Last update: 2025-01-05 14:04:51 UTC
README
feature-php is a Composer package for analyzing and implementing feature-oriented software product lines.
It can be used to:
- analyze and validate FeatureIDE feature models and configurations (domain analysis)
- implement and trace features using the following variability mechanisms
(domain implementation):
- runtime variability for PHP code
- build-system-like copying of files and directories
- preprocessor-like template and chunk systems
- feature-oriented programming (mixin-based)
- aspect-oriented programming (using Go! AOP)
- generate products and export them (e.g. as a ZIP file) (product derivation)
(If you'd like some visual tools for feature models and configurations, have a look at ekuiter/feature-configurator or ekuiter/feature-model-viz.)
Requirements
To use feature-php, the following is required:
- PHP >= 5.3
- the libxml and SimpleXML extensions (most servers have these)
Also recommended are:
- the DOM extension (for validating XML data)
- the ZIP extension (for exporting products as ZIP files)
feature-php also depends on some Composer packages:
- ekuiter/feature-schema for validating feature models and configurations
- nikic/PHP-Parser for feature- and aspect-oriented programming
To install the dependencies, create the following composer.json
file:
{ "minimum-stability": "dev", "require": { "ekuiter/feature-php": "dev-master" } }
Then run composer install
(more information on
Composer). Refer to the guide for further
information.
Usage
Check out the User Guide for installation and usage.
For a quick start, you can also
- look at the example below
- try ekuiter/feature-web
- run the command-line interface with
vendor/bin/feature-php
API Reference
The API reference for feature-php can be found here.
A good starting point is the ProductLine class. If you want to learn about configuration files, have a look at the ProductLine\Settings class.
Example
Command line interface
After installing, run:
vendor/bin/feature-php --settings <productLine.json> --configuration <configuration.xml>
in your project root to analyze a given configuration. For more information on
the command-line interface, run vendor/bin/feature-php
or refer to the
guide. To see example input files, see
uvr2web.json
and
UVR1611.xml.
Script usage
<?php /* * This is a simple example for the usage of the feature-php library. * Here we are going to analyze a given feature model regarding a given configuration. * Then, for a valid configuration, we analyze the generated product. * Finally, the user may export a ZIP file and download it. * * Feature models and configurations are expected to be supplied as * FeatureIDE XML files, see https://featureide.github.io/. * The product line settings can be supplied in various formats, see * the feature-php API reference. */ use \FeaturePhp as fphp; // this is just for convenience so we can abbreviate the prefix "FeaturePhp\" below require "vendor/autoload.php"; // include classes from Composer // feature-php may throw exceptions, in particular on parsing errors. // We just output an exception if we get one. try { // read a product line settings file, containing the model and the default configuration $productLine = new fphp\ProductLine\ProductLine(fphp\ProductLine\Settings::fromFile("config.json")); // alternatively you can supply the settings directly as an array $productLine = new fphp\ProductLine\ProductLine(fphp\ProductLine\Settings::fromArray(array( "model" => "model.xml", "defaultConfiguration" => array( "data" => "<configuration></configuration>" ) ))); // the configuration is user-supplied with the GET or POST parameter "configuration" // we could also use XmlConfiguration::fromString(...) or XmlConfiguration::fromFile(...) if (isset($_REQUEST["configuration"])) $configuration = new fphp\Model\Configuration( $productLine->getModel(), fphp\Model\XmlConfiguration::fromRequest("configuration") ); else // if not supplied, use the default configuration $configuration = $productLine->getDefaultConfiguration(); // used for replacements by the templating system fphp\Specification\ReplacementRule::setConfiguration($configuration); if (!isset($_REQUEST["generate"])) { // output some information on the model and configuration echo '<h2><a href="?generate">Generate</a></h2>'; echo $configuration->renderAnalysis(); } else { // we want to generate or export a product $product = $productLine->getProduct($configuration); if (!isset($_REQUEST["export"])) { // output some information on the product echo '<h2><a href="?generate&export">Download ZIP</a></h2>'; echo $product->renderAnalysis(); } else // export product as ZIP file (using "tmp" as a temporary directory) $product->export(new fphp\Exporter\DownloadZipExporter("tmp")); } } catch (Exception $e) { echo $e->getMessage(); } ?>
License
This project is released under the LGPL v3 license.