Skip to content

Commit e78c5d3

Browse files
committed
Mostly revert "Accept crate name instead of attributes in build_output_filenames"
1 parent c42e092 commit e78c5d3

File tree

4 files changed

+16
-6
lines changed

4 files changed

+16
-6
lines changed

Diff for: compiler/rustc_attr/src/builtin.rs

+4
Original file line numberDiff line numberDiff line change
@@ -492,6 +492,10 @@ 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+
495499
#[derive(Clone, Debug)]
496500
pub struct Condition {
497501
pub name: Symbol,

Diff for: compiler/rustc_driver_impl/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -766,8 +766,8 @@ fn print_crate_info(
766766
// no crate attributes, print out an error and exit
767767
return Compilation::Continue;
768768
};
769+
let t_outputs = rustc_interface::util::build_output_filenames(attrs, sess);
769770
let id = rustc_session::output::find_crate_name(sess, attrs);
770-
let t_outputs = rustc_interface::util::build_output_filenames(sess, id.to_string());
771771
let crate_types = collect_crate_types(sess, attrs);
772772
for &style in &crate_types {
773773
let fname =

Diff for: compiler/rustc_interface/src/queries.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -130,7 +130,7 @@ impl<'tcx> Queries<'tcx> {
130130
sess.opts.cg.metadata.clone(),
131131
sess.cfg_version,
132132
);
133-
let outputs = util::build_output_filenames(sess, crate_name.to_string());
133+
let outputs = util::build_output_filenames(&pre_configured_attrs, sess);
134134
let dep_graph = setup_dep_graph(sess, crate_name, stable_crate_id)?;
135135

136136
let cstore = FreezeLock::new(Box::new(CStore::new(

Diff for: compiler/rustc_interface/src/util.rs

+10-4
Original file line numberDiff line numberDiff line change
@@ -471,14 +471,20 @@ fn multiple_output_types_to_stdout(
471471
}
472472
}
473473

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

482+
let crate_name = sess
483+
.opts
484+
.crate_name
485+
.clone()
486+
.or_else(|| rustc_attr::find_crate_name(attrs).map(|n| n.to_string()));
487+
482488
match sess.io.output_file {
483489
None => {
484490
// "-" as input file will cause the parser to read from stdin so we
@@ -487,11 +493,11 @@ pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilen
487493
let dirpath = sess.io.output_dir.clone().unwrap_or_default();
488494

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

492498
OutputFilenames::new(
493499
dirpath,
494-
crate_name,
500+
crate_name.unwrap_or_else(|| stem.replace('-', "_")),
495501
stem,
496502
None,
497503
sess.io.temps_dir.clone(),
@@ -520,7 +526,7 @@ pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilen
520526
out_file.filestem().unwrap_or_default().to_str().unwrap().to_string();
521527
OutputFilenames::new(
522528
out_file.parent().unwrap_or_else(|| Path::new("")).to_path_buf(),
523-
crate_name,
529+
crate_name.unwrap_or_else(|| out_filestem.replace('-', "_")),
524530
out_filestem,
525531
ofile,
526532
sess.io.temps_dir.clone(),

0 commit comments

Comments
 (0)