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