-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathoption.elpi
33 lines (25 loc) · 970 Bytes
/
option.elpi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/*
* Copyright (C) BlueRock Security Inc. 2024
*
* SPDX-License-Identifier: LGPL-2.1 WITH BedRock Exception for use over network, see repository root for details.
*/
/** * Options */
accumulate "bedrock.elpi.extra/Program/both/option". % ../both/option.elpi
namespace option {
pred of_term i:term, i:(term -> A -> prop), o:option A. % May panic
pred as_term i:option A, i:term, i:(A -> term -> prop), o:term. % May panic
/*
Implementation
*/
of_term T F O :- std.do! [
coq.eval_whd_all T Tred,
( Tred = {{ lib:core.option.None }} , !, O = none
; Tred = {{ lib:core.option.Some lp:V }}, !, std.assert! (F V R) "option.of_term", O = some R
; coq.error "option.of_term: Expected <<option>> constructor:" {coq.term->string Tred} )
].
as_term none Ty _ {{ lib:@core.option.None lp:Ty }} :- !.
as_term (some V) Ty F T :- std.do! [
std.assert! (F V VT) "option.as_term",
T = {{ lib:@core.option.Some lp:Ty lp:VT }},
].
}