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.

82 lines
2.1 KiB

(*
* 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
(** utilities for importing JSON specifications of sources/sinks into Quandary *)
module Source = struct
type t = {procedure: string; kind: string; index: string}
let of_json = function
| `List sources ->
let parse_source json =
let open Yojson.Basic in
let procedure = Util.member "procedure" json |> Util.to_string in
let kind = Util.member "kind" json |> Util.to_string in
let index =
Util.member "index" json |> Util.to_string_option |> Option.value ~default:"return"
in
{procedure; kind; index}
in
List.map ~f:parse_source sources
| _ ->
[]
end
module Sink = struct
type t = {procedure: string; kind: string; index: string}
let of_json = function
| `List sinks ->
let parse_sink json =
let open Yojson.Basic in
let procedure = Util.member "procedure" json |> Util.to_string in
let kind = Util.member "kind" json |> Util.to_string in
let index =
Util.member "index" json |> Util.to_string_option |> Option.value ~default:"all"
in
{procedure; kind; index}
in
List.map ~f:parse_sink sinks
| _ ->
[]
end
module Sanitizer = struct
type t = {procedure: string}
let of_json = function
| `List sinks ->
let parse_sanitizer json =
let open Yojson.Basic in
let procedure = Util.member "procedure" json |> Util.to_string in
{procedure}
in
List.map ~f:parse_sanitizer sinks
| _ ->
[]
end
module Endpoint = struct
type t = string
let of_json = function
| `List endpoints ->
let parse_endpoint = Yojson.Basic.Util.to_string in
List.map ~f:parse_endpoint endpoints
| _ ->
[]
end