Linux and UNIX Man Pages

Linux & Unix Commands - Search Man Pages

jocamlyacc(1) [debian man page]

JOCAMLYACC(1)						      General Commands Manual						     JOCAMLYACC(1)

NAME
jocamlyacc - The JoCaml parser generator SYNOPSIS
jocamlyacc [ -v ] [ -bprefix ] filename.mly DESCRIPTION
The jocamlyacc(1) command produces a parser from a LALR(1) context-free grammar specification with attached semantic actions, in the style of yacc(1). Assuming the input file is grammar.mly, running jocamlyacc produces Caml code for a parser in the file grammar.ml, and its interface in file grammar.mli. The generated module defines one parsing function per entry point in the grammar. These functions have the same names as the entry points. Parsing functions take as arguments a lexical analyzer (a function from lexer buffers to tokens) and a lexer buffer, and return the seman- tic attribute of the corresponding entry point. Lexical analyzer functions are usually generated from a lexer specification by the jocam- llex(1) program. Lexer buffers are an abstract data type implemented in the standard library module Lexing. Tokens are values from the con- crete type token, defined in the interface file grammar.mli produced by jocamlyacc(1). OPTIONS
The jocamlyacc(1) command recognizes the following options: -v Generate a description of the parsing tables and a report on conflicts resulting from ambiguities in the grammar. The description is put in file grammar.output. -bprefix Name the output files prefix.ml, prefix.mli, prefix.output, instead of the default naming convention. SEE ALSO
jocamllex(1). The Objective Caml user's manual, chapter "Lexer and parser generators". JOCAMLYACC(1)

Check Out this Related Man Page

OCAMLLEX(1)						      General Commands Manual						       OCAMLLEX(1)

NAME
ocamllex - The OCaml lexer generator SYNOPSIS
ocamllex [ -o output-file ] [ -ml ] filename.mll DESCRIPTION
The ocamllex(1) command generates OCaml lexers from a set of regular expressions with associated semantic actions, in the style of lex(1). Running ocamllex(1) on the input file lexer.mll produces OCaml code for a lexical analyzer in file lexer.ml. This file defines one lexing function per entry point in the lexer definition. These functions have the same names as the entry points. Lexing functions take as argument a lexer buffer, and return the semantic attribute of the corresponding entry point. Lexer buffers are an abstract data type implemented in the standard library module Lexing. The functions Lexing.from_channel, Lex- ing.from_string and Lexing.from_function create lexer buffers that read from an input channel, a character string, or any reading function, respectively. When used in conjunction with a parser generated by ocamlyacc(1), the semantic actions compute a value belonging to the type token defined by the generated parsing module. OPTIONS
The ocamllex(1) command recognizes the following options: -ml Output code that does not use OCaml's built-in automata interpreter. Instead, the automaton is encoded by OCaml functions. This option is mainly useful for debugging ocamllex(1), using it for production lexers is not recommended. -o output-file Specify the name of the output file produced by ocamllex(1). The default is the input file name, with its extension replaced by .ml. -q Quiet mode. ocamllex(1) normally outputs informational messages to standard output. They are suppressed if option -q is used. -v or -version Print version string and exit. -vnum Print short version number and exit. -help or --help Display a short usage summary and exit. SEE ALSO
ocamlyacc(1). The OCaml user's manual, chapter "Lexer and parser generators". OCAMLLEX(1)
Man Page