From fe64346ae237322c3510764447d6a20596a37b1c Mon Sep 17 00:00:00 2001 From: yuyi Date: Fri, 16 Jul 2021 17:00:37 +0800 Subject: [PATCH] parser: minor optimization of array filtering judgement (#10821) --- vlib/v/parser/expr.v | 2 +- vlib/v/parser/parser.v | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/vlib/v/parser/expr.v b/vlib/v/parser/expr.v index ef2b3d9ea9..9dc9a584c9 100644 --- a/vlib/v/parser/expr.v +++ b/vlib/v/parser/expr.v @@ -36,7 +36,7 @@ pub fn (mut p Parser) check_expr(precedence int) ?ast.Expr { ident := p.parse_ident(ast.Language.v) node = ident if p.inside_defer { - if p.defer_vars.filter(it.name == ident.name && it.mod == ident.mod).len == 0 + if !p.defer_vars.any(it.name == ident.name && it.mod == ident.mod) && ident.name != 'err' { p.defer_vars << ident } diff --git a/vlib/v/parser/parser.v b/vlib/v/parser/parser.v index 83aec8c477..7073a035ab 100644 --- a/vlib/v/parser/parser.v +++ b/vlib/v/parser/parser.v @@ -2055,8 +2055,8 @@ pub fn (mut p Parser) name_expr() ast.Expr { ident := p.parse_ident(language) node = ident if p.inside_defer { - if p.defer_vars.filter(it.name == ident.name - && it.mod == ident.mod).len == 0 && ident.name != 'err' { + if !p.defer_vars.any(it.name == ident.name && it.mod == ident.mod) + && ident.name != 'err' { p.defer_vars << ident } } @@ -2085,7 +2085,7 @@ pub fn (mut p Parser) name_expr() ast.Expr { ident := p.parse_ident(language) node = ident if p.inside_defer { - if p.defer_vars.filter(it.name == ident.name && it.mod == ident.mod).len == 0 + if !p.defer_vars.any(it.name == ident.name && it.mod == ident.mod) && ident.name != 'err' { p.defer_vars << ident } @@ -2197,7 +2197,7 @@ pub fn (mut p Parser) name_expr() ast.Expr { ident := p.parse_ident(language) node = ident if p.inside_defer { - if p.defer_vars.filter(it.name == ident.name && it.mod == ident.mod).len == 0 + if !p.defer_vars.any(it.name == ident.name && it.mod == ident.mod) && ident.name != 'err' { p.defer_vars << ident } @@ -2354,7 +2354,7 @@ fn (mut p Parser) dot_expr(left ast.Expr) ast.Expr { concrete_list_pos = concrete_list_pos.extend(p.prev_tok.position()) // In case of `foo()` // T is unwrapped and registered in the checker. - has_generic := concrete_types.filter(it.has_flag(.generic)).len > 0 + has_generic := concrete_types.any(it.has_flag(.generic)) if !has_generic { // will be added in checker p.table.register_fn_concrete_types(field_name, concrete_types)