[inferbo] silence firing assert

Summary: Not sure how that happens but it does. Instead of crashing, log the error and continue.

Reviewed By: martintrojer

Differential Revision: D15660008

fbshipit-source-id: c87e724d4
master
Jules Villard 6 years ago committed by Facebook Github Bot
parent a3d8b9c4a4
commit 33ae8bae02

@ -6,6 +6,7 @@
*) *)
open! IStd open! IStd
module F = Format module F = Format
module L = Logging
module BoundEnd = struct module BoundEnd = struct
type t = LowerBound | UpperBound [@@deriving compare] type t = LowerBound | UpperBound [@@deriving compare]
@ -230,6 +231,20 @@ module Symbol = struct
| BoundEnd of {unsigned: extra_bool; path: SymbolPath.t; bound_end: BoundEnd.t} | BoundEnd of {unsigned: extra_bool; path: SymbolPath.t; bound_end: BoundEnd.t}
[@@deriving compare] [@@deriving compare]
let pp : F.formatter -> t -> unit =
fun fmt s ->
match s with
| OneValue {unsigned; path} | BoundEnd {unsigned; path} ->
SymbolPath.pp fmt path ;
( if Config.developer_mode then
match s with
| BoundEnd {bound_end} ->
Format.fprintf fmt ".%s" (BoundEnd.to_string bound_end)
| OneValue _ ->
() ) ;
if Config.bo_debug > 1 then F.fprintf fmt "(%c)" (if unsigned then 'u' else 's')
let compare s1 s2 = let compare s1 s2 =
match (s1, s2) with match (s1, s2) with
| OneValue _, BoundEnd _ -> | OneValue _, BoundEnd _ ->
@ -239,8 +254,10 @@ module Symbol = struct
| OneValue {unsigned= unsigned1}, OneValue {unsigned= unsigned2} | OneValue {unsigned= unsigned1}, OneValue {unsigned= unsigned2}
| BoundEnd {unsigned= unsigned1}, BoundEnd {unsigned= unsigned2} -> | BoundEnd {unsigned= unsigned1}, BoundEnd {unsigned= unsigned2} ->
let r = compare s1 s2 in let r = compare s1 s2 in
if Int.equal r 0 then assert (Bool.equal unsigned1 unsigned2) ; if Int.equal r 0 && not (Bool.equal unsigned1 unsigned2) then (
r L.internal_error "values are equal but their signs are different: %a <> %a" pp s1 pp s2 ;
Bool.compare unsigned1 unsigned2 )
else r
type 'res eval = t -> BoundEnd.t -> 'res AbstractDomain.Types.bottom_lifted type 'res eval = t -> BoundEnd.t -> 'res AbstractDomain.Types.bottom_lifted
@ -264,20 +281,6 @@ module Symbol = struct
fun bound_end ~unsigned path -> BoundEnd {unsigned; path; bound_end} fun bound_end ~unsigned path -> BoundEnd {unsigned; path; bound_end}
let pp : F.formatter -> t -> unit =
fun fmt s ->
match s with
| OneValue {unsigned; path} | BoundEnd {unsigned; path} ->
SymbolPath.pp fmt path ;
( if Config.developer_mode then
match s with
| BoundEnd {bound_end} ->
Format.fprintf fmt ".%s" (BoundEnd.to_string bound_end)
| OneValue _ ->
() ) ;
if Config.bo_debug > 1 then F.fprintf fmt "(%c)" (if unsigned then 'u' else 's')
let pp_mark ~markup = if markup then MarkupFormatter.wrap_monospaced pp else pp let pp_mark ~markup = if markup then MarkupFormatter.wrap_monospaced pp else pp
let is_unsigned : t -> bool = function OneValue {unsigned} | BoundEnd {unsigned} -> unsigned let is_unsigned : t -> bool = function OneValue {unsigned} | BoundEnd {unsigned} -> unsigned

Loading…
Cancel
Save