Project

bel_parser

0.01
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Implements language versions 1.0 and 2.0.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

 Project Readme

bel_parser

The bel_parser gem implements BEL specifications (currently 1.0 and 2.0) and BEL Script nanopub format.

Installation

gem install bel_parser

Motivation

The motivation for this library is to provide the building blocks to implement BEL specifications more easily. This includes:

  • Recognizing input to Abstract Syntax Trees
  • Applying syntax validation relative to a BEL specification.
  • Applying signature validation relative to a BEL specification.
  • Conversion of Abstract Syntax Trees to a Nanopub object model.

Currently BEL 1.0 and 2.0 specifications are implemented.

Getting Started

bel_parser provides a Ruby library and a set of command-line tools.

Command-line tools:

  1. bel2_debug_ast

Writes the AST output recognized from the input.

usage: bel2_debug_ast (Then enter a line at a time)

usage: bel2_debug_ast --file file.bel

  1. bel2_validator

Validate the syntax and semantics of the AST recognized from the input.

usage: bel2_validator (Then enter a line at a time)

usage: bel2_validator --file file.bel --specification 2.0

  1. bel2_upgrade

Upgrades BEL statements from 1.0 to 2.0.

usage: bel2_upgrade (Then enter a line at a time)

usage: bel2_upgrade --file file.bel

Development / Deployment

Development for the next release should be performed on the next branch. When the new changes are complete, functional, and tested they should be merged over to the master branch.

To make a release, perform the following steps:

  • Update the version in the VERSION file.

  • Add a new version with list of changes in the CHANGELOG file. This file is modelled after http://keepachangelog.com/.

  • Build the Ruby and Java versions of the gem:

    Ruby: gem build .gemspec

    Java: jruby -S gem build .gemspec

  • Create a release on GitHub with both gems and a summary of the changes in this version.

  • Push both gems to RubyGems:

    gem push bel_parser-VERSION.gem

    gem push bel_parser-VERSION-java.gem