mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
parent
029d583bb2
commit
758f84fa86
@ -1264,7 +1264,7 @@ pub fn (t &Table) type_to_str_using_aliases(typ Type, import_aliases map[string]
|
||||
} else if sym.info is SumType && (sym.info as SumType).is_anon {
|
||||
variant_names := sym.info.variants.map(t.shorten_user_defined_typenames(t.sym(it).name,
|
||||
import_aliases))
|
||||
res = '${variant_names.join(' | ')}'
|
||||
res = '${variant_names.join('|')}'
|
||||
} else {
|
||||
res = t.shorten_user_defined_typenames(res, import_aliases)
|
||||
}
|
||||
|
@ -1,13 +1,13 @@
|
||||
import v.token
|
||||
|
||||
struct Foo {
|
||||
bar string | int
|
||||
bar string|int
|
||||
}
|
||||
|
||||
interface Egg {
|
||||
milk string | int
|
||||
milk string|int
|
||||
}
|
||||
|
||||
fn foo(bar string | int) int | string | token.Pos {
|
||||
fn foo(bar string|int) int|string|token.Pos {
|
||||
return 1
|
||||
}
|
||||
|
@ -401,7 +401,7 @@ fn (mut g Gen) gen_str_for_union_sum_type(info ast.SumType, styp string, str_fn_
|
||||
mut clean_sum_type_v_type_name := ''
|
||||
if info.is_anon {
|
||||
variant_names := info.variants.map(util.strip_main_name(g.table.sym(it).name))
|
||||
clean_sum_type_v_type_name = '(${variant_names.join(' | ')})'
|
||||
clean_sum_type_v_type_name = '${variant_names.join('|')}'
|
||||
} else {
|
||||
clean_sum_type_v_type_name = styp.replace('__', '.')
|
||||
if styp.ends_with('*') {
|
||||
|
@ -2493,6 +2493,24 @@ pub fn (mut p Parser) name_expr() ast.Expr {
|
||||
typ: typ
|
||||
pos: type_pos
|
||||
}
|
||||
} else if !known_var && language == .v && (p.table.known_type(p.tok.lit) || lit0_is_capital)
|
||||
&& p.peek_tok.kind == .pipe {
|
||||
start_pos := p.tok.pos()
|
||||
mut to_typ := p.parse_type()
|
||||
p.check(.lpar)
|
||||
expr := p.expr(0)
|
||||
end_pos := p.tok.pos()
|
||||
p.check(.rpar)
|
||||
node = ast.CastExpr{
|
||||
typ: to_typ
|
||||
typname: p.table.sym(to_typ).name
|
||||
expr: expr
|
||||
arg: ast.empty_expr()
|
||||
has_arg: false
|
||||
pos: start_pos.extend(end_pos)
|
||||
}
|
||||
p.expr_mod = ''
|
||||
return node
|
||||
}
|
||||
|
||||
ident := p.parse_ident(language)
|
||||
|
@ -1,8 +1,8 @@
|
||||
fn returns_sumtype() int | string {
|
||||
fn returns_sumtype() int|string {
|
||||
return 1
|
||||
}
|
||||
|
||||
fn returns_sumtype_reverse() int | string {
|
||||
fn returns_sumtype_reverse() int|string {
|
||||
return 1
|
||||
}
|
||||
|
||||
@ -13,7 +13,7 @@ fn test_stringification() {
|
||||
}
|
||||
|
||||
struct Milk {
|
||||
egg int | string
|
||||
egg int|string
|
||||
}
|
||||
|
||||
fn test_struct_with_inline_sumtype() {
|
||||
@ -24,7 +24,7 @@ fn test_struct_with_inline_sumtype() {
|
||||
}
|
||||
|
||||
interface IMilk {
|
||||
egg int | string
|
||||
egg int|string
|
||||
}
|
||||
|
||||
fn receive_imilk(milk IMilk) {}
|
||||
@ -36,6 +36,6 @@ fn test_interface_with_inline_sumtype() {
|
||||
receive_imilk(m)
|
||||
}
|
||||
|
||||
fn returns_sumtype_in_multireturn() (int | string, string) {
|
||||
fn returns_sumtype_in_multireturn() (int|string, string) {
|
||||
return 1, ''
|
||||
}
|
||||
|
7
vlib/v/tests/cast_to_anon_sumtype_test.v
Normal file
7
vlib/v/tests/cast_to_anon_sumtype_test.v
Normal file
@ -0,0 +1,7 @@
|
||||
module main
|
||||
|
||||
fn test_cast_to_anon_sumtype() {
|
||||
x := string|none(none)
|
||||
println(x)
|
||||
assert '$x' == 'string|none(none)'
|
||||
}
|
@ -11,7 +11,7 @@ fn (err MyError) code() int {
|
||||
return err.code
|
||||
}
|
||||
|
||||
fn foo() int | none | IError {
|
||||
fn foo() int|none|IError {
|
||||
return IError(MyError{})
|
||||
}
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
module main
|
||||
|
||||
fn string_none() string | none {
|
||||
fn string_none() string|none {
|
||||
return none
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user