fmt: cleanup redundant generic types code (#10990)

pull/10993/head
Lukas Neubert 2021-07-29 14:21:10 +02:00 committed by GitHub
parent ae05ab880e
commit 1e255d3ab1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 32 deletions

View File

@ -110,14 +110,6 @@ fn (mut f Fmt) write_indent() {
f.line_len += f.indent * 4 f.line_len += f.indent * 4
} }
fn (mut f Fmt) write_language_prefix(lang ast.Language) {
match lang {
.c { f.write('C.') }
.js { f.write('JS.') }
else {}
}
}
pub fn (mut f Fmt) wrap_long_line(penalty_idx int, add_indent bool) bool { pub fn (mut f Fmt) wrap_long_line(penalty_idx int, add_indent bool) bool {
if f.buffering { if f.buffering {
return false return false
@ -156,6 +148,25 @@ pub fn (mut f Fmt) remove_new_line(cfg RemoveNewLineConfig) {
f.empty_line = false f.empty_line = false
} }
//=== Specialized write methods ===//
fn (mut f Fmt) write_language_prefix(lang ast.Language) {
match lang {
.c { f.write('C.') }
.js { f.write('JS.') }
else {}
}
}
fn (mut f Fmt) write_generic_types(gtypes []ast.Type) {
if gtypes.len > 0 {
f.write('<')
gtypes_string := gtypes.map(f.table.type_to_str(it)).join(', ')
f.write(gtypes_string)
f.write('>')
}
}
//=== Module handling helper methods ===// //=== Module handling helper methods ===//
pub fn (mut f Fmt) set_current_module_name(cmodname string) { pub fn (mut f Fmt) set_current_module_name(cmodname string) {
@ -1016,19 +1027,14 @@ pub fn (mut f Fmt) interface_decl(node ast.InterfaceDecl) {
} }
f.write('interface ') f.write('interface ')
f.write_language_prefix(node.language) f.write_language_prefix(node.language)
name := node.name.after('.') name := node.name.after('.') // strip prepended module
f.write(name) f.write(name)
if node.generic_types.len > 0 { f.write_generic_types(node.generic_types)
f.write('<')
gtypes := node.generic_types.map(f.table.type_to_str(it)).join(', ')
f.write(gtypes)
f.write('>')
}
f.write(' {') f.write(' {')
if node.fields.len > 0 || node.methods.len > 0 || node.pos.line_nr < node.pos.last_line { if node.fields.len > 0 || node.methods.len > 0 || node.pos.line_nr < node.pos.last_line {
f.writeln('') f.writeln('')
} }
f.comments_after_last_field(node.pre_comments) f.comments_before_field(node.pre_comments)
for iface in node.ifaces { for iface in node.ifaces {
f.write('\t$iface.name') f.write('\t$iface.name')
f.comments(iface.comments, inline: true, has_nl: false, level: .indent) f.comments(iface.comments, inline: true, has_nl: false, level: .indent)
@ -1208,12 +1214,7 @@ pub fn (mut f Fmt) sum_type_decl(node ast.SumTypeDecl) {
f.write('pub ') f.write('pub ')
} }
f.write('type $node.name') f.write('type $node.name')
if node.generic_types.len > 0 { f.write_generic_types(node.generic_types)
f.write('<')
gtypes := node.generic_types.map(f.table.type_to_str(it)).join(', ')
f.write(gtypes)
f.write('>')
}
f.write(' = ') f.write(' = ')
mut sum_type_names := []string{} mut sum_type_names := []string{}
@ -1510,7 +1511,7 @@ pub fn (mut f Fmt) call_expr(node ast.CallExpr) {
if node.mod == '' && node.name == '' { if node.mod == '' && node.name == '' {
f.write(node.left.str()) f.write(node.left.str())
} }
f.write_generic_if_require(node) f.write_generic_call_if_require(node)
f.write('(') f.write('(')
f.call_args(node.args) f.call_args(node.args)
f.write(')') f.write(')')
@ -1518,7 +1519,7 @@ pub fn (mut f Fmt) call_expr(node ast.CallExpr) {
f.comments(node.comments, has_nl: false) f.comments(node.comments, has_nl: false)
} }
fn (mut f Fmt) write_generic_if_require(node ast.CallExpr) { fn (mut f Fmt) write_generic_call_if_require(node ast.CallExpr) {
if node.concrete_types.len > 0 { if node.concrete_types.len > 0 {
f.write('<') f.write('<')
for i, concrete_type in node.concrete_types { for i, concrete_type in node.concrete_types {

View File

@ -18,19 +18,13 @@ pub fn (mut f Fmt) struct_decl(node ast.StructDecl) {
f.write('struct ') f.write('struct ')
} }
f.write_language_prefix(node.language) f.write_language_prefix(node.language)
name := node.name.after('.') name := node.name.after('.') // strip prepended module
f.write(name) f.write(name)
if node.generic_types.len > 0 { f.write_generic_types(node.generic_types)
f.write('<')
gtypes := node.generic_types.map(f.table.type_to_str(it)).join(', ')
f.write(gtypes)
f.write('>')
}
if node.fields.len == 0 && node.embeds.len == 0 && node.pos.line_nr == node.pos.last_line { if node.fields.len == 0 && node.embeds.len == 0 && node.pos.line_nr == node.pos.last_line {
f.writeln(' {}') f.writeln(' {}')
return return
} }
f.writeln(' {')
mut field_aligns := []AlignInfo{} mut field_aligns := []AlignInfo{}
mut comment_aligns := []AlignInfo{} mut comment_aligns := []AlignInfo{}
mut default_expr_aligns := []AlignInfo{} mut default_expr_aligns := []AlignInfo{}
@ -59,6 +53,7 @@ pub fn (mut f Fmt) struct_decl(node ast.StructDecl) {
use_threshold: true) use_threshold: true)
} }
} }
f.writeln(' {')
for embed in node.embeds { for embed in node.embeds {
f.mark_types_import_as_used(embed.typ) f.mark_types_import_as_used(embed.typ)
styp := f.table.type_to_str_using_aliases(embed.typ, f.mod2alias) styp := f.table.type_to_str_using_aliases(embed.typ, f.mod2alias)