From 789020bc2f7fbc330e33818075a94381da04de4e Mon Sep 17 00:00:00 2001 From: kei <70096720+thelissimus@users.noreply.github.com> Date: Mon, 6 May 2024 11:35:02 +0500 Subject: [PATCH] chore: add `Union` and `SDiff` instances for `Std.RBSet` (#775) --- Std/Data/RBMap/Basic.lean | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Std/Data/RBMap/Basic.lean b/Std/Data/RBMap/Basic.lean index 4753a1446b..07a725e968 100644 --- a/Std/Data/RBMap/Basic.lean +++ b/Std/Data/RBMap/Basic.lean @@ -822,6 +822,8 @@ If equal keys exist in both, the key from `t₂` is preferred. def union (t₁ t₂ : RBSet α cmp) : RBSet α cmp := t₂.foldl .insert t₁ +instance : Union (RBSet α cmp) := ⟨RBSet.union⟩ + /-- `O(n₂ * log (n₁ + n₂))`. Merges the maps `t₁` and `t₂`. If equal keys exist in both, then use `mergeFn a₁ a₂` to produce the new merged value. @@ -857,6 +859,8 @@ def map (t : RBSet α cmpα) (f : α → β) : RBSet β cmpβ := -/ def sdiff (t₁ t₂ : RBSet α cmp) : RBSet α cmp := t₁.filter (!t₂.contains ·) +instance : SDiff (Std.RBSet α cmp) := ⟨RBSet.sdiff⟩ + end RBSet /- TODO(Leo): define dRBMap -/