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.

34 lines
913 B

(*
* Copyright (c) 2017 - present Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*)
open! IStd
module F = Format
module L = Logging
(* Extremely simple abstraction of resources: count the number of acquired resources. If there's
not a corresponding number of releases, there may be a leak. *)
type astate = int
(* 2(a) *)
(* For now, type of abstract state and summary are the same *)
type summary = astate
(* 4(a) *)
let ( <= ) ~lhs ~rhs = lhs <= rhs
let join = Pervasives.max
let widen ~prev ~next ~num_iters:_ = join prev next
let pp fmt astate = F.fprintf fmt "Resource count: %d" astate
(* At the beginning of a procedure, assume no resources are held *)
let initial = 0