vet: remove false positive space indent errors inside strings (#9568)

pull/9575/head
Lukas Neubert 2021-04-03 12:16:49 +02:00 committed by GitHub
parent 7f81702d81
commit 094441c863
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 7 deletions

View File

@ -1,3 +1,5 @@
cmd/tools/vvet/tests/indent_with_space.vv:2: error: Looks like you are using spaces for indentation.
cmd/tools/vvet/tests/indent_with_space.vv:10: error: Looks like you are using spaces for indentation.
cmd/tools/vvet/tests/indent_with_space.vv:16: error: Looks like you are using spaces for indentation.
cmd/tools/vvet/tests/indent_with_space.vv:19: error: Looks like you are using spaces for indentation.
NB: You can run `v fmt -w file.v` to fix these errors automatically

View File

@ -11,3 +11,10 @@ fn block_comments() {
and inside too
*/
}
fn space_inside_strings() {
str := "Bad space usage for variable indentation.
Here it's fine.
Here too."
str2 := 'linebreak and space\n inside'
}

View File

@ -2330,9 +2330,14 @@ fn (mut p Parser) string_expr() ast.Expr {
}
mut node := ast.empty_expr()
val := p.tok.lit
pos := p.tok.position()
mut pos := p.tok.position()
pos.last_line = pos.line_nr + val.count('\n')
if p.peek_tok.kind != .str_dollar {
p.next()
if p.vet_errors.len > 0 && val.contains('\n ') {
p.vet_errors = p.vet_errors.filter(!(it.pos.line_nr > pos.line_nr - 1
&& it.pos.line_nr <= pos.last_line - 1))
}
node = ast.StringLiteral{
val: val
is_raw: is_raw