fmt, ast: fix usage of import aliases (#10151)

pull/10166/head
Lukas Neubert 2021-05-21 19:33:04 +02:00 committed by GitHub
parent 9be596ef12
commit 788520eb52
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 38 additions and 10 deletions

View File

@ -909,7 +909,7 @@ pub fn (t &Table) type_to_str_using_aliases(typ Type, import_aliases map[string]
} else { } else {
if res.starts_with('fn (') { if res.starts_with('fn (') {
// fn foo () // fn foo ()
res = t.fn_signature(info.func, type_only: true) res = t.fn_signature_using_aliases(info.func, import_aliases, type_only: true)
} else { } else {
// FnFoo // FnFoo
res = t.shorten_user_defined_typenames(res, import_aliases) res = t.shorten_user_defined_typenames(res, import_aliases)
@ -1001,9 +1001,14 @@ fn (t Table) shorten_user_defined_typenames(originalname string, import_aliases
mut parts := res.split('.') mut parts := res.split('.')
if parts.len > 1 { if parts.len > 1 {
ind := parts.len - 2 ind := parts.len - 2
if t.is_fmt {
// Rejoin the module parts for correct usage of aliases
parts[ind] = parts[..ind + 1].join('.')
}
if parts[ind] in import_aliases { if parts[ind] in import_aliases {
parts[ind] = import_aliases[parts[ind]] parts[ind] = import_aliases[parts[ind]]
} }
res = parts[ind..].join('.') res = parts[ind..].join('.')
} else { } else {
res = parts[0] res = parts[0]
@ -1018,6 +1023,10 @@ pub struct FnSignatureOpts {
} }
pub fn (t &Table) fn_signature(func &Fn, opts FnSignatureOpts) string { pub fn (t &Table) fn_signature(func &Fn, opts FnSignatureOpts) string {
return t.fn_signature_using_aliases(func, map[string]string{}, opts)
}
pub fn (t &Table) fn_signature_using_aliases(func &Fn, import_aliases map[string]string, opts FnSignatureOpts) string {
mut sb := strings.new_builder(20) mut sb := strings.new_builder(20)
if !opts.skip_receiver { if !opts.skip_receiver {
sb.write_string('fn ') sb.write_string('fn ')
@ -1041,7 +1050,7 @@ pub fn (t &Table) fn_signature(func &Fn, opts FnSignatureOpts) string {
if !opts.type_only { if !opts.type_only {
sb.write_string('$param.name ') sb.write_string('$param.name ')
} }
styp := t.type_to_str(typ) styp := t.type_to_str_using_aliases(typ, import_aliases)
if i == func.params.len - 1 && func.is_variadic { if i == func.params.len - 1 && func.is_variadic {
sb.write_string('...$styp') sb.write_string('...$styp')
} else { } else {
@ -1050,7 +1059,7 @@ pub fn (t &Table) fn_signature(func &Fn, opts FnSignatureOpts) string {
} }
sb.write_string(')') sb.write_string(')')
if func.return_type != ast.void_type { if func.return_type != ast.void_type {
sb.write_string(' ${t.type_to_str(func.return_type)}') sb.write_string(' ${t.type_to_str_using_aliases(func.return_type, import_aliases)}')
} }
return sb.str() return sb.str()
} }

View File

@ -75,11 +75,10 @@ pub fn fmt(file ast.File, table &ast.Table, pref &pref.Preferences, is_debug boo
pub fn (mut f Fmt) process_file_imports(file &ast.File) { pub fn (mut f Fmt) process_file_imports(file &ast.File) {
for imp in file.imports { for imp in file.imports {
mod := imp.mod.all_after_last('.') f.mod2alias[imp.mod] = imp.alias
f.mod2alias[mod] = imp.alias
for sym in imp.syms { for sym in imp.syms {
f.mod2alias['${imp.mod}.$sym.name'] = sym.name f.mod2alias['${imp.mod}.$sym.name'] = sym.name
f.mod2alias['${mod}.$sym.name'] = sym.name f.mod2alias['${imp.mod.all_after_last('.')}.$sym.name'] = sym.name
f.mod2alias[sym.name] = sym.name f.mod2alias[sym.name] = sym.name
f.import_syms_used[sym.name] = false f.import_syms_used[sym.name] = false
} }
@ -211,7 +210,8 @@ pub fn (mut f Fmt) short_module(name string) string {
if vals.len < 2 { if vals.len < 2 {
return name return name
} }
mname, tprefix := f.get_modname_prefix(vals[vals.len - 2]) idx := vals.len - 1
mname, tprefix := f.get_modname_prefix(vals[..idx].join('.'))
symname := vals[vals.len - 1] symname := vals[vals.len - 1]
aname := f.mod2alias[mname] aname := f.mod2alias[mname]
if aname == '' { if aname == '' {
@ -2194,7 +2194,8 @@ pub fn (mut f Fmt) match_expr(node ast.MatchExpr) {
} }
pub fn (mut f Fmt) offset_of(node ast.OffsetOf) { pub fn (mut f Fmt) offset_of(node ast.OffsetOf) {
f.write('__offsetof(${f.table.type_to_str(node.struct_type)}, $node.field)') f.write('__offsetof(${f.table.type_to_str_using_aliases(node.struct_type, f.mod2alias)}, $node.field)')
f.mark_types_import_as_used(node.struct_type)
} }
pub fn (mut f Fmt) or_expr(node ast.OrExpr) { pub fn (mut f Fmt) or_expr(node ast.OrExpr) {
@ -2427,7 +2428,7 @@ pub fn (mut f Fmt) string_inter_literal(node ast.StringInterLiteral) {
} }
pub fn (mut f Fmt) type_expr(node ast.TypeNode) { pub fn (mut f Fmt) type_expr(node ast.TypeNode) {
f.write(f.table.type_to_str(node.typ)) f.write(f.table.type_to_str_using_aliases(node.typ, f.mod2alias))
} }
pub fn (mut f Fmt) type_of(node ast.TypeOf) { pub fn (mut f Fmt) type_of(node ast.TypeOf) {

View File

@ -59,4 +59,3 @@ fn main() {
println(file_ext('main.v')) println(file_ext('main.v'))
println(imaginary(1)) println(imaginary(1))
} }

View File

@ -0,0 +1,5 @@
import math.complex { Complex }
fn main() {
assert *(&f64(&byte(&num) + __offsetof(Complex, re))) == 1.0
}

View File

@ -1,6 +1,8 @@
import os import os
import time as t import time as t
import some.library as slib import some.library as slib
import crypto.sha256
import mymod.sha256 as mysha256
type my_alias = fn (t slib.MyType) type my_alias = fn (t slib.MyType)
@ -18,4 +20,6 @@ fn main() {
t.sleep_ms(500) t.sleep_ms(500)
println('end') println('end')
os.system('date') os.system('date')
v_hash := sha256.sum('hi'.bytes()).hex()
my_hash := mysha256.sum('hi'.bytes()).hex()
} }

View File

@ -1,6 +1,7 @@
import time import time
import semver as sv import semver as sv
import term.ui as tui import term.ui as tui
import v.ast
interface Inter { interface Inter {
code tui.KeyCode code tui.KeyCode
@ -24,3 +25,12 @@ fn bar_multi_return(b sv.Version) (sv.Version, int) {
b2 := sv.Version{} b2 := sv.Version{}
return b, 0 return b, 0
} }
struct SomeStruct {
a fn (ast.Stmt, voidptr) bool
}
fn main() {
if x is ast.FnDecl {
}
}