diff options
author | 2015-10-29 20:52:32 +0100 | |
---|---|---|
committer | 2015-10-29 20:52:32 +0100 | |
commit | 48ffb1173702f86fa6cb6392f7876d7da5e5d6b6 (patch) | |
tree | 8284dc3eda6ddb7db3e3bd6a5e262d1bb2934868 /printing/printer.ml | |
parent | 4444f04cfdbe449d184ac1ce0a56eb484805364d (diff) |
Make the code of compare functions linear in the number of constructors.
This scheme has been advised by @gashe on #79.
Interestingly there are several comparison functions in Coq which were already implemented with this scheme.
Diffstat (limited to 'printing/printer.ml')
-rw-r--r-- | printing/printer.ml | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/printing/printer.ml b/printing/printer.ml index 18e490225..12782a428 100644 --- a/printing/printer.ml +++ b/printing/printer.ml @@ -724,18 +724,17 @@ module OrderedContextObject = struct type t = context_object let compare x y = - match x , y with - | Variable i1 , Variable i2 -> Id.compare i1 i2 - | Axiom (k1,_) , Axiom (k2, _) -> con_ord k1 k2 - | Opaque k1 , Opaque k2 -> con_ord k1 k2 - | Transparent k1 , Transparent k2 -> con_ord k1 k2 - | Axiom _ , Variable _ -> 1 - | Opaque _ , Variable _ - | Opaque _ , Axiom _ -> 1 - | Transparent _ , Variable _ - | Transparent _ , Axiom _ - | Transparent _ , Opaque _ -> 1 - | _ , _ -> -1 + match x , y with + | Variable i1 , Variable i2 -> Id.compare i1 i2 + | Variable _ , _ -> -1 + | _ , Variable _ -> 1 + | Axiom (k1,_) , Axiom (k2, _) -> con_ord k1 k2 + | Axiom _ , _ -> -1 + | _ , Axiom _ -> 1 + | Opaque k1 , Opaque k2 -> con_ord k1 k2 + | Opaque _ , _ -> -1 + | _ , Opaque _ -> 1 + | Transparent k1 , Transparent k2 -> con_ord k1 k2 end module ContextObjectSet = Set.Make (OrderedContextObject) |