You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

99 lines
4.1 KiB
OCaml

(***********************************************************************)
(* *)
(* Heptagon *)
(* *)
(* Gwenael Delaval, LIG/INRIA, UJF *)
(* Leonard Gerard, Parkas, ENS *)
(* Adrien Guatto, Parkas, ENS *)
(* Cedric Pasteur, Parkas, ENS *)
(* *)
(* Copyright 2012 ENS, INRIA, UJF *)
(* *)
(* This file is part of the Heptagon compiler. *)
(* *)
(* Heptagon is free software: you can redistribute it and/or modify it *)
(* under the terms of the GNU General Public License as published by *)
(* the Free Software Foundation, either version 3 of the License, or *)
(* (at your option) any later version. *)
(* *)
(* Heptagon is distributed in the hope that it will be useful, *)
(* but WITHOUT ANY WARRANTY; without even the implied warranty of *)
(* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *)
(* GNU General Public License for more details. *)
(* *)
(* You should have received a copy of the GNU General Public License *)
(* along with Heptagon. If not, see <http://www.gnu.org/licenses/> *)
(* *)
(***********************************************************************)
open Obc
open Idents
open Global_compare
open Misc
let rec extvalue_compare w1 w2 =
let cr = type_compare w1.w_ty w2.w_ty in
if cr <> 0 then cr
else
match w1.w_desc, w2.w_desc with
| Wvar x1, Wvar x2 -> ident_compare x1 x2
| Wmem x1, Wmem x2 -> ident_compare x1 x2
| Wfield(r1, f1), Wfield(r2, f2) ->
let cr = compare f1 f2 in
if cr <> 0 then cr else extvalue_compare r1 r2
| Warray(l1, e1), Warray(l2, e2) ->
let cr = extvalue_compare l1 l2 in
if cr <> 0 then cr else exp_compare e1 e2
| Wvar _, _ -> 1
| Wmem _, Wvar _ -> -1
| Wmem _, _ -> 1
| Wfield _, (Wvar _ | Wmem _) -> -1
| Wfield _, _ -> 1
| Wconst _, (Wvar _ | Wmem _ | Wfield _) -> -1
| Wconst _, _ -> 1
| Warray _, _ -> -1
and exp_compare e1 e2 =
let cr = type_compare e1.e_ty e2.e_ty in
if cr <> 0 then cr
else
match e1.e_desc, e2.e_desc with
| Eextvalue w1, Eextvalue w2 -> extvalue_compare w1 w2
| Eop(op1, el1), Eop(op2, el2) ->
let cr = compare op1 op2 in
if cr <> 0 then cr else list_compare exp_compare el1 el2
| Estruct(_, fnel1), Estruct (_, fnel2) ->
let compare_fne (fn1, e1) (fn2, e2) =
let cr = compare fn1 fn2 in
if cr <> 0 then cr else exp_compare e1 e2
in
list_compare compare_fne fnel1 fnel2
| Earray el1, Earray el2 ->
list_compare exp_compare el1 el2
| Eextvalue _, _ -> 1
| Eop _, (Eextvalue _) -> -1
| Eop _, _ -> 1
| Estruct _, (Eextvalue _ | Eop _) -> -1
| Estruct _, _ -> 1
| Earray _, _ -> -1
let rec compare_lhs_extvalue l w = match l.pat_desc, w.w_desc with
| Lvar x1, Wvar x2 -> ident_compare x1 x2
| Lmem x1, Wmem x2 -> ident_compare x1 x2
| Lfield (l1, f1), Wfield (w2, f2) ->
let cr = compare f1 f2 in
if cr <> 0 then cr else compare_lhs_extvalue l1 w2
| Larray (l1, e1), Warray (w2, e2) ->
let cr = compare_lhs_extvalue l1 w2 in
if cr <> 0 then cr else exp_compare e1 e2
| _, _ -> 1 (* always return 1 as we only use it for comparison *)