-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathambient.v
89 lines (69 loc) · 2.18 KB
/
ambient.v
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
Require Import List.
Require Import ZArith.
Open Scope Z_scope.
(* K ::= cap[P] P \in CN \union AN \union {*} \un*)
Inductive CapType := Cap : list Z -> CapType.
(* m ::= mob[P C] avec P,C \in CN \union AN \union {*} *)
Inductive MobType := Mob : (list Z * list Z) -> MobType.
(* A ::= amb[m] *)
Inductive AmbType := Amb : MobType -> AmbType.
Inductive Capability :=
| Path : Capability -> Capability -> Capability
| In : Z -> Capability
| Out : Z -> Capability
| Open : Z -> Capability
.
Inductive Process :=
| Composition : Process -> Process -> Process
| Restriction : nat -> AmbType -> Process
| Replication : Process -> Process
| Action : Capability -> Process -> Process
| Inactivity : Process
| Ambient : nat -> Process -> Process
.
Definition parents(m : MobType): list Z :=
match m with
| Mob (parents, _) => parents
end.
Definition childs(m : MobType): list Z :=
match m with
| Mob (_, childs) => childs
end.
Definition mob(a : AmbType): MobType :=
match a with
| Amb m => m
end.
Inductive 𝛤 :=
| Empty: 𝛤
| Cons: (Z * AmbType) -> 𝛤 -> 𝛤
.
Inductive ConcreteContexts :=
| Single : 𝛤 -> ConcreteContexts
| Multiple : 𝛤 -> ConcreteContexts -> ConcreteContexts
.
Fixpoint Inbool (a: Z) (l:list Z) : bool :=
match l with
| nil => false
| b :: m => if b =? a then true else Inbool a m
end.
Fixpoint ContextUpdate (𝛾: 𝛤) ( amb: (Z * AmbType)): 𝛤 :=
match 𝛾 with
| Empty => 𝛾
| Cons (m, (Amb M0)) 𝛾 =>
match amb with
| (n, (Amb N)) =>
let parentsM0 := parents M0 in
let parentsM1 := if Inbool m (childs N) then n :: parentsM0 else parentsM0 in
let childsM0 := childs M0 in
let childsM1 := if Inbool m (parents N) then n :: childsM0 else childsM0 in
Cons (m, Amb (Mob (parentsM1, childsM1))) (ContextUpdate 𝛾 amb)
end
end.
Fixpoint TypeCheckAmbient (𝛾: 𝛤 ) (Θ: 𝛤) (ambient: Z) (type: AmbType) : Prop :=
False
.
Fixpoint TypeCheckCapability (𝛾: 𝛤 ) (Θ: 𝛤) (capability: Capability) (type: CapType) : Prop :=
match capability with
| Path U V => TypeCheckCapability 𝛾 Θ U type /\ TypeCheckCapability 𝛾 Θ V type
| _ => False
end.