v: cgen fix struct ordering
parent
be2480c320
commit
ea2a79ec20
|
@ -652,14 +652,14 @@ fn (g mut Gen) write_sorted_types() {
|
||||||
// builtin types need to be on top
|
// builtin types need to be on top
|
||||||
builtins := ['string', 'array', 'KeyValue', 'map', 'Option']
|
builtins := ['string', 'array', 'KeyValue', 'map', 'Option']
|
||||||
// everything except builtin will get sorted
|
// everything except builtin will get sorted
|
||||||
for typ in g.table.types {
|
for builtin_name in builtins {
|
||||||
if typ.name in builtins {
|
builtin_types << g.table.types[g.table.type_idxs[builtin_name]]
|
||||||
// || t.is_generic {
|
|
||||||
builtin_types << typ
|
|
||||||
continue
|
|
||||||
}
|
}
|
||||||
|
for typ in g.table.types {
|
||||||
|
if !(typ.name in builtins) {
|
||||||
types << typ
|
types << typ
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// sort structs
|
// sort structs
|
||||||
types_sorted := g.sort_structs(types)
|
types_sorted := g.sort_structs(types)
|
||||||
// Generate C code
|
// Generate C code
|
||||||
|
@ -712,7 +712,7 @@ fn (g &Gen) sort_structs(types []table.TypeSymbol) []table.TypeSymbol {
|
||||||
// ft := if field.typ.starts_with('[') { field.typ.all_after(']') } else { field.typ }
|
// ft := if field.typ.starts_with('[') { field.typ.all_after(']') } else { field.typ }
|
||||||
dep := g.table.get_type_symbol(field.typ).name
|
dep := g.table.get_type_symbol(field.typ).name
|
||||||
// skip if not in types list or already in deps
|
// skip if not in types list or already in deps
|
||||||
if !(dep in type_names) || dep in field_deps {
|
if !(dep in type_names) || dep in field_deps || table.type_is_ptr(field.typ){
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
field_deps << dep
|
field_deps << dep
|
||||||
|
@ -731,12 +731,7 @@ fn (g &Gen) sort_structs(types []table.TypeSymbol) []table.TypeSymbol {
|
||||||
// sort types
|
// sort types
|
||||||
mut types_sorted := []table.TypeSymbol
|
mut types_sorted := []table.TypeSymbol
|
||||||
for node in dep_graph_sorted.nodes {
|
for node in dep_graph_sorted.nodes {
|
||||||
for t in types {
|
types_sorted << g.table.types[g.table.type_idxs[node.name]]
|
||||||
if t.name == node.name {
|
|
||||||
types_sorted << t
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return types_sorted
|
return types_sorted
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue