non associative with precedence 90
for @{ 'Star $k }.
-notation "hvbox( ♭ (term 90 I) break T1 . break T )"
+notation "hvbox( 𝕚 { I } break (term 90 T1) . break (term 90 T) )"
non associative with precedence 90
- for @{ 'SCon $I $T1 $T }.
+ for @{ 'SItem $I $T1 $T }.
-notation "hvbox( T . break ♭ (term 90 I) break T1 )"
+notation "hvbox( 𝕓 { I } break (term 90 T1) . break (term 90 T) )"
non associative with precedence 90
- for @{ 'DCon $T $I $T1 }.
+ for @{ 'SBind $I $T1 $T }.
+
+notation "hvbox( 𝕗 { I } break (term 90 T1) . break (term 90 T) )"
+ non associative with precedence 90
+ for @{ 'SFlat $I $T1 $T }.
+
+notation "hvbox( T . break 𝕓 { I } break (term 90 T1) )"
+ non associative with precedence 89
+ for @{ 'DBind $T $I $T1 }.
notation "hvbox( # term 90 x )"
non associative with precedence 90
(* substitution *************************************************************)
-notation "hvbox( [ d , break e ] ↑ break T1 ≡ break T2 )"
+notation "hvbox( ↑ [ d , break e ] break T1 ≡ break T2 )"
non associative with precedence 45
for @{ 'RLift $T1 $d $e $T2 }.
-notation "hvbox( [ d , break e ] ← break (term 90 L) / break T1 ≡ break T2 )"
+notation "hvbox( ↓ [ d , break e ] break L1 ≡ break L2 )"
+ non associative with precedence 45
+ for @{ 'RSubst $L1 $d $e $L2 }.
+
+notation "hvbox( L ⊢ break ↓ [ d , break e ] break T1 ≡ break T2 )"
non associative with precedence 45
for @{ 'RSubst $L $T1 $d $e $T2 }.
+
+(* reduction ****************************************************************)
+
+notation "hvbox( L ⊢ break T1 ⇒ break T2 )"
+ non associative with precedence 45
+ for @{ 'PR $L $T1 $T2 }.