diff --git a/docs/conf.py b/docs/conf.py index 8979dcb80..08f1ea77b 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -70,7 +70,7 @@ language = None # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. # This patterns also effect to html_static_path and html_extra_path -exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'usage.rst'] +exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'doc_gen'] # The name of the Pygments (syntax highlighting) style to use. pygments_style = 'sphinx' diff --git a/docs/doc_gen/rpcs/rpc_doc.ml b/docs/doc_gen/rpcs/rpc_doc.ml index 0a7ffdabe..bf0e7da22 100644 --- a/docs/doc_gen/rpcs/rpc_doc.ml +++ b/docs/doc_gen/rpcs/rpc_doc.ml @@ -7,12 +7,6 @@ (* *) (**************************************************************************) -(* let example_args_completions = - * [ ("", [ ("head", 0.8) ; ("head~1", 0.1) ; ("genesis", 0.1) ]) ; - * ("", [ ("127.0.0.1:18731", 1.) ]) ; - * ("", [ ]); - * ] *) - (* Utility functions *) exception Unsupported_construct @@ -146,43 +140,42 @@ let make_descr = function let repr_of_service path RPC_description.{ description ; error ; meth ; input ; output ; _ } : service_repr= - (* TODO? : check that json schema are not empty *) - (* let escape_html_string str = * let open Stringext in - * let str = replace_all str "<" "<" in - * replace_all str ">" ">" + * let str = replace_all str ~pattern:"<" ~with_:"<" in + * replace_all str ~pattern:">" ~with_:">" * in * * let example = begin - * match input with - * | None -> None - * | Some input when input = Json_schema.any -> None - * | Some input -> begin - * let json = random_fill_in ~show_optionals:true input in - * (\* curl -X METH -H "Content-type: application/json" http://
: -d '' *\) + * try + * match input with + * | None -> None + * | Some input -> begin + * let path = List.map escape_html_string path |> String.concat "/" in + * Printf.eprintf "%s\n%!" path; + * let json = random_fill_in ~show_optionals:true input in + * let tezos_client_cmd_example = + * Format.sprintf "tezos-client rpc call /%s with '%s'" + * path + * (Data_encoding.Json.to_string ~minify:true json) + * in + * let curl_cmd_example = + * Format.sprintf "curl -X %s -H \"Content-type: application/json\" http://%s/%s -d '%s'" + * (RPC_service.string_of_meth meth) + * "127.0.0.1:18731" + * path + * (Data_encoding.Json.to_string ~minify:true json) + * in + * let open Format in + * Some ( + * List.fold_left (fun acc s -> + * (Format.sprintf "
%s
" s) :: acc) + * [] [ curl_cmd_example ; tezos_client_cmd_example ] + * |> String.concat "or" + * ) * - * let tezos_client_cmd_example = - * Format.asprintf "tezos-client rpc call /%s with '%s'" - * (String.concat "/" path |> escape_html_string) - * (Data_encoding.Json.to_string ~minify:true json) - * in - * let curl_cmd_example = - * Format.asprintf "curl -X %s -H \"Content-type: application/json\" http://<address>:<port>/%s -d '%s'" - * (RPC_service.string_of_meth meth) - * (String.concat "/" path |> escape_html_string) - * (Data_encoding.Json.to_string ~minify:true json) - * in - * let open Format in - * - * Some ( - * List.fold_left (fun acc s -> - * (Format.sprintf "
%s
" s) :: acc) - * [] [tezos_client_cmd_example ; curl_cmd_example] - * |> List.rev |> String.concat "or" - * ) - * - * end + * end + * with | Unsupported_construct -> None * end in *) { path ; meth ; @@ -232,15 +225,16 @@ let pp_print_collected_args ppf () = (function | { name ; descr=Some d } -> fprintf ppf "@[**<%s>** : @[%s@]@]@ @ " name d; - | { name=_ ; _ } -> () (* Should we print it anyway ? *) + | { descr=None ; _ } -> assert false ) (List.rev !collected_args); fprintf ppf "@]" let make_tree cctxt path = - (* TODO : discuss about automatic example generation *) let collect arg = - if not (arg.RPC_arg.descr <> None && List.mem arg !collected_args) then + if not (arg.RPC_arg.descr = None || + (List.exists (fun { Resto.Arg.name } -> name = arg.name) + !collected_args)) then collected_args := arg :: !collected_args in let open RPC_description in @@ -593,18 +587,16 @@ let run ?(rpc_port=18731) () = (* Page title *) fprintf ppf "%a" pp_print_rst_h1 "Tezos RPCs"; (* include/copy usage.rst from input *) - let rec loop () = - let s = read_line () in - fprintf ppf "%s@\n" s; - loop () - in begin try loop () with End_of_file -> () end + Lwt_io.(read stdin) >>= fun s -> + fprintf ppf "%s@\n" s; + Lwt.return () in (make_tree cctxt [] >>= function | Ok service_tree -> (* Print header!! *) fprintf ppf "@\n"; - print_header (); + print_header () >>= fun () -> fprintf ppf "@\n"; (* Shell RPCs tree *) @@ -623,7 +615,6 @@ let run ?(rpc_port=18731) () = begin make_tree cctxt path_proto_alpha >>= function | Ok service_tree -> - (* TODO : replace head by ? *) (* Proto alpha RPCs tree *) fprintf ppf "%a@." (pp_print_rst_hierarchy ~title:"Protocol Alpha RPCs - Index") service_tree; fprintf ppf "%a" pp_print_rst_h2 "Protocol Alpha RPCs - Full description"; @@ -637,7 +628,6 @@ let run ?(rpc_port=18731) () = end; Lwt.return 0 - (* TODO : add dynamic parameter description *) | Error _ -> Format.fprintf err_ppf "[RPC Doc Generation] Proto alpha : Couldn't reach node\n"; diff --git a/src/lib_error_monad/error_monad.ml b/src/lib_error_monad/error_monad.ml index 83343e203..c3bd0998d 100644 --- a/src/lib_error_monad/error_monad.ml +++ b/src/lib_error_monad/error_monad.ml @@ -538,52 +538,6 @@ module Make(Prefix : sig val id : string end) = struct (Format.pp_print_list pp) (List.rev errors) - (** Catch all error when 'serializing' an error. *) - type error += Unclassified of string - - let () = - let id = "" in - let category = `Temporary in - let to_error msg = Unclassified msg in - let from_error = function - | Unclassified msg -> Some msg - | error -> - let msg = Obj.(extension_name @@ extension_constructor error) in - Some ("Unclassified error: " ^ msg ^ ". Was the error registered?") in - let title = "Generic error" in - let description = "An unclassified error" in - let encoding_case = - let open Data_encoding in - case Json_only - (describe ~title ~description @@ - conv (fun x -> ((), x)) (fun ((), x) -> x) @@ - (obj2 - (req "kind" (constant "generic")) - (req "error" string))) - from_error to_error in - let pp = Format.pp_print_string in - error_kinds := - Error_kind { id ; from_error ; category ; encoding_case ; pp } :: !error_kinds - - (** Catch all error when 'deserializing' an error. *) - type error += Unregistered_error of Data_encoding.json - - let () = - let id = "" in - let category = `Temporary in - let to_error msg = Unregistered_error msg in - let from_error = function - | Unregistered_error json -> Some json - | _ -> None in - let encoding_case = - let open Data_encoding in - case Json_only json from_error to_error in - let pp ppf json = - Format.fprintf ppf "@[Unregistered error:@ %a@]" - Data_encoding.Json.pp json in - error_kinds := - Error_kind { id ; from_error ; category ; encoding_case ; pp } :: !error_kinds - type error += Assert_error of string * string let () =