From 9d845262b75bd4cd1fc8c15d16410de4f5e62afe Mon Sep 17 00:00:00 2001 From: yuyi Date: Mon, 29 Jun 2020 23:15:40 +0800 Subject: [PATCH] parser: fix module type cast --- vlib/v/parser/parser.v | 9 ++++++--- vlib/v/tests/module_type_cast_test.v | 8 ++++++++ 2 files changed, 14 insertions(+), 3 deletions(-) create mode 100644 vlib/v/tests/module_type_cast_test.v diff --git a/vlib/v/parser/parser.v b/vlib/v/parser/parser.v index e10830cdbb..d6bd73fd89 100644 --- a/vlib/v/parser/parser.v +++ b/vlib/v/parser/parser.v @@ -855,6 +855,7 @@ pub fn (mut p Parser) name_expr() ast.Expr { else {} } } + mut is_mod_cast := false if p.peek_tok.kind == .dot && !known_var && (language != .v || p.known_import(p.tok.lit) || p.mod.all_after_last('.') == p.tok.lit) { if language == .c { @@ -864,6 +865,9 @@ pub fn (mut p Parser) name_expr() ast.Expr { } else { if p.tok.lit in p.imports { p.register_used_import(p.tok.lit) + if p.peek_tok.kind == .dot && p.peek_tok2.lit[0].is_capital() { + is_mod_cast = true + } } // prepend the full import mod = p.imports[p.tok.lit] @@ -884,9 +888,8 @@ pub fn (mut p Parser) name_expr() ast.Expr { name_w_mod := p.prepend_mod(name) // type cast. TODO: finish // if name in table.builtin_type_names { - if !known_var && (name in p.table.type_idxs || - name_w_mod in p.table.type_idxs) && - name !in ['C.stat', 'C.sigaction'] { + if (!known_var && (name in p.table.type_idxs || name_w_mod in p.table.type_idxs) && + name !in ['C.stat', 'C.sigaction']) || is_mod_cast { // TODO handle C.stat() mut to_typ := p.parse_type() if p.is_amp { diff --git a/vlib/v/tests/module_type_cast_test.v b/vlib/v/tests/module_type_cast_test.v new file mode 100644 index 0000000000..525ef2260c --- /dev/null +++ b/vlib/v/tests/module_type_cast_test.v @@ -0,0 +1,8 @@ +import time + +fn test_module_type_cast() { + a := time.Duration(5) + b := time.Duration(6) + //println(a+b) + assert a+b == 11 +}