package elpi
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
ELPI - Embeddable λProlog Interpreter
Install
dune-project
Dependency
Authors
Maintainers
Sources
elpi-3.4.1.tbz
sha256=deb40fc3dd5d1c0aa9eb52931e4d54384aa1e6cc96ad9675575ff5784f1cc88f
sha512=71092d086b9ad72a5b6e08ecfa2fa896bd109730c1896ff0cfe7465be6d7dc5faff033e0bd518e450279925e38ac1cb254ce18f90235b3492508ce346a3d1efc
doc/trace_ppx/Trace_ppx/index.html
Module Trace_ppxSource
elpi.trace.ppx provides the following syntax extensions:
type t = { a : T; b : S [@trace] }
let rec f x (w[@trace]) =
[%trace "f" (fun fmt -> .. x ..) begin
match x with
| K1 -> ...
| K2 x -> [%tcall f x]
| K2(x,y) ->
let z = f x in
[%spy "z" ~rid ~gid ~cond (fun fmt z -> .. z ..) z];
[%spyl "z" ~rid ~gid ~cond (fun fmt z -> .. z ..) zs];
[%log "K2" ~rid "whatever" 37];
let x[@trace] = ... in e
let w = { a; b = b[@trace ] } in
match w with
| { a; b = b [@trace] } ->
z + f y (b[@trace])
end]
[%end_trace "stop" ~rid]
If --cookie "elpi_trace=\"true\"" is not passed to the ppx rewriter:
[%end_trace "stop" ~rid]--->()[%trace "foo" pp code]--->code[%tcall f x]--->f x[%spy ...][%spyl ...]and[%log ...]--->()f x (y[@trace]) z--->f x zlet x[@trace] = .. in e--->etype x = { a : T; b : T [@trace] }--->type x = { a : T }{ a; b = b [@trace] }--->{ a }(in both patterns and expressions)T -> (S[@trace]) -> U--->T -> U
In records, the shorcut "x" to mean "x = x" does not work, you have to use the longer form.
Source
val trace :
rid:Ppxlib_ast.Ast.expression ->
loc:Ppxlib.location ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expressionSource
val spy :
loc:Ppxlib.location ->
(loc:Ppxlib.location -> unit -> Ppxlib_ast.Ast.expression) ->
?cond:Ppxlib_ast.Ast.expression ->
rid:Ppxlib_ast.Ast.expression ->
?gid:Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression list ->
Ppxlib_ast.Ast.expressionSource
val spyl :
loc:Ppxlib.location ->
(loc:Ppxlib.location -> unit -> Ppxlib_ast.Ast.expression) ->
?cond:Ppxlib_ast.Ast.expression ->
rid:Ppxlib_ast.Ast.expression ->
?gid:Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression list ->
Ppxlib_ast.Ast.expressionSource
val log :
loc:Ppxlib.location ->
Ppxlib_ast.Ast.expression ->
rid:Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expressionSource
val end_trace :
loc:Ppxlib.location ->
rid:Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expressionSource
val tcall :
loc:Ppxlib.location ->
Ppxlib__.Import.expression ->
Ppxlib__.Import.expression list ->
Ppxlib_ast.Ast.expressionSource
val spyl_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expressionSource
val spy_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expressionSource
val tcall_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expressionSource
val trace_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expressionSource
val cur_pred_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib_ast.Ast.expression ->
Ppxlib_ast.Ast.expressionSource
val log_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expressionSource
val end_trace_expand_function :
loc:Ppxlib.location ->
path:'a ->
Ppxlib.expression ->
Ppxlib_ast.Ast.expression sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>