Skip to content

Latest commit

 

History

History
115 lines (81 loc) · 2.69 KB

README.md

File metadata and controls

115 lines (81 loc) · 2.69 KB
   ____  __  ___     __            _______
  / __ \/  |/  /__  / /_____ _    / / ___/
 / / / / /|_/ / _ \/ __/ __ `/_  / /\__ \
/ /_/ / /  / /  __/ /_/ /_/ / /_/ /___/ /
\____/_/  /_/\___/\__/\__,_/\____//____/

OMetaJS Build Status

OMetaJS is a JavaScript implementation of the OMeta, an object-oriented language for pattern matching.

This is a node.js module for developing and using such pattern matching grammars.

Installation

Installing npm (node package manager)

$ curl http://npmjs.org/install.sh | sh

Installing ometajs

$ [sudo] npm install ometajs -g

Note: If you are using ometajs programatically you should not install it globally.

$ cd /path/to/your/project
$ npm install ometajs

Usage

Command line

$ ometajs2js --help

Usage:
  ometajs2js [OPTIONS] [ARGS]


Options:
  -h, --help : Help
  -v, --version : Version
  -i INPUT, --input=INPUT : Input file (default: stdin)
  -o OUTPUT, --output=OUTPUT : Output file (default: stdout)
  --root=ROOT : Path to root module (default: ometajs)

ometajs2js will take input *.ometajs file and produce CommonJS compatible javascript file.

Also you may require('*.ometajs') files directly without compilation. (OmetaJS is patching require.extensions as CoffeeScript does).

Using as CommonJS module

var ometajs = require('ometajs');

var ast = ometajs.grammars.BSJSParser.matchAll('var x = 1', 'topLevel'),
    code = ometajs.grammars.BSJSTranslator.matchAll([ast], 'trans');

Example

Example grammar

ometa Simple {
  top = [#simple] -> 'ok'
}

More information about OmetaJS syntax.

Use cases

Fast prototyping and building your own parser/language. Processing/traversing complex AST.

Some projects that are using this:

More information

To study OmetaJS or ask questions about it's core you can try to reach out original repository author Alessandro Warth or me.

Here is documented code.

Contributors