Skip to content

ICE: const_generics: unexpected const parent in type_of_def_id() #73683

Closed
@Boscop

Description

@Boscop

Code

#[ext(pub, name = CollectArr)] // https://crates.io/crates/extend
impl<T: Iterator> T {
	fn collect_arr<const N: usize>(self) -> [T::Item; N]
	where
		[T::Item; N]: Array<Item = T::Item>,
		ArrayVec<[T::Item; N]>: Debug,
	{
		self.collect::<ArrayVec<[T::Item; N]>>().into_inner().expect("collect_arr")
	}
}

pub struct ChannelUsage(pub u16);

impl ChannelUsage {
	fn to_arr(&self) -> [bool; 16] {
		// self.iter().collect_arr() // works
		// self.iter().collect_arr::<16>() // error: cannot infer type for type `{integer}`
		self.iter().collect_arr::<16usize>() // ICE
	}
}

Meta

rustc --version --verbose:

rustc 1.46.0-nightly (ff5b446d2 2020-06-23)
binary: rustc
commit-hash: ff5b446d2fdbd898bc97a751f2f72858de185cf1
commit-date: 2020-06-23
host: x86_64-pc-windows-msvc
release: 1.46.0-nightly
LLVM version: 10.0

Error output

error: proj\src\lib.rs:1: unexpected const parent in type_of_def_id(): Expr(Expr { hir_id: HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 10 }, kind: MethodCall(PathSegment { ident: collect_arr#0, hir_id: Some(HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 5 }), res: Some(Err), args: Some(GenericArgs { args: [Const(ConstArg { value: AnonConst { hir_id: HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 3 }, body: BodyId { hir_id: HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 4 } } }, span: proj\src\chan_usage.rs:146:29: 146:36 (#0) })], bindings: [], parenthesized: false }), infer_args: false }, proj\src\chan_usage.rs:146:15: 146:26 (#0), [Expr { hir_id: HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 9 }, kind: MethodCall(PathSegment { ident: iter#0, hir_id: Some(HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 6 }), res: Some(Err), args: None, infer_args: true }, proj\src\chan_usage.rs:146:8: 146:12 (#0), [Expr { hir_id: HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 8 }, kind: Path(Resolved(None, Path { span: proj\src\chan_usage.rs:146:3: 146:7 (#0), res: Local(HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 1 }), segments: [PathSegment { ident: self#0, hir_id: Some(HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 7 }), res: Some(Local(HirId { owner: DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]), local_id: 1 })), args: None, infer_args: true }] })), attrs: ThinVec(None), span: proj\src\chan_usage.rs:146:3: 146:7 (#0) }], proj\src\chan_usage.rs:146:8: 146:14 (#0)), attrs: ThinVec(None), span: proj\src\chan_usage.rs:146:3: 146:14 (#0) }], proj\src\chan_usage.rs:146:15: 146:39 (#0)), attrs: ThinVec(None), span: proj\src\chan_usage.rs:146:3: 146:39 (#0) })
note: proj\src\lib.rs:1: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:146: Const::from_anon_const: couldn't lit_to_const
note: proj\src\chan_usage.rs:146: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\lib.rs:1: TyKind::Error constructed but no error reported
note: proj\src\lib.rs:1: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\lib.rs:1: ty::ConstKind::Error constructed but no error reported.
note: proj\src\lib.rs:1: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:146: `ErrorReported` without an error
note: proj\src\chan_usage.rs:146: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:145: cat_expr Errd
note: proj\src\chan_usage.rs:145: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:146: cat_expr Errd
note: proj\src\chan_usage.rs:146: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:145: PromoteTemps: MIR had errors
note: proj\src\chan_usage.rs:145: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:145: broken MIR in DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]) ("return type"): bad type [type error]
note: proj\src\chan_usage.rs:145: delayed at src\librustc_mir\borrow_check\type_check\mod.rs:258:27
error: proj\src\chan_usage.rs:145: broken MIR in DefId(0:27 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]) (LocalDecl { mutability: Mut, local_info: None, internal: false, is_block_tail: None, ty: [type error], user_ty: None, source_info: SourceInfo { span: proj\src\chan_usage.rs:145:2: 148:3 (#0), scope: scope[0] } }): bad type [type error]
note: proj\src\chan_usage.rs:145: delayed at src\librustc_mir\borrow_check\type_check\mod.rs:258:27
error: proj\src\chan_usage.rs:146: mir_const_qualif: MIR had errors
note: proj\src\chan_usage.rs:146: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:146: PromoteTemps: MIR had errors
note: proj\src\chan_usage.rs:146: delayed at /rustc/ff5b446d2fdbd898bc97a751f2f72858de185cf1\src\librustc_session\session.rs:436:27
error: proj\src\chan_usage.rs:146: broken MIR in DefId(0:29 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]::{{constant}}[1]) ("return type"): bad type [type error]
note: proj\src\chan_usage.rs:146: delayed at src\librustc_mir\borrow_check\type_check\mod.rs:258:27
error: proj\src\chan_usage.rs:146: broken MIR in DefId(0:29 ~ vmidi[fa26]::chan_usage[0]::{{impl}}[1]::to_arr[0]::{{constant}}[1]) (LocalDecl { mutability: Mut, local_info: None, internal: false, is_block_tail: None, ty: [type error], user_ty: None, source_info: SourceInfo { span: proj\src\chan_usage.rs:146:29: 146:36 (#0), scope: scope[0] } }): bad type [type error]
note: proj\src\chan_usage.rs:146: delayed at src\librustc_mir\borrow_check\type_check\mod.rs:258:27
thread 'rustc' panicked at 'no errors encountered even though `delay_span_bug` issued', src\librustc_errors\lib.rs:367:17
stack backtrace:
   0: <std::sys_common::backtrace::_print::DisplayBacktrace as core::fmt::Display>::fmt
   1: core::fmt::write
   2: <std::io::IoSliceMut as core::fmt::Debug>::fmt
   3: std::panicking::take_hook
   4: std::panicking::take_hook
   5: rustc_driver::report_ice
   6: std::panicking::rust_panic_with_hook
   7: <rustc_errors::styled_buffer::StyledBuffer as core::fmt::Debug>::fmt
   8: <rustc_errors::HandlerInner as core::ops::drop::Drop>::drop
   9: <rustc_ast::ast::Item<rustc_ast::ast::ForeignItemKind> as rustc_ast::attr::HasAttrs>::attrs
  10: <rustc_ast::ast::Item<rustc_ast::ast::ForeignItemKind> as rustc_ast::attr::HasAttrs>::attrs
  11: <rustc_ast_passes::node_count::NodeCounter as rustc_ast::visit::Visitor>::visit_ident
  12: <rustc_metadata::foreign_modules::Collector as rustc_hir::itemlikevisit::ItemLikeVisitor>::visit_impl_item
  13: <rustc_driver::DEFAULT_HOOK as core::ops::deref::Deref>::deref
  14: <rustc_span::symbol::SymbolStr as core::fmt::Display>::fmt
  15: <i16 as petgraph::matrix_graph::Zero>::zero
  16: std::sys::windows::thread::Thread::new
  17: BaseThreadInitThunk
  18: RtlUserThreadStart
note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.

error: internal compiler error: unexpected panic

note: the compiler unexpectedly panicked. this is a bug.

note: we would appreciate a bug report: https://github.com/rust-lang/rust/blob/master/CONTRIBUTING.md#bug-reports

note: rustc 1.46.0-nightly (ff5b446d2 2020-06-23) running on x86_64-pc-windows-msvc

note: compiler flags: -C opt-level=3 -C panic=abort -C embed-bitcode=no -C debuginfo=2 -C debug-assertions=on -C incremental --crate-type lib

note: some of the compiler flags provided by cargo are hidden

query stack during panic:
end of query stack

Metadata

Metadata

Assignees

No one assigned

    Labels

    A-const-genericsArea: const generics (parameters and arguments)C-bugCategory: This is a bug.F-const_generics`#![feature(const_generics)]`I-ICEIssue: The compiler panicked, giving an Internal Compilation Error (ICE) ❄️T-compilerRelevant to the compiler team, which will review and decide on the PR/issue.requires-nightlyThis issue requires a nightly compiler in some way.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions