Skip to content

Commit f4e3ad0

Browse files
committed
Accept crate name instead of attributes in build_output_filenames
1 parent 4627148 commit f4e3ad0

File tree

5 files changed

+10
-18
lines changed

5 files changed

+10
-18
lines changed

compiler/rustc_attr/src/builtin.rs

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -492,10 +492,6 @@ fn parse_unstability(sess: &Session, attr: &Attribute) -> Option<(Symbol, Stabil
492492
}
493493
}
494494

495-
pub fn find_crate_name(attrs: &[Attribute]) -> Option<Symbol> {
496-
attr::first_attr_value_str_by_name(attrs, sym::crate_name)
497-
}
498-
499495
#[derive(Clone, Debug)]
500496
pub struct Condition {
501497
pub name: Symbol,

compiler/rustc_driver_impl/src/lib.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -805,8 +805,8 @@ fn print_crate_info(
805805
// no crate attributes, print out an error and exit
806806
return Compilation::Continue;
807807
};
808-
let t_outputs = rustc_interface::util::build_output_filenames(attrs, sess);
809808
let id = rustc_session::output::find_crate_name(sess, attrs);
809+
let t_outputs = rustc_interface::util::build_output_filenames(sess, id.to_string());
810810
let crate_types = collect_crate_types(sess, attrs);
811811
for &style in &crate_types {
812812
let fname =

compiler/rustc_interface/src/interface.rs

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,10 @@ impl Compiler {
5959
sess: &Session,
6060
attrs: &[ast::Attribute],
6161
) -> OutputFilenames {
62-
util::build_output_filenames(attrs, sess)
62+
util::build_output_filenames(
63+
sess,
64+
rustc_session::output::find_crate_name(sess, attrs).to_string(),
65+
)
6366
}
6467
}
6568

compiler/rustc_interface/src/passes.rs

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -567,10 +567,9 @@ fn resolver_for_lowering<'tcx>(
567567
fn output_filenames(tcx: TyCtxt<'_>, (): ()) -> Arc<OutputFilenames> {
568568
let sess = tcx.sess;
569569
let _timer = sess.timer("prepare_outputs");
570-
let (_, krate) = &*tcx.resolver_for_lowering(()).borrow();
571570
let crate_name = tcx.crate_name(LOCAL_CRATE);
572571

573-
let outputs = util::build_output_filenames(&krate.attrs, sess);
572+
let outputs = util::build_output_filenames(sess, crate_name.to_string());
574573
let output_paths =
575574
generated_output_paths(tcx, &outputs, sess.io.output_file.is_some(), crate_name);
576575

compiler/rustc_interface/src/util.rs

Lines changed: 4 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -469,20 +469,14 @@ fn multiple_output_types_to_stdout(
469469
}
470470
}
471471

472-
pub fn build_output_filenames(attrs: &[ast::Attribute], sess: &Session) -> OutputFilenames {
472+
pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilenames {
473473
if multiple_output_types_to_stdout(
474474
&sess.opts.output_types,
475475
sess.io.output_file == Some(OutFileName::Stdout),
476476
) {
477477
sess.emit_fatal(errors::MultipleOutputTypesToStdout);
478478
}
479479

480-
let crate_name = sess
481-
.opts
482-
.crate_name
483-
.clone()
484-
.or_else(|| rustc_attr::find_crate_name(attrs).map(|n| n.to_string()));
485-
486480
match sess.io.output_file {
487481
None => {
488482
// "-" as input file will cause the parser to read from stdin so we
@@ -491,11 +485,11 @@ pub fn build_output_filenames(attrs: &[ast::Attribute], sess: &Session) -> Outpu
491485
let dirpath = sess.io.output_dir.clone().unwrap_or_default();
492486

493487
// If a crate name is present, we use it as the link name
494-
let stem = crate_name.clone().unwrap_or_else(|| sess.io.input.filestem().to_owned());
488+
let stem = crate_name.clone();
495489

496490
OutputFilenames::new(
497491
dirpath,
498-
crate_name.unwrap_or_else(|| stem.replace('-', "_")),
492+
crate_name,
499493
stem,
500494
None,
501495
sess.io.temps_dir.clone(),
@@ -524,7 +518,7 @@ pub fn build_output_filenames(attrs: &[ast::Attribute], sess: &Session) -> Outpu
524518
out_file.filestem().unwrap_or_default().to_str().unwrap().to_string();
525519
OutputFilenames::new(
526520
out_file.parent().unwrap_or_else(|| Path::new("")).to_path_buf(),
527-
crate_name.unwrap_or_else(|| out_filestem.replace('-', "_")),
521+
crate_name,
528522
out_filestem,
529523
ofile,
530524
sess.io.temps_dir.clone(),

0 commit comments

Comments
 (0)