1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

cgen: fix print(struct); use automatic referencing

This commit is contained in:
Alexander Medvednikov 2020-03-20 17:11:58 +01:00
parent 078f498b17
commit 6b571155f4
6 changed files with 8 additions and 7 deletions

View File

@ -13,7 +13,7 @@ pub fn compile(command string, args []string) {
// Construct the V object from command line arguments
parse_and_output_new_format(args)
prefs, remaining := parse_arguments(args)
check_for_common_mistake(args, &prefs)
check_for_common_mistake(args, prefs)
mut v := compiler.new_v(prefs)
if v.pref.verbosity.is_higher_or_equal(.level_two) {
println(args)

View File

@ -29,7 +29,7 @@ fn parse_arguments(args []string) (pref.Preferences, []string) {
} else {
p.backend = .c
}
mut remaining := flag.parse_pref(args, parse_options, &p) or {
mut remaining := flag.parse_pref(args, parse_options, p) or {
println('V error: Error while parsing flags.')
println(err)
println('Args:')

View File

@ -36,7 +36,7 @@ fn main() {
}
if prefs.verbosity.is_higher_or_equal(.level_three) {
println('Parsed preferences: ')
println(prefs)
//println(prefs) // QTODO
println('Remaining: $values')
}
// Do a quick check for `v -v`. Too much error has been made this way.

View File

@ -1330,7 +1330,7 @@ fn (p mut Parser) fn_call_args(f mut Fn, generic_param_types []string) {
p.check(.rpar)
if f.is_generic && !p.scanner.is_fmt {
type_map := p.extract_type_inst(f, saved_args)
p.dispatch_generic_fn_instance(mut f, &type_map)
p.dispatch_generic_fn_instance(mut f, type_map)
}
if f.is_variadic {
p.fn_gen_caller_vargs(f, varg_type, varg_values)

View File

@ -365,7 +365,7 @@ fn (p mut Parser) struct_init(typ_ string) string {
t = p.table.find_type(t.name)
typ = t.name
}
if p.gen_struct_init(typ, &t) {
if p.gen_struct_init(typ, t) {
return typ
}
ptr := typ.contains('*')

View File

@ -648,8 +648,9 @@ fn (g mut Gen) expr(node ast.Expr) {
g.write('${name}(')
if name == 'println' && it.args[0].typ != table.string_type_idx {
// `println(int_str(10))`
sym := g.table.get_type_symbol(it.args[0].typ)
g.write('${sym.name}_str(')
// sym := g.table.get_type_symbol(it.args[0].typ)
styp := g.typ(it.args[0].typ)
g.write('${styp}_str(')
g.expr(it.args[0].expr)
g.write('))')
}