fmt: fix removal of selective imported types used in type decl (#12868)
parent
2f7ac7e407
commit
e5e3979e45
|
@ -1238,6 +1238,7 @@ pub fn (mut f Fmt) alias_type_decl(node ast.AliasTypeDecl) {
|
||||||
f.write('type $node.name = $ptype')
|
f.write('type $node.name = $ptype')
|
||||||
|
|
||||||
f.comments(node.comments, has_nl: false)
|
f.comments(node.comments, has_nl: false)
|
||||||
|
f.mark_types_import_as_used(node.parent_type)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (mut f Fmt) fn_type_decl(node ast.FnTypeDecl) {
|
pub fn (mut f Fmt) fn_type_decl(node ast.FnTypeDecl) {
|
||||||
|
@ -1254,6 +1255,7 @@ pub fn (mut f Fmt) fn_type_decl(node ast.FnTypeDecl) {
|
||||||
f.write(arg.typ.share().str() + ' ')
|
f.write(arg.typ.share().str() + ' ')
|
||||||
}
|
}
|
||||||
f.write(arg.name)
|
f.write(arg.name)
|
||||||
|
f.mark_types_import_as_used(arg.typ)
|
||||||
mut s := f.no_cur_mod(f.table.type_to_str_using_aliases(arg.typ, f.mod2alias))
|
mut s := f.no_cur_mod(f.table.type_to_str_using_aliases(arg.typ, f.mod2alias))
|
||||||
if arg.is_mut {
|
if arg.is_mut {
|
||||||
if s.starts_with('&') {
|
if s.starts_with('&') {
|
||||||
|
@ -1278,6 +1280,7 @@ pub fn (mut f Fmt) fn_type_decl(node ast.FnTypeDecl) {
|
||||||
}
|
}
|
||||||
f.write(')')
|
f.write(')')
|
||||||
if fn_info.return_type.idx() != ast.void_type_idx {
|
if fn_info.return_type.idx() != ast.void_type_idx {
|
||||||
|
f.mark_types_import_as_used(fn_info.return_type)
|
||||||
ret_str := f.no_cur_mod(f.table.type_to_str_using_aliases(fn_info.return_type,
|
ret_str := f.no_cur_mod(f.table.type_to_str_using_aliases(fn_info.return_type,
|
||||||
f.mod2alias))
|
f.mod2alias))
|
||||||
f.write(' $ret_str')
|
f.write(' $ret_str')
|
||||||
|
@ -1298,8 +1301,11 @@ pub fn (mut f Fmt) sum_type_decl(node ast.SumTypeDecl) {
|
||||||
f.write_generic_types(node.generic_types)
|
f.write_generic_types(node.generic_types)
|
||||||
f.write(' = ')
|
f.write(' = ')
|
||||||
|
|
||||||
mut sum_type_names := node.variants.map(f.table.type_to_str_using_aliases(it.typ,
|
mut sum_type_names := []string{cap: node.variants.len}
|
||||||
f.mod2alias))
|
for variant in node.variants {
|
||||||
|
sum_type_names << f.table.type_to_str_using_aliases(variant.typ, f.mod2alias)
|
||||||
|
f.mark_types_import_as_used(variant.typ)
|
||||||
|
}
|
||||||
sum_type_names.sort()
|
sum_type_names.sort()
|
||||||
|
|
||||||
mut separator := ' | '
|
mut separator := ' | '
|
||||||
|
|
|
@ -6,7 +6,10 @@ import os {
|
||||||
user_os,
|
user_os,
|
||||||
}
|
}
|
||||||
import mod {
|
import mod {
|
||||||
|
AliasTarget,
|
||||||
Enum,
|
Enum,
|
||||||
|
FnAliasParam,
|
||||||
|
FnAliasRet,
|
||||||
FnArg,
|
FnArg,
|
||||||
FnArgGeneric,
|
FnArgGeneric,
|
||||||
FnArgTypeParam1,
|
FnArgTypeParam1,
|
||||||
|
@ -29,8 +32,14 @@ import mod {
|
||||||
StructMethodRet,
|
StructMethodRet,
|
||||||
StructMethodRetGeneric,
|
StructMethodRetGeneric,
|
||||||
StructRefField,
|
StructRefField,
|
||||||
|
SumVariant1,
|
||||||
|
SumVariant2,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Alias = AliasTarget
|
||||||
|
type SumType = SumVariant1 | SumVariant2
|
||||||
|
type Fn = fn (FnAliasParam) FnAliasRet
|
||||||
|
|
||||||
struct Struct {
|
struct Struct {
|
||||||
StructEmbed
|
StructEmbed
|
||||||
v StructField
|
v StructField
|
||||||
|
|
|
@ -32,9 +32,17 @@ import mod {
|
||||||
RightOfIs,
|
RightOfIs,
|
||||||
RightOfAs,
|
RightOfAs,
|
||||||
|
|
||||||
|
AliasTarget,
|
||||||
|
SumVariant1, SumVariant2,
|
||||||
|
FnAliasParam, FnAliasRet
|
||||||
|
|
||||||
Enum
|
Enum
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Alias = AliasTarget
|
||||||
|
type SumType = SumVariant1 | SumVariant2
|
||||||
|
type Fn = fn(FnAliasParam) FnAliasRet
|
||||||
|
|
||||||
struct Struct {
|
struct Struct {
|
||||||
StructEmbed
|
StructEmbed
|
||||||
v StructField
|
v StructField
|
||||||
|
|
Loading…
Reference in New Issue