package odoc

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file parse_error.ml

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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
module Location = Odoc_model.Location_
module Error = Odoc_model.Error

open Odoc_compat



let bad_markup : ?suggestion:string -> string -> Location.span -> Error.t =
    fun ?suggestion ->
  Error.make ?suggestion "'%s': bad markup."

let bad_heading_level : int -> Location.span -> Error.t =
  Error.make "'%d': bad heading level (0-5 allowed)."

let leading_zero_in_heading_level : string -> Location.span -> Error.t =
  Error.make "'%s': leading zero in heading level."

let should_not_be_empty : what:string -> Location.span -> Error.t = fun ~what ->
  Error.make "%s should not be empty." (String.capitalize_ascii what)

let should_begin_on_its_own_line : what:string -> Location.span -> Error.t =
    fun ~what ->
  Error.make "%s should begin on its own line." (String.capitalize_ascii what)

let should_be_followed_by_whitespace : what:string -> Location.span -> Error.t =
    fun ~what ->
  Error.make
    "%s should be followed by space, a tab, or a new line."
    (String.capitalize_ascii what)

let not_allowed
    : ?suggestion:string -> what:string -> in_what:string -> Location.span ->
        Error.t =
    fun ?suggestion ~what ~in_what ->
  Error.make
    ?suggestion "%s is not allowed in %s."
    (String.capitalize_ascii what) in_what

let no_leading_whitespace_in_verbatim : Location.span -> Error.t =
  Error.make "'{v' should be followed by whitespace."

let no_trailing_whitespace_in_verbatim : Location.span -> Error.t =
  Error.make "'v}' should be preceded by whitespace."

let page_heading_required : string -> Error.t =
  Error.filename_only "Pages (.mld files) should start with a heading."

let heading_level_should_be_lower_than_top_level
    : int -> int -> Location.span -> Error.t =
    fun this_heading_level top_heading_level ->
  Error.make
    "%s: heading level should be lower than top heading level '%d'."
    (String.capitalize_ascii
      (Token.print (`Begin_section_heading (this_heading_level, None))))
    top_heading_level

let headings_not_allowed : Location.span -> Error.t =
  Error.make "Headings not allowed in this comment."

let titles_not_allowed : Location.span -> Error.t =
  Error.make "Title-level headings {0 ...} are only allowed in pages."

let stray_at : Location.span -> Error.t =
  Error.make "Stray '@'."

let stray_cr : Location.span -> Error.t =
  Error.make "Stray '\\r' (carriage return character)."

let truncated_before : Location.span -> Error.t =
  Error.make "'@before' expects version number on the same line."

let truncated_param : Location.span -> Error.t =
  Error.make "'@param' expects parameter name on the same line."

let truncated_raise : Location.span -> Error.t =
  Error.make "'@raise' expects exception constructor on the same line."

let truncated_see : Location.span -> Error.t =
  Error.make
    "'@see' should be followed by <url>, 'file', or \"document title\"."

let unknown_tag : string -> Location.span -> Error.t =
  Error.make "Unknown tag '%s'."

let unpaired_right_brace : Location.span -> Error.t =
  Error.make ~suggestion:"try '\\}'." "Unpaired '}' (end of markup)."

let unpaired_right_bracket : Location.span -> Error.t =
  Error.make ~suggestion:"try '\\]'." "Unpaired ']' (end of code)."

let invalid_raw_markup_target : string -> Location.span -> Error.t =
  Error.make
    ~suggestion:
      (Printf.sprintf "try %s." (Token.print (`Raw_markup (Some "html", ""))))
      "'{%%%s:': bad raw markup target."

let default_raw_markup_target_not_supported : Location.span -> Error.t =
  Error.make
    ~suggestion:
      (Printf.sprintf "try %s." (Token.print (`Raw_markup (Some "html", ""))))
    "%s needs a target language."
    (Token.describe (`Raw_markup (None, "")))

let expected : string -> Location.span -> Error.t =
  Error.make "Expected %s."

let unknown_reference_qualifier : string -> Location.span -> Error.t =
  Error.make "Unknown reference qualifier '%s'."

let deprecated_reference_kind : string -> string -> Location.span -> Error.t =
  Error.make "'%s' is deprecated, use '%s' instead."

let reference_kinds_do_not_match
    : string -> string -> Location.span -> Error.t =
  Error.make "Old-style reference kind ('%s:') does not match new ('%s-')."
OCaml

Innovation. Community. Security.