Skip to main content

This module provides a get_tree function to obtain an ANTLR parse-tree from a UVL-defined feature model

Project description

UVL parser

Documentation

Documentation for UVL can be found in the project's wiki

Dev

This python UVL parser for diverso project is generated by ANTLR from the UVL.g4 file, where the grammar is defined. In order to generate the UVL*.py files, first we need to install antlr python runtime:

pip install antlr4-python3-runtime

Then, this command should generate the files we need for the parser to work:

antlr4 -Dlanguage=Python3 -no-listener UVL.g4

With this, any grammar change or update done to the UVL.g4 file will be effective.

Usage and integration

With the grammar defined and the parser generated, get_tree.py gives us a method that, returns a ParseTree object given an uvl file via absolute path. ParseTree is an ANTLR object which represents an AST-ish structure of the file we read with the defined grammar.

This file performs a transformation from an ANTLR ParseTree to a fm_metamodel-structured FM. Pretty much every way to obtain data from this ParseTree can be seen there. However, we will give some insight into its structure for easier usage and integration.

First, these dependencies must be installed:

apt install antlr4
pip3 install antlr-denter

Now, after getting our ParseTree object from the parser:

Features and relations

root_feature = parse_tree.features().child() #Returns a ChildContext object which contains the model root feature

For any ChildContext object:

child_context.feature_spec() # Returns the feature contained in the node
child_context.feature_spec().ref() # From the feature, return the node containing its name
child_context.feature_spec().ref().WORD()[0].getText() # From feature ref, obtain its actual name. We have to get the first element from WORD() as, in imports (yet to be supported), multiple WORDs are allowed on the same ref. getText() function returns a string with the text from the node called.

child_context.feature_spec().relation() # Returns the list of RelationContext objects children of the feature called

For any RelationContext object:

relation_context.relation_spec() # Return the node containing the relation
relation_context.relation_spec().RELATION_WORD().getText() # Return a string containing the relation's name
relation_context.relation_spec().child() # Return the list of ChildContext objects the relation is parent of, with each one being processed as described above

Constraints

constraints_node = parse_tree.constraints() # Returns ConstraintsContext object
constraints_node.constraint() # Returns list of ConstraintContext objects, with each node containing a constraint

For any ConstraintContext object:

list(constraint_context.getChildren())[0] # Returns the constraint itself, it is a bit tricky due to its structure in the parser
constraint.WORD[0].getText() # Returns the left node of the constraint, [1] returns the right node
constraint.getChild(1).getText() # Returns constraint operator

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uvlparser-0.9.0.dev0.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

uvlparser-0.9.0.dev0-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file uvlparser-0.9.0.dev0.tar.gz.

File metadata

  • Download URL: uvlparser-0.9.0.dev0.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for uvlparser-0.9.0.dev0.tar.gz
Algorithm Hash digest
SHA256 1924d1344a625a1bd223dec19e9e39044f9f781cb0c592b239da5b813f675082
MD5 c205666d5250b7b977c8f77eba64cee3
BLAKE2b-256 e43b3ff1a00e0617bf97642a4b86cb212e29598c668418d91ed5391f1fb739e8

See more details on using hashes here.

File details

Details for the file uvlparser-0.9.0.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for uvlparser-0.9.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 e9c7b52e134649db2c9d122284a2ca4bd960dd016078ba2dcbb33172e3974f19
MD5 c14d6a137794087f4f056e9ce87942fe
BLAKE2b-256 b6539bbac8aa6d65f68a88abee90b8c42d1e9a380ab02f762b56bf0a3f19f252

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page