Reviewed By: ngorogiannis Differential Revision: D24306099 fbshipit-source-id: 673179d90master
parent
b6a77f6567
commit
08da86ae62
@ -0,0 +1,29 @@
|
||||
(*
|
||||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||
*
|
||||
* This source code is licensed under the MIT license found in the
|
||||
* LICENSE file in the root directory of this source tree.
|
||||
*)
|
||||
|
||||
include CCHashSet
|
||||
|
||||
module Make (E : ELEMENT) = struct
|
||||
include CCHashSet.Make (E)
|
||||
|
||||
let update s e ~f =
|
||||
let eo = find s e in
|
||||
match (eo, f eo) with
|
||||
| None, None -> ()
|
||||
| Some e, Some e' when e == e' -> ()
|
||||
| Some _, None -> remove s e
|
||||
| _, Some e' -> insert s e'
|
||||
|
||||
let add s e =
|
||||
let change = ref false in
|
||||
update s e ~f:(function
|
||||
| None ->
|
||||
change := true ;
|
||||
Some e
|
||||
| Some e -> Some e ) ;
|
||||
!change
|
||||
end
|
@ -0,0 +1,18 @@
|
||||
(*
|
||||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||
*
|
||||
* This source code is licensed under the MIT license found in the
|
||||
* LICENSE file in the root directory of this source tree.
|
||||
*)
|
||||
|
||||
include module type of CCHashSet with module Make := CCHashSet.Make
|
||||
|
||||
module Make (E : ELEMENT) : sig
|
||||
include module type of CCHashSet.Make (E)
|
||||
|
||||
val add : t -> elt -> bool
|
||||
(** [add s x] adds [x] into [s] and returns whether [s] was changed, that
|
||||
is, [add s x = not (mem s x)] *)
|
||||
|
||||
val update : t -> elt -> f:(elt option -> elt option) -> unit
|
||||
end
|
Loading…
Reference in new issue