-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CHANGES: Requires Menhir 20211230 and OCaml 4.08 or above. - Compiler: - Improve performance of separate compilation - CHR: - Syntax extension for constraint declaration. - This aims to avoid the `overlapping` clique error - Example: `constraint c t x ?- p1 p2 { rule (Ctx ?- ...) <=> (Ctx => ...) }` - `c`, `t` and `x` are the symbols which should be loaded in the rule of the constraint and should be considered as symbols composing the context (`Ctx`) under which `p1` and `p2` are used.
- Loading branch information
Showing
1 changed file
with
90 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
opam-version: "2.0" | ||
maintainer: "Enrico Tassi <[email protected]>" | ||
authors: [ "Claudio Sacerdoti Coen" "Enrico Tassi" ] | ||
license: "LGPL-2.1-or-later" | ||
homepage: "https://github.com/LPCIC/elpi" | ||
doc: "https://LPCIC.github.io/elpi/" | ||
dev-repo: "git+https://github.com/LPCIC/elpi.git" | ||
bug-reports: "https://github.com/LPCIC/elpi/issues" | ||
|
||
build: [ | ||
["dune" "subst"] {dev} | ||
["dune" "build" "-p" name "-j" jobs] | ||
[make "tests" "DUNE_OPTS=-p %{name}%" "SKIP=performance_HO" "SKIP+=performance_FO" "SKIP+=elpi_api_performance"] {with-test & os != "macos" & os-distribution != "alpine" & os-distribution != "freebsd"} | ||
] | ||
|
||
depends: [ | ||
"ocaml" {>= "4.08.0" } | ||
"stdlib-shims" | ||
"ppxlib" {>= "0.12.0" } | ||
"menhir" {>= "20211230" } | ||
"re" {>= "1.7.2"} | ||
"ppx_deriving" {>= "4.3"} | ||
"ANSITerminal" {with-test} | ||
"cmdliner" {with-test} | ||
"fileutils" {with-test} | ||
"dune" {>= "2.8.0"} | ||
"conf-time" {with-test} | ||
"atdgen" {>= "2.10.0"} | ||
"atdts" {>= "2.10.0"} | ||
"odoc" {with-doc} | ||
] | ||
synopsis: "ELPI - Embeddable λProlog Interpreter" | ||
description: """ | ||
ELPI implements a variant of λProlog enriched with Constraint Handling Rules, | ||
a programming language well suited to manipulate syntax trees with binders. | ||
|
||
ELPI is designed to be embedded into larger applications written in OCaml as | ||
an extension language. It comes with an API to drive the interpreter and | ||
with an FFI for defining built-in predicates and data types, as well as | ||
quotations and similar goodies that are handy to adapt the language to the host | ||
application. | ||
|
||
This package provides both a command line interpreter (elpi) and a library to | ||
be linked in other applications (eg by passing -package elpi to ocamlfind). | ||
|
||
The ELPI programming language has the following features: | ||
|
||
- Native support for variable binding and substitution, via an Higher Order | ||
Abstract Syntax (HOAS) embedding of the object language. The programmer | ||
does not need to care about technical devices to handle bound variables, | ||
like De Bruijn indices. | ||
|
||
- Native support for hypothetical context. When moving under a binder one can | ||
attach to the bound variable extra information that is collected when the | ||
variable gets out of scope. For example when writing a type-checker the | ||
programmer needs not to care about managing the typing context. | ||
|
||
- Native support for higher order unification variables, again via HOAS. | ||
Unification variables of the meta-language (λProlog) can be reused to | ||
represent the unification variables of the object language. The programmer | ||
does not need to care about the unification-variable assignment map and | ||
cannot assign to a unification variable a term containing variables out of | ||
scope, or build a circular assignment. | ||
|
||
- Native support for syntactic constraints and their meta-level handling rules. | ||
The generative semantics of Prolog can be disabled by turning a goal into a | ||
syntactic constraint (suspended goal). A syntactic constraint is resumed as | ||
soon as relevant variables gets assigned. Syntactic constraints can be | ||
manipulated by constraint handling rules (CHR). | ||
|
||
- Native support for backtracking. To ease implementation of search. | ||
|
||
- The constraint store is extensible. The host application can declare | ||
non-syntactic constraints and use custom constraint solvers to check their | ||
consistency. | ||
|
||
- Clauses are graftable. The user is free to extend an existing program by | ||
inserting/removing clauses, both at runtime (using implication) and at | ||
"compilation" time by accumulating files. | ||
|
||
ELPI is free software released under the terms of LGPL 2.1 or above.""" | ||
url { | ||
src: | ||
"https://github.com/LPCIC/elpi/releases/download/v1.19.5/elpi-1.19.5.tbz" | ||
checksum: [ | ||
"sha256=033f1e86d155a53bc1908fd5ee8bff007bc924866b5cd066a053bce154635715" | ||
"sha512=ddf0c7e1a3ed9b8d9be765e96c937f4b35ebefef0aeeef77bb05b1e4a5ed78c5cc34bc37a486ca6855ac5af8f038dbdbab361d0c210b5f8115cbf1c254136252" | ||
] | ||
} | ||
x-commit-hash: "f27441e35eff9379b1c1839ee165ad533759e79d" |