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

68 lines
1.5 KiB

(*
* Copyright (c) 2009-2013, Monoidics ltd.
* Copyright (c) 2013-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*)
(** The Smallfoot Intermediate Language: Constants *)
open! IStd
module F = Format
type t =
| Cint of IntLit.t (** integer constants *)
| Cfun of Typ.Procname.t (** function names *)
| Cstr of string (** string constants *)
| Cfloat of float (** float constants *)
| Cclass of Ident.name (** class constant *)
[@@deriving compare]
let equal = [%compare.equal: t]
let kind_equal c1 c2 =
let const_kind_number = function
| Cint _ ->
1
| Cfun _ ->
2
| Cstr _ ->
3
| Cfloat _ ->
4
| Cclass _ ->
5
in
Int.equal (const_kind_number c1) (const_kind_number c2)
let pp pe f = function
| Cint i ->
IntLit.pp f i
| Cfun fn -> (
match pe.Pp.kind with
| HTML ->
F.fprintf f "_fun_%s" (Escape.escape_xml (Typ.Procname.to_string fn))
| _ ->
F.fprintf f "_fun_%s" (Typ.Procname.to_string fn) )
| Cstr s ->
F.fprintf f "\"%s\"" (String.escaped s)
| Cfloat v ->
F.pp_print_float f v
| Cclass c ->
Ident.pp_name f c
let iszero_int_float = function Cint i -> IntLit.iszero i | Cfloat 0.0 -> true | _ -> false
let isone_int_float = function Cint i -> IntLit.isone i | Cfloat 1.0 -> true | _ -> false
let isminusone_int_float = function
| Cint i ->
IntLit.isminusone i
| Cfloat -1.0 ->
true
| _ ->
false