repl: handle print and one-line conditions
							parent
							
								
									03bc5ab3d5
								
							
						
					
					
						commit
						30e7cd8ed5
					
				| 
						 | 
					@ -11,34 +11,42 @@ struct Repl {
 | 
				
			||||||
mut:
 | 
					mut:
 | 
				
			||||||
	indent         int
 | 
						indent         int
 | 
				
			||||||
	in_func        bool
 | 
						in_func        bool
 | 
				
			||||||
 | 
						line           string
 | 
				
			||||||
	lines          []string
 | 
						lines          []string
 | 
				
			||||||
	temp_lines     []string
 | 
						temp_lines     []string
 | 
				
			||||||
	functions_name []string
 | 
						functions_name []string
 | 
				
			||||||
	functions      []string
 | 
						functions      []string
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
fn (r mut Repl) checks(line string) bool {
 | 
					fn (r mut Repl) checks() bool {
 | 
				
			||||||
	mut in_string := false
 | 
						mut in_string := false
 | 
				
			||||||
 | 
						mut is_cut := false
 | 
				
			||||||
	was_indent := r.indent > 0
 | 
						was_indent := r.indent > 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for i := 0; i < line.len; i++ {
 | 
						for i := 0; i < r.line.len; i++ {
 | 
				
			||||||
		if line[i] == `\'` && (i == 0 || line[i - 1] != `\\`) {
 | 
							if r.line[i] == `\'` && (i == 0 || r.line[i - 1] != `\\`) {
 | 
				
			||||||
			in_string = !in_string
 | 
								in_string = !in_string
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line[i] == `{` && !in_string {
 | 
							if r.line[i] == `{` && !in_string {
 | 
				
			||||||
 | 
								r.line = r.line.left(i + 1) + '\n' + r.line.right(i + 1)
 | 
				
			||||||
 | 
								is_cut = true
 | 
				
			||||||
 | 
								i++
 | 
				
			||||||
			r.indent++
 | 
								r.indent++
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line[i] == `}` && !in_string {
 | 
							if r.line[i] == `}` && !in_string {
 | 
				
			||||||
 | 
								r.line = r.line.left(i) + '\n' + r.line.right(i)
 | 
				
			||||||
 | 
								is_cut = true
 | 
				
			||||||
 | 
								i++
 | 
				
			||||||
			r.indent--
 | 
								r.indent--
 | 
				
			||||||
			if r.indent == 0 {
 | 
								if r.indent == 0 {
 | 
				
			||||||
				r.in_func = false
 | 
									r.in_func = false
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if i + 2 < line.len && r.indent == 0 && line[i + 1] == `f` && line[i + 2] == `n` {
 | 
							if i + 2 < r.line.len && r.indent == 0 && r.line[i + 1] == `f` && r.line[i + 2] == `n` {
 | 
				
			||||||
			r.in_func = true
 | 
								r.in_func = true
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return r.in_func || (was_indent && r.indent <= 0) || r.indent > 0
 | 
						return r.in_func || (was_indent && r.indent <= 0) || r.indent > 0 || is_cut
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
fn (r &Repl) function_call(line string) bool {
 | 
					fn (r &Repl) function_call(line string) bool {
 | 
				
			||||||
| 
						 | 
					@ -81,47 +89,49 @@ fn run_repl() []string {
 | 
				
			||||||
		else {
 | 
							else {
 | 
				
			||||||
			print('... ')
 | 
								print('... ')
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		mut line := os.get_raw_line()
 | 
							r.line = os.get_raw_line()
 | 
				
			||||||
		if line.trim_space() == '' && line.ends_with('\n') {
 | 
							if r.line.trim_space() == '' && r.line.ends_with('\n') {
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		line = line.trim_space()
 | 
							r.line = r.line.trim_space()
 | 
				
			||||||
		if line.len == -1 || line == '' || line == 'exit' {
 | 
							if r.line.len == -1 || r.line == '' || r.line == 'exit' {
 | 
				
			||||||
			break
 | 
								break
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line == '\n' {
 | 
							if r.line == '\n' {
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line == 'clear' {
 | 
							if r.line == 'clear' {
 | 
				
			||||||
			term.erase_display('2')
 | 
								term.erase_display('2')
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line == 'help' {
 | 
							if r.line == 'help' {
 | 
				
			||||||
			repl_help()
 | 
								repl_help()
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if line.starts_with('fn') {
 | 
							if r.line.starts_with('fn') {
 | 
				
			||||||
			r.in_func = true
 | 
								r.in_func = true
 | 
				
			||||||
			r.functions_name << line.all_after('fn').all_before('(').trim_space()
 | 
								r.functions_name << r.line.all_after('fn').all_before('(').trim_space()
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		was_func := r.in_func
 | 
							was_func := r.in_func
 | 
				
			||||||
		if r.checks(line) {
 | 
							if r.checks() {
 | 
				
			||||||
			if r.in_func || was_func {
 | 
								for line in r.line.split('\n') {
 | 
				
			||||||
				r.functions << line
 | 
									if r.in_func || was_func {
 | 
				
			||||||
			}
 | 
										r.functions << line
 | 
				
			||||||
			else {
 | 
									}
 | 
				
			||||||
				r.temp_lines << line
 | 
									else {
 | 
				
			||||||
 | 
										r.temp_lines << line
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			if r.indent > 0 {
 | 
								if r.indent > 0 {
 | 
				
			||||||
				continue
 | 
									continue
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			line = ''
 | 
								r.line = ''
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		// Save the source only if the user is printing something,
 | 
							// Save the source only if the user is printing something,
 | 
				
			||||||
		// but don't add this print call to the `lines` array,
 | 
							// but don't add this print call to the `lines` array,
 | 
				
			||||||
		// so that it doesn't get called during the next print.
 | 
							// so that it doesn't get called during the next print.
 | 
				
			||||||
		if line.starts_with('print') {
 | 
							if r.line.starts_with('print') {
 | 
				
			||||||
			source_code := r.functions.join('\n') + r.lines.join('\n') + '\n' + line
 | 
								source_code := r.functions.join('\n') + r.lines.join('\n') + '\n' + r.line
 | 
				
			||||||
			os.write_file(file, source_code)
 | 
								os.write_file(file, source_code)
 | 
				
			||||||
			s := os.exec('$vexe run $file -repl') or {
 | 
								s := os.exec('$vexe run $file -repl') or {
 | 
				
			||||||
				verror(err)
 | 
									verror(err)
 | 
				
			||||||
| 
						 | 
					@ -133,27 +143,27 @@ fn run_repl() []string {
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		else {
 | 
							else {
 | 
				
			||||||
			mut temp_line := line
 | 
								mut temp_line := r.line
 | 
				
			||||||
			mut temp_flag := false
 | 
								mut temp_flag := false
 | 
				
			||||||
			func_call := r.function_call(line)
 | 
								func_call := r.function_call(r.line)
 | 
				
			||||||
			if !(line.contains(' ') || line.contains(':') || line.contains('=') || line.contains(',') || line == '') && !func_call {
 | 
								if !(r.line.contains(' ') || r.line.contains(':') || r.line.contains('=') || r.line.contains(',') || r.line == '') && !func_call {
 | 
				
			||||||
				temp_line = 'println($line)'
 | 
									temp_line = 'println($r.line)'
 | 
				
			||||||
				temp_flag = true
 | 
									temp_flag = true
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			temp_source_code := r.functions.join('\n') + r.lines.join('\n') + r.temp_lines.join('\n') + '\n' + temp_line
 | 
								temp_source_code := r.functions.join('\n') + r.lines.join('\n') + '\n' + r.temp_lines.join('\n') + '\n' + temp_line
 | 
				
			||||||
			os.write_file(temp_file, temp_source_code)
 | 
								os.write_file(temp_file, temp_source_code)
 | 
				
			||||||
			s := os.exec('$vexe run $temp_file -repl') or {
 | 
								s := os.exec('$vexe run $temp_file -repl') or {
 | 
				
			||||||
				verror(err)
 | 
									verror(err)
 | 
				
			||||||
				return []string
 | 
									return []string
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			if !func_call && s.exit_code == 0 {
 | 
								if !func_call && s.exit_code == 0 && !temp_flag {
 | 
				
			||||||
				for r.temp_lines.len > 0 {
 | 
									for r.temp_lines.len > 0 {
 | 
				
			||||||
					if !r.temp_lines[0].starts_with('print') {
 | 
										if !r.temp_lines[0].starts_with('print') {
 | 
				
			||||||
						r.lines << r.temp_lines[0]
 | 
											r.lines << r.temp_lines[0]
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					r.temp_lines.delete(0)
 | 
										r.temp_lines.delete(0)
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
				r.lines << line
 | 
									r.lines << r.line
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			else {
 | 
								else {
 | 
				
			||||||
				for r.temp_lines.len > 0 {
 | 
									for r.temp_lines.len > 0 {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -32,47 +32,47 @@
 | 
				
			||||||
/*(17)*/ e.v << 1    // Error (e immutable)
 | 
					/*(17)*/ e.v << 1    // Error (e immutable)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
===output===
 | 
					===output===
 | 
				
			||||||
.vrepl_temp.v:8:14: cannot modify immutable field `len` (type `string`)
 | 
					.vrepl_temp.v:27:14: cannot modify immutable field `len` (type `string`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct string {
 | 
					struct string {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	len int
 | 
						len int
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:9:14: cannot modify immutable field `a` (type `B`)
 | 
					.vrepl_temp.v:30:14: cannot modify immutable field `a` (type `B`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct B {
 | 
					struct B {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	a A
 | 
						a A
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:9:12: cannot modify immutable field `a` (type `B`)
 | 
					.vrepl_temp.v:29:12: cannot modify immutable field `a` (type `B`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct B {
 | 
					struct B {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	a A
 | 
						a A
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:12:14: cannot modify immutable field `a` (type `B`)
 | 
					.vrepl_temp.v:41:14: cannot modify immutable field `a` (type `B`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct B {
 | 
					struct B {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	a A
 | 
						a A
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:12:16: cannot modify immutable field `a` (type `B`)
 | 
					.vrepl_temp.v:42:16: cannot modify immutable field `a` (type `B`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct B {
 | 
					struct B {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	a A
 | 
						a A
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:13:15: `c2` is immutable
 | 
					.vrepl_temp.v:44:15: `c2` is immutable
 | 
				
			||||||
.vrepl_temp.v:16:12: cannot modify immutable field `e` (type `F`)
 | 
					.vrepl_temp.v:53:12: cannot modify immutable field `e` (type `F`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct F {
 | 
					struct F {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	e []E
 | 
						e []E
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:16:17: cannot modify immutable field `e` (type `F`)
 | 
					.vrepl_temp.v:54:17: cannot modify immutable field `e` (type `F`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct F {
 | 
					struct F {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	e []E
 | 
						e []E
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:17:17: `e` is immutable (can't <<)
 | 
					.vrepl_temp.v:57:17: `e` is immutable (can't <<)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,5 +1,5 @@
 | 
				
			||||||
a
 | 
					a
 | 
				
			||||||
33
 | 
					33
 | 
				
			||||||
===output===
 | 
					===output===
 | 
				
			||||||
.vrepl_temp.v:2:9: undefined: `a`
 | 
					.vrepl_temp.v:3:9: undefined: `a`
 | 
				
			||||||
33
 | 
					33
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -9,19 +9,19 @@ ints.len = 0   // Error (field len immutable)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
println('BYE')
 | 
					println('BYE')
 | 
				
			||||||
===output===
 | 
					===output===
 | 
				
			||||||
.vrepl_temp.v:2:5: cannot modify immutable field `len` (type `string`)
 | 
					.vrepl_temp.v:3:5: cannot modify immutable field `len` (type `string`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct string {
 | 
					struct string {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	len int
 | 
						len int
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:3:5: cannot modify immutable field `len` (type `array`)
 | 
					.vrepl_temp.v:4:5: cannot modify immutable field `len` (type `array`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct array {
 | 
					struct array {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
	len int
 | 
						len int
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.vrepl_temp.v:4:8: cannot modify immutable field `len` (type `array`)
 | 
					.vrepl_temp.v:5:8: cannot modify immutable field `len` (type `array`)
 | 
				
			||||||
declare the field with `mut:`
 | 
					declare the field with `mut:`
 | 
				
			||||||
struct array {
 | 
					struct array {
 | 
				
			||||||
  mut:
 | 
					  mut:
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue