package acgtk
Install
Dune Dependency
Authors
Maintainers
Sources
sha512=e0c72426381259e9ce599c160f83ecf411eaf48b8b050d9c3e87b63d124a719cbc58101892e9594ea30c6ad8950b0dc66c84debca1ca3c370d81fc6654afd21c
CHANGES.md.html
Version 2.0.0
Various bug fixes
The acg
interpreter:
Changes
Completely new command langage. Warning: It breaks backward compatibility. For a list of the available commands, run
acg
andhelp
. See https://acg.gitlabpages.inria.fr/dev/ACGtk/master/acgtk/scripting.html.Adds completion capabilities to the command language.
Improve sorting the terms to be printed as result of a
parse
command.Allow parsing with magic set rewritten programs (experimental)
Command line arguments
-c
or ---colors
: to control colors in the output. Useyes
to enable colors,no
to disable them, orauto
to enable them if the output is a TTY.-d
or--debug
: startsacg
in debug mode: it will record and print backtraces of uncaught exceptions.-i
or--interacgtive
: starts interactive mode even if script files are provided, i.e., after running the script, move to interactive mode.-I
or--include
: to add directories where to look for object and data files.-m
or--magic
: Toggle on using magic set rewritten programs for parsing (experimental feature). When set, parsing commands using magic rewritten programs (if available in object files generated byacgc
).-r
or--seed
: set a seed value to use for initialization of the random number generator (useful for thelist-terms
command ofacg
). If this paramenter is not provided, the random number generator will be initialized with a random seed.--realize
: sets the json config rendering file for the svg generated (by the realize command) files.-s
or--step-by-step
: runs scripts step by step. This means that the execution will be paused before each command, and after printing the result of commands which return terms. Also, this will print the executed script during the execution."--version
to get the version number of the software.
The acgc
compiler:
acg data language
Now use UTF-8 symbols
New syntax for identifiers, operators and binders. See https://acg.gitlabpages.inria.fr/dev/ACGtk/master/acgtk/users.html#identifiers and https://acg.gitlabpages.inria.fr/dev/ACGtk/master/acgtk/users.html#symbols.
Command line arguments
-i
flag and interactive mode are removed. Command line arguments are now:-c
or ---colors
: to control colors in the output. Useyes
to enable colors,no
to disable them, orauto
to enable them if the output is a TTY.-d
or--debug
: startsacgc
in debug mode: it will record and print backtraces of uncaught exceptions.-I
or--include
: to add directories where to look for object and data files-m
or--magic
: toggles on generating magic programs. This is an experimental feature. Parsing with magic will be available inacg
. Be aware that using this option may cause generated object files to be very large.-o
or--output
: to output the result in a specific file (instead of a filefile.acgo
idfile.acg
was the last file provided as argument.-v
or--verbosity
: verbosity level. For the moment, only 0 (when the flag is not provided) or 1 (default when the flag is provided) are available. If the level is greater, than all debug information are printed. Be aware that positional argument(s) (files) may need to be separated by "--" if no other optional argument is provided after "-v".--version
to get the version number of the software.
Version 1.5.4
Various bug fixes
The acg.opt
/acg
interpreter:
Add a
all-parse
command to get all the possible parses (possibly infinitely many) of an object term.
Version 1.5.3
Various bug fixes
Prepare Datalog prover extension to handle states and weights for probabilistic ACG
Version 1.5.2
Fixes build dependency to menhir generated messages
Various bug fixes
Version 1.5.1
Remove dependency to the ocf package
Arguments of acg
and acgc
are now handled by the Cmdliner library
For
acgc
, arguments are now:
--version
(instead of-version
) to get the version number of the software-o
and--output
(instead of only-o
) to output the result in a specific file-I
and--include
(instead of only-I
) to add directories where to look for files-i
and--interactive
(instead of only-i
) to enter the interaction loop--help
(instead of-help
and--help
) to get help
For
acg
, arguments are now:
--version
(instead of-version
) to get the version number of the software-I
and--include
(instead of only-I
) to add directories where to look for files--nc
and--no-color
(instead of-nc
) to toggle off output coloring--npp
and--no-pretty-printing
(instead of-npp
) to toggle off output pretty printing--nsvg
and--no-svg
(instead of-nsvg
) to toggle off svg output of therealize
acg command--realize
(instead of-realize
) to set the configuration file with the rendering engines--svg
(instead of-svg
) to set the file name of the svg output of therealize
acg command--help
(instead of-help
and--help
) to get help
Version 1.5.0
The acgc.opt
/acgc
compiler and the acg.opt
/acg
interpreter:
Removed the dependency to BOLT (replaced by Logs) and dypgen (replaced by menhir)
Some syntax changes:
Prefix operators have the highest priority
Application has precedence over infix operators
An associativity property (none, left, right) can be set to infix operators (left is the default), and a precedence level as well. See the associativity and the precedence section in the README.
Infix operator can be used as usual constant by surrounding then with left and right parenthesis, so that
t SYM u
=(SYM) t u
Version 1.4.0
The acgc.opt
/acgc
compiler and the acg.opt
/acg
interpreter:
Improved performance by better logging management (for debug)
Extended set of latin1 characters allowed in .acg files
Version 1.3.3
The acgc.opt
/acgc
compiler and the acg.opt
/acg
interpreter:
the build process now relies on
jbuilder
Version 1.3.1
The acg.opt
/acg
interpreter
Bug fix: constants that were given two interpretations in a lexicon (only the last one is available) generated two rules in the corresponding datalog program (hence possibly several parses)
Bug fix: when an object constant was the direct interpretation of an abstract constant, parsing this object constant raised an exception
an option
-svg filename
is added to./acg
and./acg.opt
to allow the user to provide another name than the defaultrealize.svg
to the svg output file.
Configuration and opam file
an option
--disable-warning-as-errors
to the.configure
script in order to make opam compile without the-warn-error A
option.
Version 1.3.0
The acg.opt
/acg
interpreter
Colors and link between signature and rendering engines are now defined in a json configuration file. The option to load the configuration is
-realize
.
Version 1.2
The acg.opt
/acg
interpreter
Added the generation of a
realize.svg
file when therealize
command ofacg
is invoked. Colors and link between signature and rendering engines are hard-coded.An option is added to toggle of the
realize.svg
file generation (takes a bit of time)
Version 1.1
The acgc.opt
/acgc
compiler and the acg.opt
/acg
interpreter:
Fixed severe bug that prevented finding some parses and sometimes caused a
Fatal Error
Added a control on the compiler version that generated the object (
.acgo
) files. The version has to be the same as the current version of the compiler or of the interpreter that is being used.
The acgc.opt
/acgc
compiler:
added a
nl_lexicon
keyword that causes the interpretation of any functional type (->
or=>
) of the abstract signature to be interpreted by the intuitionistic arrow=>
in the object signature.Accordingly, the interpretation should use
Lambda
.
The acg.opt
/acg
interpreter:
Improved terminal output (colors and formatting)
added a
-nc
option to disable colored outputsadded a
-npp
option to disable formatting on the output
The acg emacs mode
improved handling of long files
Version 1.0b
The acgc.opt
/acgc
compiler:
Now outputs an
file.acgo
file when compilation is successfulCan declare a lexicon as the composition of two other lexicons using the following declaration:
lexicon lex_name = lex_name2 << lex_name1
The acg.opt
/acg
interpreter:
Can load an acg object file using the command:
load o file.acco;
The
analyse
command is deprecated. It is replaced by:A
check
command, prefixed by signatures, that typecheck the typing assignment of a termSig1 Sig2 check term:type;
A
realize
command that must be preceded by lexicons and followed by the type assignment of a term. It checks that the term is well typed in the abstract signatures of the lexicons and compute its realizations through the lexicons.Lex1 Lex2 realize term:type;
A
parse
command has been added. It must be preceded with the name of a lexicon and it returns the antecedent by this lexicon of the input term with respect to some distinguished (atomic) type:Lex parse object_term:distinguished_type;
A
query
command has been added. It follows theparse
command syntax and it outputs the associated query and associated extensional database.
Lex query object_term:distinguished_type;
A
idb
command has been added. It must be preceded with the name of a lexicon and it returns the intensional database associated with the lexicon
Lex idb;
Current limitation:
Only parse images of atomic types
The result of parsing with non-linear lexicons is unspecified yet