repl: fix import xxx with no fn main error

pull/4675/head
yuyi 2020-05-02 00:12:18 +08:00 committed by GitHub
parent 4d04e88679
commit de272654f1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 46 additions and 19 deletions

View File

@ -1,5 +0,0 @@
vlib/v/checker/tests/no_fn_main.v:1:1: error: function `main` must be declared in the main module
1 | fn no_main() {
| ^
2 | println('Hello world !')
3 | }

View File

@ -1,3 +0,0 @@
fn no_main() {
println('Hello world !')
}

View File

@ -401,3 +401,18 @@ fn (mut p Parser) fn_redefinition_error(name string) {
*/ */
p.error('redefinition of function `$name`') p.error('redefinition of function `$name`')
} }
fn have_fn_main(stmts []ast.Stmt) bool {
mut has_main_fn := false
for stmt in stmts {
match stmt {
ast.FnDecl {
if it.name == 'main' {
has_main_fn = true
}
}
else {}
}
}
return has_main_fn
}

View File

@ -63,7 +63,7 @@ pub fn parse_stmt(text string, table &table.Table, scope &ast.Scope) ast.Stmt {
return p.stmt() return p.stmt()
} }
pub fn parse_file(path string, table &table.Table, comments_mode scanner.CommentsMode, pref &pref.Preferences, global_scope &ast.Scope) ast.File { pub fn parse_file(path string, b_table &table.Table, comments_mode scanner.CommentsMode, pref &pref.Preferences, global_scope &ast.Scope) ast.File {
// println('parse_file("$path")') // println('parse_file("$path")')
// text := os.read_file(path) or { // text := os.read_file(path) or {
// panic(err) // panic(err)
@ -71,7 +71,7 @@ pub fn parse_file(path string, table &table.Table, comments_mode scanner.Comment
mut stmts := []ast.Stmt{} mut stmts := []ast.Stmt{}
mut p := Parser{ mut p := Parser{
scanner: scanner.new_scanner_file(path, comments_mode) scanner: scanner.new_scanner_file(path, comments_mode)
table: table table: b_table
file_name: path file_name: path
file_name_dir: os.dir(path) file_name_dir: os.dir(path)
pref: pref pref: pref
@ -102,9 +102,13 @@ pub fn parse_file(path string, table &table.Table, comments_mode scanner.Comment
*/ */
// TODO: import only mode // TODO: import only mode
for { for {
// res := s.scan()
if p.tok.kind == .eof { if p.tok.kind == .eof {
// println('EOF, breaking') if p.pref.is_script && !p.pref.is_test && p.mod == 'main' && !have_fn_main(stmts) {
stmts << ast.FnDecl {
name: 'main'
return_type: table.void_type
}
}
break break
} }
// println('stmt at ' + p.tok.str()) // println('stmt at ' + p.tok.str())
@ -350,7 +354,7 @@ pub fn (mut p Parser) top_stmt() ast.Stmt {
} }
else { else {
if p.pref.is_script && !p.pref.is_test { if p.pref.is_script && !p.pref.is_test {
p.scanner.add_fn_main_and_rescan() p.scanner.add_fn_main_and_rescan(p.tok.pos-1)
p.read_first_token() p.read_first_token()
return p.top_stmt() return p.top_stmt()
} else { } else {

View File

@ -75,12 +75,17 @@ pub fn new_scanner(text string, comments_mode CommentsMode) &Scanner {
return s return s
} }
pub fn (s &Scanner) add_fn_main_and_rescan() { pub fn (s &Scanner) add_fn_main_and_rescan(pos int) {
s.text = 'fn main() {' + s.text + '}' if pos > 0 {
s.is_started = false s.text = s.text[..pos] + 'fn main() {' + s.text[pos..] + '}'
s.pos = 0 s.pos = pos
s.line_nr = 0 s.is_started = false
s.last_nl_pos = 0 } else {
s.text = 'fn main() {' + s.text + '}'
s.pos = 0
s.line_nr = 0
s.is_started = false
}
} }
fn (s &Scanner) new_token(tok_kind token.Kind, lit string, len int) token.Token { fn (s &Scanner) new_token(tok_kind token.Kind, lit string, len int) token.Token {

View File

@ -0,0 +1,7 @@
mut a := [1, 2, 3]
b := [4, 5]
a << b
a = a.filter(it%2==0)
a
===output===
[2, 4]

View File

@ -0,0 +1,4 @@
import time
time.now().unix_time() > 160000
===output===
true