summaryrefslogtreecommitdiff
path: root/testsuite/tests/formatting/errors_batch.ml
blob: 6d5bf4611c15b7f19686a63f30ef4542d5e84cdd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
(* TEST
 include ocamlcommon;
*)

let () =
  let open Location in
  (* Some dummy locations for demo purposes *)
  let pos = Lexing.{
    pos_fname = "hello.ml";
    pos_lnum = 18;
    pos_bol = 15;
    pos_cnum = 35;
  } in
  let loc1 = {
    loc_start = pos; loc_end = { pos with pos_cnum = 42 };
    loc_ghost = false
  } in
  let loc2 = {
    loc_start = { pos with pos_lnum = 20; pos_bol = 0; pos_cnum = 4 };
    loc_end = { pos with pos_lnum = 20; pos_bol = 0; pos_cnum = 8 };
    loc_ghost = false
  } in
  let loc3 = {
    loc_start = { pos with pos_lnum = 20; pos_bol = 0; pos_cnum = 6 };
    loc_end = { pos with pos_lnum = 20; pos_bol = 0; pos_cnum = 8 };
    loc_ghost = false
  } in
  let report = {
    kind = Report_error;
    main = msg ~loc:loc1 "%a" Format.pp_print_text
        "These are the contents of the main error message. \
         It is very long and should wrap across several lines.";
    sub = [
      msg ~loc:loc2 "A located first sub-message.";
      msg ~loc:loc3 "%a" Format.pp_print_text
        "Longer sub-messages that do not fit on the \
         same line as the location get indented.";
      msg "@[<v>This second sub-message does not have \
           a location;@,ghost locations of submessages are \
           not printed.@]";
    ]
  } in
  print_report Format.std_formatter report