Přejít na soubor
Aleksey Chichenkov 1091e507b6 readme 2019-01-31 11:55:21 +03:00
documentation first commit 2019-01-28 15:08:59 +03:00
example remove dependencies 2019-01-30 18:03:10 +03:00
lemon-src rm 2019-01-28 15:16:25 +03:00
libs remove dependencies 2019-01-30 18:03:10 +03:00
parser_template fix readme and add input config 2019-01-30 14:50:02 +03:00
require_js template 2019-01-31 11:19:42 +03:00
README.md readme 2019-01-31 11:55:21 +03:00
build-example.sh readme 2019-01-30 18:07:22 +03:00
build.sh remove dependencies 2019-01-30 18:03:10 +03:00
config.example fix readme and add input config 2019-01-30 14:50:02 +03:00
config.template fix readme and add input config 2019-01-30 14:50:02 +03:00
main.js add require_template 2019-01-31 11:18:50 +03:00
package.json remove dependencies 2019-01-30 18:03:10 +03:00
test.js remove dependencies 2019-01-30 18:03:10 +03:00

README.md

Requires

  • node
  • npm
  • gcc

Install

# bash
git clone -- http://git.macaw.me:3000/chichenkov/LemonJS
cd LemonJS

gcc -o ./lemon-src/lemon-js -O2 ./lemon-src/lemon-js.c
#or
./build.sh

Start

node main.js --c=<your_config>.js --t=<web|node>

Example (One minute start)

Also you can build example config

./build-example.sh

node main.js
#or test if want check work
node test.js

Configurate

You need create your config.js from config.template or config.example

var config = {
    lemon_bin: "./lemon-src/lemon-js", // папка с исходниками лемона
    input_path: "parser_template/", // папка с шаблоном парсера
    output_path: "out/", // папка куда будет выгружен файл
    file_name: "parser", // имя файла шаблона
    flags: "-l", // флаги для ./lemon-js
    require_template: "require_js/" // Папка для шаблона require_js/
};
cat config.template > config.js
# or
cat config.example > config.js

Test

Also you can test your parser

node test.js --c=<your_config>.js

Also

You can use this syntax for include your *.y file.

<&&REPLACER{<file_path>}&&>

Special Directives

See lemon.html for additional documentation.

  • %name - Set parser class name (default is "Parse")
  • %include - Include code in the beginning of file (usefull for imports)
  • %code - Include code in the end of file (usefull for exports or main code)
  • %token_destructor - Define code which will be executed on token destruction.
  • %default_destructor
  • %token_prefix - Define token name prefix.
  • %syntax_error - Define custom error handler for syntax erorrs.
  • %parse_accept - Define handler for all accepted tokens.
  • %parse_failure - Define handler for parse errors.
  • %stack_overflow - Define handler for stack overflow.
  • %extra_argument - NOT SUPPORTED
  • %token_type - NOT SUPPORTED
  • %default_type - NOT SUPPORTED
  • %stack_size - Set default stack size.
  • %start_symbol
  • %left - Set left associative tokens.
  • %right - Set right associative tokens.
  • %nonassoc - Set non associative tokens.
  • %destructor - Define custom parser destructor.
  • %type - NOT SUPPORTED
  • %fallback - Define fallback logic for tokens.
  • %wildcard - Define WILDCARD token.
  • %token_class - NOT SUPPORTED

Lexer

Used re2js lexer from: http://git.macaw.me:3000/chichenkov/re2-js-generator

Original project

See https://github.com/sormy/lemon-js