mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
cgen: fix dumping shared variable (#15615)
This commit is contained in:
parent
56135dbdbc
commit
64f403e997
@ -14,7 +14,13 @@ fn (mut g Gen) dump_expr(node ast.DumpExpr) {
|
||||
}
|
||||
dump_fn_name := '_v_dump_expr_$node.cname' + (if node.expr_type.is_ptr() { '_ptr' } else { '' })
|
||||
g.write(' ${dump_fn_name}(${ctoslit(fpath)}, $line, $sexpr, ')
|
||||
if node.expr_type.has_flag(.shared_f) {
|
||||
g.write('&')
|
||||
g.expr(node.expr)
|
||||
g.write('->val')
|
||||
} else {
|
||||
g.expr(node.expr)
|
||||
}
|
||||
g.write(' )')
|
||||
}
|
||||
|
||||
@ -27,7 +33,7 @@ fn (mut g Gen) dump_expr_definitions() {
|
||||
_, str_method_expects_ptr, _ := dump_sym.str_method_info()
|
||||
is_ptr := ast.Type(dump_type).is_ptr()
|
||||
deref, _ := deref_kind(str_method_expects_ptr, is_ptr, dump_type)
|
||||
to_string_fn_name := g.get_str_fn(dump_type)
|
||||
to_string_fn_name := g.get_str_fn(ast.Type(dump_type).clear_flag(.shared_f))
|
||||
ptr_asterisk := if is_ptr { '*' } else { '' }
|
||||
mut str_dumparg_type := '$cname$ptr_asterisk'
|
||||
if dump_sym.kind == .function {
|
||||
|
3
vlib/v/tests/inout/dump_shared_arg.out
Normal file
3
vlib/v/tests/inout/dump_shared_arg.out
Normal file
@ -0,0 +1,3 @@
|
||||
[vlib/v/tests/inout/dump_shared_arg.vv:12] inst: &AtomicStruct{
|
||||
a: 1
|
||||
}
|
14
vlib/v/tests/inout/dump_shared_arg.vv
Normal file
14
vlib/v/tests/inout/dump_shared_arg.vv
Normal file
@ -0,0 +1,14 @@
|
||||
module main
|
||||
|
||||
struct AtomicStruct {
|
||||
a int
|
||||
}
|
||||
|
||||
fn main() {
|
||||
shared inst := AtomicStruct{
|
||||
a: 1
|
||||
}
|
||||
lock inst {
|
||||
dump(inst)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user