Skip to content

Commit

Permalink
Rollup merge of #77452 - Mark-Simulacrum:fix-symbol-v0, r=eddyb
Browse files Browse the repository at this point in the history
Permit ty::Bool in const generics for v0 mangling

This should unbreak using new-symbol-mangling = true in config.toml (once it lands in beta anyway).

Fixes #76365 (well, it will, but seems fine to close as soon as we have support)

r? @eddyb (for mangling) but I'm okay with some other reviewer too :)
  • Loading branch information
jonas-schievink authored Oct 2, 2020
2 parents 23408de + 89fdfe6 commit eff6398
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 0 deletions.
1 change: 1 addition & 0 deletions compiler/rustc_symbol_mangling/src/v0.rs
Original file line number Diff line number Diff line change
Expand Up @@ -504,6 +504,7 @@ impl Printer<'tcx> for SymbolMangler<'tcx> {

match ct.ty.kind() {
ty::Uint(_) => {}
ty::Bool => {}
_ => {
bug!("symbol_names: unsupported constant of type `{}` ({:?})", ct.ty, ct);
}
Expand Down
18 changes: 18 additions & 0 deletions src/test/ui/symbol-names/issue-76365.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// check-pass
// revisions: legacy v0
//[legacy]compile-flags: -Z symbol-mangling-version=legacy --crate-type=lib
//[v0]compile-flags: -Z symbol-mangling-version=v0 --crate-type=lib

#![feature(min_const_generics)]

pub struct Bar<const F: bool>;

impl Bar<true> {
pub fn foo() {}
}

impl<const F: bool> Bar<F> {
pub fn bar() {}
}

fn main() {}

0 comments on commit eff6398

Please sign in to comment.