mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-16 17:03:35 +00:00
Auto merge of #32579 - michaelwoerister:stable-symbol-name-fix, r=eddyb
Fix typo in TxCtxt::crate_disambiguator() and add test case. r? @nikomatsakis Fixes #32554
This commit is contained in:
commit
a09f386e8d
@ -434,7 +434,7 @@ impl<'tcx> TyCtxt<'tcx> {
|
||||
if cnum == LOCAL_CRATE {
|
||||
self.sess.crate_disambiguator.get().as_str()
|
||||
} else {
|
||||
self.sess.cstore.crate_name(cnum)
|
||||
self.sess.cstore.crate_disambiguator(cnum)
|
||||
}
|
||||
}
|
||||
|
||||
|
18
src/test/run-make/stable-symbol-names/Makefile
Normal file
18
src/test/run-make/stable-symbol-names/Makefile
Normal file
@ -0,0 +1,18 @@
|
||||
-include ../tools.mk
|
||||
|
||||
# This test case makes sure that monomorphizations of the same function with the
|
||||
# same set of generic arguments will have the same symbol names when
|
||||
# instantiated in different crates.
|
||||
|
||||
dump-symbols = nm "$(TMPDIR)/lib$(1).rlib" \
|
||||
| grep "some_test_function" \
|
||||
| sed "s/^[0-9a-f]\{8,16\}/00000000/" \
|
||||
| sort \
|
||||
> "$(TMPDIR)/$(1).nm"
|
||||
|
||||
all:
|
||||
$(RUSTC) stable-symbol-names1.rs
|
||||
$(RUSTC) stable-symbol-names2.rs
|
||||
$(call dump-symbols,stable_symbol_names1)
|
||||
$(call dump-symbols,stable_symbol_names2)
|
||||
cmp "$(TMPDIR)/stable_symbol_names1.nm" "$(TMPDIR)/stable_symbol_names2.nm"
|
@ -0,0 +1,22 @@
|
||||
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||
// file at the top-level directory of this distribution and at
|
||||
// http://rust-lang.org/COPYRIGHT.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
#![crate_type="rlib"]
|
||||
|
||||
pub fn some_test_function<T>(t: T) -> T {
|
||||
t
|
||||
}
|
||||
|
||||
pub fn user() {
|
||||
some_test_function(0u32);
|
||||
some_test_function("abc");
|
||||
let x = 2u64;
|
||||
some_test_function(&x);
|
||||
}
|
@ -0,0 +1,20 @@
|
||||
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||
// file at the top-level directory of this distribution and at
|
||||
// http://rust-lang.org/COPYRIGHT.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
#![crate_type="rlib"]
|
||||
|
||||
extern crate stable_symbol_names1;
|
||||
|
||||
pub fn user() {
|
||||
stable_symbol_names1::some_test_function(1u32);
|
||||
stable_symbol_names1::some_test_function("def");
|
||||
let x = 2u64;
|
||||
stable_symbol_names1::some_test_function(&x);
|
||||
}
|
Loading…
Reference in New Issue
Block a user