generated from cloudwego/.github
-
Notifications
You must be signed in to change notification settings - Fork 38
Open
Description
处理同名方法和 trait 方法
考虑 rust 的例子:
struct Foo;
impl Foo { fn say(&self) { println!("foo.say") } }
trait Bar { fn say(&self); }
impl Bar for Foo { fn say(&self) { println!("Bar<Foo>.say") } }
fn g<T: Bar>(x: &T) { x.say(); }Foo 的 say 方法应该有哪个?
按理说应该是 Foo.say,不是 Bar.say。
但是当前实现里,后者名为 say 也归属于 Foo,所以导致了重名函数的问题。
并且因为 uniast.Type.Methods[name] 只有一个函数,所以会导致 parser 输出不稳定。
要解决这个问题,有两个方法1
- 让 Bar.say 也归属于 Foo,把 uniast.Type.Methods 变成 name -> list[Identity]
- 让它单独归属于一个 trait object(标准 Rust 方法),需要在 collect 阶段处理 symbol kind Object。
同样,考虑到 C++ 有 OOP,类似问题存在,比如 Child.foo 重载 Parent.foo。
但是解决很简单,用亲类和后代类来区分就好。
(当然,如果有 C++ concept 了的话,需要更好的设计,但先不考虑)
Metadata
Metadata
Assignees
Labels
No labels