diff options
Diffstat (limited to 'lib/expression')
| -rwxr-xr-x | lib/expression/dune | 6 | ||||
| -rw-r--r-- | lib/expression/sym.ml | 4 | ||||
| -rw-r--r-- | lib/expression/t.ml | 9 | ||||
| -rw-r--r-- | lib/expression/t.mli | 2 | ||||
| -rw-r--r-- | lib/expression/type_of.mli | 6 | 
5 files changed, 14 insertions, 13 deletions
| diff --git a/lib/expression/dune b/lib/expression/dune index d141b7b..8bf6e62 100755 --- a/lib/expression/dune +++ b/lib/expression/dune @@ -7,6 +7,8 @@     importErrors
   )
   (preprocess (pps 
 -    ppx_deriving.show 
 -    ppx_deriving.eq ))
 +   ppx_deriving.ord
 +   ppx_deriving.show 
 +   ppx_deriving.eq 
 +   ))
  )
 diff --git a/lib/expression/sym.ml b/lib/expression/sym.ml index 0360e8e..49e923d 100644 --- a/lib/expression/sym.ml +++ b/lib/expression/sym.ml @@ -1,8 +1,6 @@  (** The signature for an expression analyzer. -    Every element is mapped to a function, using the tagless final pattern. - - *) +    Every element is mapped to a function, using the tagless final pattern. *)  module type SYM_EXPR = sig    type 'a repr    type 'a obs diff --git a/lib/expression/t.ml b/lib/expression/t.ml index fec8fd7..324d515 100644 --- a/lib/expression/t.ml +++ b/lib/expression/t.ml @@ -6,7 +6,7 @@ type 'a window =    | Counter    | Previous of 'a    | Sum of 'a -[@@deriving show, eq] +[@@deriving show, eq, ord]  type 'a t =    | Empty @@ -22,7 +22,7 @@ type 'a t =    | BOperator of binary_operator * 'a t * 'a t    | GEquality of binary_operator * 'a t * 'a t list    | Function' of funct * 'a t list -[@@deriving show, eq] +[@@deriving show, eq, ord]  and binary_operator =    | Equal @@ -34,6 +34,7 @@ and binary_operator =    | GT    | And    | Or +[@@deriving ord]  and funct =    | Cmp @@ -119,13 +120,13 @@ let rec cmp : ('a -> 'a -> int) -> 'a t -> 'a t -> int =        let name_cmp = String.compare n1 n2 in        if name_cmp = 0 then List.compare ~cmp:(cmp f) elems1 elems2 else name_cmp    | Window (s1, l11, l12), Window (s2, l21, l22) -> ( -      match compare s1 s2 with +      match compare_window (cmp f) s1 s2 with        | 0 ->            let l1_cmp = List.compare ~cmp:(cmp f) l11 l21 in            if l1_cmp = 0 then List.compare ~cmp:(cmp f) l12 l22 else l1_cmp        | other -> other)    | BOperator (n1, arg11, arg12), BOperator (n2, arg21, arg22) -> begin -      match compare n1 n2 with +      match compare_binary_operator n1 n2 with        | 0 -> begin            match cmp f arg11 arg21 with            | 0 -> cmp f arg12 arg22 diff --git a/lib/expression/t.mli b/lib/expression/t.mli index 4e1af55..4c9e0a7 100644 --- a/lib/expression/t.mli +++ b/lib/expression/t.mli @@ -19,7 +19,7 @@ type 'a t =    | BOperator of binary_operator * 'a t * 'a t    | GEquality of binary_operator * 'a t * 'a t list    | Function' of funct * 'a t list -[@@deriving show, eq] +[@@deriving show, eq, ord]  and binary_operator =    | Equal diff --git a/lib/expression/type_of.mli b/lib/expression/type_of.mli index 7a11582..a839c09 100644 --- a/lib/expression/type_of.mli +++ b/lib/expression/type_of.mli @@ -1,7 +1,7 @@ -(** This module tries to identify the type of an expression.  +(** This module tries to identify the type of an expression. -The references to data comming from the spreaedsheet cannot be evaluated and -marked as [Extern]. *) +    The references to data comming from the spreaedsheet cannot be evaluated and +    marked as [Extern]. *)  type t = ImportDataTypes.Types.t | 
