2017-11-02 21:57:17 +04:00
|
|
|
(**************************************************************************)
|
|
|
|
(* *)
|
2018-02-06 00:17:03 +04:00
|
|
|
(* Copyright (c) 2014 - 2018. *)
|
2017-11-02 21:57:17 +04:00
|
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
|
|
(* *)
|
|
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
|
|
(* *)
|
|
|
|
(**************************************************************************)
|
|
|
|
|
2018-01-29 04:06:47 +04:00
|
|
|
open Proto_alpha
|
2017-11-27 09:13:12 +04:00
|
|
|
open Tezos_micheline
|
2017-11-02 21:57:17 +04:00
|
|
|
open Micheline
|
|
|
|
|
|
|
|
let print_expr ppf expr =
|
2017-10-18 15:46:16 +04:00
|
|
|
let print_annot ppf = function
|
|
|
|
| None -> ()
|
|
|
|
| Some annot -> Format.fprintf ppf " %s" annot in
|
2017-11-02 21:57:17 +04:00
|
|
|
let rec print_expr ppf = function
|
2018-03-28 22:42:10 +04:00
|
|
|
| Int (_, value) -> Format.fprintf ppf "%s" (Z.to_string value)
|
2017-11-02 21:57:17 +04:00
|
|
|
| String (_, value) -> Micheline_printer.print_string ppf value
|
2017-10-18 15:46:16 +04:00
|
|
|
| Seq (_, items, annot) ->
|
|
|
|
Format.fprintf ppf "(seq%a %a)"
|
|
|
|
print_annot annot
|
2017-11-02 21:57:17 +04:00
|
|
|
(Format.pp_print_list ~pp_sep:Format.pp_print_space print_expr)
|
|
|
|
items
|
2017-10-18 15:46:16 +04:00
|
|
|
| Prim (_, name, [], None) ->
|
2017-11-02 21:57:17 +04:00
|
|
|
Format.fprintf ppf "%s" name
|
2017-10-18 15:46:16 +04:00
|
|
|
| Prim (_, name, items, annot) ->
|
|
|
|
Format.fprintf ppf "(%s%a%s%a)"
|
|
|
|
name
|
|
|
|
print_annot annot
|
|
|
|
(if items = [] then "" else " ")
|
2017-11-02 21:57:17 +04:00
|
|
|
(Format.pp_print_list ~pp_sep:Format.pp_print_space print_expr) items in
|
|
|
|
let root = root (Michelson_v1_primitives.strings_of_prims expr) in
|
|
|
|
Format.fprintf ppf "@[<h>%a@]" print_expr root
|
|
|
|
|
|
|
|
open Micheline_parser
|
2018-02-05 17:58:19 +04:00
|
|
|
open Script_tc_errors
|
2017-11-02 21:57:17 +04:00
|
|
|
|
|
|
|
let print_type_map ppf (parsed, type_map) =
|
|
|
|
let rec print_expr_types ppf = function
|
|
|
|
| Seq (loc, [], _)
|
|
|
|
| Prim (loc, _, [], _)
|
|
|
|
| Int (loc, _)
|
|
|
|
| String (loc, _) ->
|
|
|
|
print_item ppf loc
|
|
|
|
| Seq (loc, items, _)
|
|
|
|
| Prim (loc, _, items, _) ->
|
|
|
|
print_item ppf loc ;
|
|
|
|
List.iter (print_expr_types ppf) items
|
|
|
|
and print_stack ppf items =
|
|
|
|
Format.fprintf ppf "(%a)"
|
|
|
|
(Format.pp_print_list ~pp_sep:Format.pp_print_space print_expr)
|
|
|
|
items
|
|
|
|
and print_item ppf loc = try
|
|
|
|
let { start = { point = s } ; stop = { point = e } }, locs =
|
|
|
|
List.assoc loc parsed.Michelson_v1_parser.expansion_table in
|
|
|
|
let locs = List.sort compare locs in
|
|
|
|
let (bef, aft) = List.assoc (List.hd locs) type_map in
|
|
|
|
Format.fprintf ppf "(@[<h>%d %d %a %a@])@,"
|
|
|
|
s e
|
|
|
|
print_stack bef
|
|
|
|
print_stack aft
|
|
|
|
with Not_found -> () in
|
|
|
|
Format.fprintf ppf "(@[<v 0>%a@])"
|
|
|
|
print_expr_types (root parsed.unexpanded)
|
|
|
|
|
|
|
|
let first_error_location errs =
|
|
|
|
let rec find = function
|
|
|
|
| [] -> 0
|
2018-02-21 23:58:53 +04:00
|
|
|
| (Inconsistent_type_annotations (loc, _, _)
|
|
|
|
| Unexpected_annotation loc
|
|
|
|
| Ill_formed_type (_, _, loc)
|
|
|
|
| Invalid_arity (loc, _, _, _)
|
|
|
|
| Invalid_namespace (loc, _, _, _)
|
|
|
|
| Invalid_primitive (loc, _, _)
|
|
|
|
| Invalid_kind (loc, _, _)
|
|
|
|
| Fail_not_in_tail_position loc
|
|
|
|
| Undefined_binop (loc, _, _, _)
|
|
|
|
| Undefined_unop (loc, _, _)
|
|
|
|
| Bad_return (loc, _, _)
|
|
|
|
| Bad_stack (loc, _, _, _)
|
|
|
|
| Unmatched_branches (loc, _, _)
|
|
|
|
| Invalid_constant (loc, _, _)
|
|
|
|
| Invalid_contract (loc, _)
|
|
|
|
| Comparable_type_expected (loc, _)
|
|
|
|
| Michelson_v1_primitives.Invalid_primitive_name (_, loc)) :: _ -> loc
|
2017-11-02 21:57:17 +04:00
|
|
|
| _ :: rest -> find rest in
|
|
|
|
find errs
|
|
|
|
|
|
|
|
let report_errors ppf (parsed, errs) =
|
2018-02-21 23:58:53 +04:00
|
|
|
let eco, out =
|
|
|
|
List.fold_left
|
|
|
|
(fun (eco, out) -> function
|
|
|
|
| Alpha_environment.Ecoproto_error err -> (err :: eco, out)
|
|
|
|
| err -> (eco, err :: out))
|
|
|
|
([], []) errs in
|
|
|
|
let eco, out = List.rev eco, List.rev out in
|
|
|
|
Format.fprintf ppf "(@[<v 0>%a@,%a@])"
|
|
|
|
(fun ppf errs ->
|
|
|
|
let find_location loc =
|
|
|
|
let oloc = List.assoc loc parsed.Michelson_v1_parser.unexpansion_table in
|
|
|
|
fst (List.assoc oloc parsed.expansion_table) in
|
|
|
|
match errs with
|
|
|
|
| top :: errs ->
|
|
|
|
let errs, loc =
|
|
|
|
List.map
|
|
|
|
(fun e -> Alpha_environment.Ecoproto_error e)
|
|
|
|
(top :: errs),
|
|
|
|
match top with
|
|
|
|
| Ill_typed_contract (expr, _)
|
|
|
|
| Ill_typed_data (_, expr, _) ->
|
|
|
|
if expr = parsed.expanded then
|
|
|
|
find_location
|
|
|
|
(first_error_location
|
|
|
|
(top :: errs))
|
|
|
|
else find_location 0
|
|
|
|
| Michelson_v1_primitives.Invalid_primitive_name (expr, loc) ->
|
|
|
|
if Micheline.strip_locations (Michelson_v1_macros.unexpand_rec (Micheline.root expr)) =
|
|
|
|
parsed.Michelson_v1_parser.unexpanded then
|
|
|
|
find_location loc
|
|
|
|
else
|
|
|
|
find_location 0
|
|
|
|
| _ -> find_location 0
|
|
|
|
in
|
|
|
|
let message =
|
|
|
|
Format.asprintf "%a"
|
|
|
|
(Michelson_v1_error_reporter.report_errors
|
|
|
|
~details:false ~show_source:false ~parsed)
|
|
|
|
errs in
|
|
|
|
let { start = { point = s } ; stop = { point = e } } = loc in
|
|
|
|
Format.fprintf ppf "(%d %d %S)" (s + 1) (e + 1) message
|
|
|
|
| [] -> ())
|
|
|
|
eco
|
2017-11-02 21:57:17 +04:00
|
|
|
(Format.pp_print_list
|
|
|
|
(fun ppf err ->
|
2017-11-04 03:16:05 +04:00
|
|
|
let find_location loc =
|
|
|
|
let oloc = List.assoc loc parsed.Michelson_v1_parser.unexpansion_table in
|
|
|
|
fst (List.assoc oloc parsed.expansion_table) in
|
2018-02-21 23:58:53 +04:00
|
|
|
let loc =
|
2017-11-02 21:57:17 +04:00
|
|
|
match err with
|
2017-11-04 03:16:05 +04:00
|
|
|
| Invalid_utf8_sequence (point, _)
|
|
|
|
| Unexpected_character (point, _)
|
|
|
|
| Undefined_escape_sequence (point, _)
|
2018-02-21 23:58:53 +04:00
|
|
|
| Missing_break_after_number point ->
|
|
|
|
{ start = point ; stop = point }
|
2017-11-04 03:16:05 +04:00
|
|
|
| Unterminated_string loc
|
|
|
|
| Unterminated_integer loc
|
|
|
|
| Unterminated_comment loc
|
|
|
|
| Unclosed { loc }
|
|
|
|
| Unexpected { loc }
|
2018-02-21 23:58:53 +04:00
|
|
|
| Extra { loc } -> loc
|
|
|
|
| Misaligned node -> location node
|
|
|
|
| _ -> find_location 0 in
|
2017-11-02 21:57:17 +04:00
|
|
|
let message =
|
|
|
|
Format.asprintf "%a"
|
|
|
|
(Michelson_v1_error_reporter.report_errors
|
2017-11-03 14:53:54 +04:00
|
|
|
~details:false ~show_source:false ~parsed)
|
2018-02-21 23:58:53 +04:00
|
|
|
[ err ] in
|
2017-11-04 03:16:05 +04:00
|
|
|
let { start = { point = s } ; stop = { point = e } } = loc in
|
2017-11-02 21:57:17 +04:00
|
|
|
Format.fprintf ppf "(%d %d %S)" (s + 1) (e + 1) message))
|
2018-02-21 23:58:53 +04:00
|
|
|
out
|