|
|
@ -14,38 +14,32 @@ module F = Format
|
|
|
|
(** utilities for importing JSON specifications of sources/sinks into Quandary *)
|
|
|
|
(** utilities for importing JSON specifications of sources/sinks into Quandary *)
|
|
|
|
|
|
|
|
|
|
|
|
module Source = struct
|
|
|
|
module Source = struct
|
|
|
|
type t = { procedure : string; kind : string; }
|
|
|
|
type t = { procedure : Str.regexp; kind : string; }
|
|
|
|
|
|
|
|
|
|
|
|
let of_json = function
|
|
|
|
let of_json = function
|
|
|
|
| `List sources ->
|
|
|
|
| `List sources ->
|
|
|
|
let parse_source json =
|
|
|
|
let parse_source json =
|
|
|
|
let open Yojson.Basic.Util in
|
|
|
|
let open Yojson.Basic.Util in
|
|
|
|
let procedure = json |> member "procedure" |> to_string in
|
|
|
|
let procedure = json |> member "procedure" |> to_string |> Str.regexp in
|
|
|
|
let kind = json |> member "kind" |> to_string in
|
|
|
|
let kind = json |> member "kind" |> to_string in
|
|
|
|
{ procedure; kind; } in
|
|
|
|
{ procedure; kind; } in
|
|
|
|
IList.map parse_source sources
|
|
|
|
IList.map parse_source sources
|
|
|
|
| _ ->
|
|
|
|
| _ ->
|
|
|
|
[]
|
|
|
|
[]
|
|
|
|
|
|
|
|
|
|
|
|
let pp fmt { procedure; kind; } =
|
|
|
|
|
|
|
|
F.fprintf fmt "Procedure: %s Kind: %s" procedure kind
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
module Sink = struct
|
|
|
|
module Sink = struct
|
|
|
|
type t = { procedure : string; kind : string; index : string}
|
|
|
|
type t = { procedure : Str.regexp; kind : string; index : string}
|
|
|
|
|
|
|
|
|
|
|
|
let of_json = function
|
|
|
|
let of_json = function
|
|
|
|
| `List sinks ->
|
|
|
|
| `List sinks ->
|
|
|
|
let parse_sink json =
|
|
|
|
let parse_sink json =
|
|
|
|
let open Yojson.Basic.Util in
|
|
|
|
let open Yojson.Basic.Util in
|
|
|
|
let procedure = json |> member "procedure" |> to_string in
|
|
|
|
let procedure = json |> member "procedure" |> to_string |> Str.regexp in
|
|
|
|
let kind = json |> member "kind" |> to_string in
|
|
|
|
let kind = json |> member "kind" |> to_string in
|
|
|
|
let index = json |> member "index" |> to_string in
|
|
|
|
let index = json |> member "index" |> to_string in
|
|
|
|
{ procedure; kind; index; } in
|
|
|
|
{ procedure; kind; index; } in
|
|
|
|
IList.map parse_sink sinks
|
|
|
|
IList.map parse_sink sinks
|
|
|
|
| _ ->
|
|
|
|
| _ ->
|
|
|
|
[]
|
|
|
|
[]
|
|
|
|
|
|
|
|
|
|
|
|
let pp fmt { procedure; kind; index; } =
|
|
|
|
|
|
|
|
F.fprintf fmt "Procedure: %s Kind: %s Index %s" procedure kind index
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|