(* * Copyright (c) 2016-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. *) open! IStd type mode = On | Off type issue_desc = { id: string ; (* issue id *) description: string ; (* Description in the error message *) doc_url: string option ; mode: mode ; name: string option ; (* issue name, if no name is given name will be a readable version of id, by removing underscores and capitalizing first letters of words *) loc: Location.t ; (* location in the code *) severity: Exceptions.err_kind ; suggestion: string option (* an optional suggestion or correction *) } let string_of_mode m = match m with On -> "On" | Off -> "Off" let pp_issue fmt issue = Format.fprintf fmt "{@\n Id = %s@\n" issue.id ; Format.fprintf fmt "{ Name = %s@\n" (Option.value ~default:"" issue.name) ; Format.fprintf fmt " Severity = %s@\n" (Exceptions.err_kind_string issue.severity) ; Format.fprintf fmt " Mode = %s@\n" (string_of_mode issue.mode) ; Format.fprintf fmt " Description = %s@\n" issue.description ; Format.fprintf fmt " Suggestion = %s@\n" (Option.value ~default:"" issue.suggestion) ; Format.fprintf fmt " Docs URL = %s@\n" (Option.value ~default:"" issue.doc_url) ; Format.fprintf fmt " Loc = %s@\n" (Location.to_string issue.loc) ; Format.fprintf fmt "}@\n" let should_run_check mode = match mode with | On -> true | Off -> Config.debug_mode || Config.debug_exceptions || not Config.filtering