Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

"Foo is ambiguous" only when deriving Debug #62769

Open
oberien opened this issue Jul 17, 2019 · 4 comments
Open

"Foo is ambiguous" only when deriving Debug #62769

oberien opened this issue Jul 17, 2019 · 4 comments
Labels
A-resolve Area: Name/path resolution done by `rustc_resolve` specifically C-bug Category: This is a bug. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.

Comments

@oberien
Copy link
Contributor

oberien commented Jul 17, 2019

playpen

This may be related to #62768.

Given this code:

pub use Foo::*;
#[derive(Debug)]
pub enum Foo {
    Foo(i32),
}

The compiler errors, saying that the Foo in use Foo::* may refer both to the enum (type-namespace) Foo and the yet-to-be-imported variant (value-namespace) Foo::Foo:

error[E0659]: `Foo` is ambiguous (glob import vs macro-expanded name in the same module during import/macro resolution)
 --> src/lib.rs:1:9
  |
1 | pub use Foo::*;
  |         ^^^ ambiguous name
  |
note: `Foo` could refer to the enum defined here
 --> src/lib.rs:3:1
  |
3 | / pub enum Foo {
4 | |     Foo(i32),
5 | | }
  | |_^
note: `Foo` could also refer to the variant imported here
 --> src/lib.rs:1:9
  |
1 | pub use Foo::*;
  |         ^^^^^^
  = help: consider adding an explicit import of `Foo` to disambiguate

However, if I remove the #[derive(Debug)], then the code compiles just fine as expected (playpen).

@oberien
Copy link
Contributor Author

oberien commented Jul 17, 2019

When I expand the code using --pretty=expanded and just copy-paste the expanded code, which doesn't contain the #[derive(Debug)] anymore, the code compiles just fine (playpen).

@jonas-schievink jonas-schievink added A-resolve Area: Name/path resolution done by `rustc_resolve` specifically C-bug Category: This is a bug. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Jul 17, 2019
@estebank
Copy link
Contributor

cc @petrochenkov

@petrochenkov
Copy link
Contributor

First, variants exist in type namespace (and their constructors exist in value namespace).
Second, macro-expanded names have some extra restriction to avoid paradoxes, so --pretty=expanded code compiling doesn't necessarily mean the non-expanded compiling successfully as well (see the error message, it says something about macro-expanded names specifically).

Beside that, it's rather a conservative error than an outright bug.
Yeah, we should ideally do some causal tracking for globs use foo::something::* /*foo*/; and know that the suffix foo "does not exist" during resolution of the prefix foo, but we do not do it right now.

(We actually do it for single imports though, otherwise use my_crate; would cause an infinite loop.
This is done by blacklisting the "output" my_crate when resolving the "input" my_crate, but should probably be done through introducing a single "inference variable" for both, which would work for globs as well.)

@steveklabnik
Copy link
Member

steveklabnik commented Jul 20, 2020

Triage: this error is a bit more descriptive today:

error[E0659]: `Foo` is ambiguous (glob import vs macro-expanded name in the same module during import/macro resolution)
 --> src/lib.rs:1:9
  |
1 | pub use Foo::*;
  |         ^^^ ambiguous name
  |
note: `Foo` could refer to the enum defined here
 --> src/lib.rs:3:1
  |
3 | / pub enum Foo {
4 | |     Foo(i32),
5 | | }
  | |_^
note: `Foo` could also refer to the variant imported here
 --> src/lib.rs:1:9
  |
1 | pub use Foo::*;
  |         ^^^^^^
  = help: consider adding an explicit import of `Foo` to disambiguate

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-resolve Area: Name/path resolution done by `rustc_resolve` specifically C-bug Category: This is a bug. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.
Projects
None yet
Development

No branches or pull requests

5 participants