@@ -41,3 +41,112 @@ parser_switch_mut_let_order =
41
41
parser_missing_let_before_mut = missing keyword
42
42
parser_use_let_not_auto = write `let` instead of `auto` to introduce a new variable
43
43
parser_use_let_not_var = write `let` instead of `var` to introduce a new variable
44
+
45
+ parser_invalid_comparison_operator = invalid comparison operator `{ $invalid } `
46
+ .use_instead = `{ $invalid } ` is not a valid comparison operator, use `{ $correct } `
47
+ .spaceship_operator_invalid = `<=>` is not a valid comparison operator, use `std::cmp::Ordering`
48
+
49
+ parser_invalid_logical_operator = `{ $incorrect } ` is not a logical operator
50
+ .note = unlike in e.g., python and PHP, `&&` and `||` are used for logical operators
51
+ .use_amp_amp_for_conjunction = use `&&` to perform logical conjunction
52
+ .use_pipe_pipe_for_disjunction = use `||` to perform logical disjunction
53
+
54
+ parser_tilde_is_not_unary_operator = `~` cannot be used as a unary operator
55
+ .suggestion = use `!` to perform bitwise not
56
+
57
+ parser_unexpected_token_after_not = unexpected { $negated_desc } after identifier
58
+ .suggestion = use `!` to perform logical negation
59
+
60
+ parser_malformed_loop_label = malformed loop label
61
+ .suggestion = use the correct loop label format
62
+
63
+ parser_lifetime_in_borrow_expression = borrow expressions cannot be annotated with lifetimes
64
+ .suggestion = remove the lifetime annotation
65
+ .label = annotated with lifetime here
66
+
67
+ parser_field_expression_with_generic = field expressions cannot have generic arguments
68
+
69
+ parser_macro_invocation_with_qualified_path = macros cannot use qualified paths
70
+
71
+ parser_unexpected_token_after_label = expected `while`, `for`, `loop` or `{ " { " } ` after a label
72
+
73
+ parser_require_colon_after_labeled_expression = labeled expression must be followed by `:`
74
+ .note = labels are used before loops and blocks, allowing e.g., `break 'label` to them
75
+ .label = the label
76
+ .suggestion = add `:` after the label
77
+
78
+ parser_do_catch_syntax_removed = found removed `do catch` syntax
79
+ .note = following RFC #2388, the new non-placeholder syntax is `try`
80
+ .suggestion = replace with the new syntax
81
+
82
+ parser_float_literal_requires_integer_part = float literals must have an integer part
83
+ .suggestion = must have an integer part
84
+
85
+ parser_invalid_int_literal_width = invalid width `{ $width } ` for integer literal
86
+ .help = valid widths are 8, 16, 32, 64 and 128
87
+
88
+ parser_invalid_num_literal_base_prefix = invalid base prefix for number literal
89
+ .note = base prefixes (`0xff`, `0b1010`, `0o755`) are lowercase
90
+ .suggestion = try making the prefix lowercase
91
+
92
+ parser_invalid_num_literal_suffix = invalid suffix `{ $suffix } ` for number literal
93
+ .label = invalid suffix `{ $suffix } `
94
+ .help = the suffix must be one of the numeric types (`u32`, `isize`, `f32`, etc.)
95
+
96
+ parser_invalid_float_literal_width = invalid width `{ $width } ` for float literal
97
+ .help = valid widths are 32 and 64
98
+
99
+ parser_invalid_float_literal_suffix = invalid suffix `{ $suffix } ` for float literal
100
+ .label = invalid suffix `{ $suffix } `
101
+ .help = valid suffixes are `f32` and `f64`
102
+
103
+ parser_int_literal_too_large = integer literal is too large
104
+
105
+ parser_missing_semicolon_before_array = expected `;`, found `[`
106
+ .suggestion = consider adding `;` here
107
+
108
+ parser_invalid_block_macro_segment = cannot use a `block` macro fragment here
109
+ .label = the `block` fragment is within this context
110
+
111
+ parser_if_expression_missing_then_block = this `if` expression is missing a block after the condition
112
+ .add_then_block = add a block here
113
+ .condition_possibly_unfinished = this binary operation is possibly unfinished
114
+
115
+ parser_if_expression_missing_condition = missing condition for `if` expression
116
+ .condition_label = expected condition here
117
+ .block_label = if this block is the condition of the `if` expression, then it must be followed by another block
118
+
119
+ parser_expected_expression_found_let = expected expression, found `let` statement
120
+
121
+ parser_expected_else_block = expected `{ " { " } `, found { $first_tok }
122
+ .label = expected an `if` or a block after this `else`
123
+ .suggestion = add an `if` if this is the condition of a chained `else if` statement
124
+
125
+ parser_outer_attribute_not_allowed_on_if_else = outer attributes are not allowed on `if` and `else` branches
126
+ .branch_label = the attributes are attached to this branch
127
+ .ctx_label = the branch belongs to this `{ $ctx } `
128
+ .suggestion = remove the attributes
129
+
130
+ parser_missing_in_in_for_loop = missing `in` in `for` loop
131
+ .use_in_not_of = try using `in` here instead
132
+ .add_in = try adding `in` here
133
+
134
+ parser_missing_comma_after_match_arm = expected `,` following `match` arm
135
+ .suggestion = missing a comma here to end this `match` arm
136
+
137
+ parser_catch_after_try = keyword `catch` cannot follow a `try` block
138
+ .help = try using `match` on the result of the `try` block instead
139
+
140
+ parser_comma_after_base_struct = cannot use a comma after the base struct
141
+ .note = the base struct must always be the last field
142
+ .suggestion = remove this comma
143
+
144
+ parser_eq_field_init = expected `:`, found `=`
145
+ .suggestion = replace equals symbol with a colon
146
+
147
+ parser_dotdotdot = unexpected token: `...`
148
+ .suggest_exclusive_range = use `..` for an exclusive range
149
+ .suggest_inclusive_range = or `..=` for an inclusive range
150
+
151
+ parser_left_arrow_operator = unexpected token: `<-`
152
+ .suggestion = if you meant to write a comparison against a negative value, add a space in between `<` and `-`
0 commit comments