Mostly revert "Accept crate name instead of attributes in build_output_filenames"
This commit is contained in:
parent
7ede8e2a59
commit
365a580bc4
4 changed files with 16 additions and 6 deletions
|
@ -492,6 +492,10 @@ fn parse_unstability(sess: &Session, attr: &Attribute) -> Option<(Symbol, Stabil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn find_crate_name(attrs: &[Attribute]) -> Option<Symbol> {
|
||||||
|
attr::first_attr_value_str_by_name(attrs, sym::crate_name)
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct Condition {
|
pub struct Condition {
|
||||||
pub name: Symbol,
|
pub name: Symbol,
|
||||||
|
|
|
@ -764,8 +764,8 @@ fn print_crate_info(
|
||||||
// no crate attributes, print out an error and exit
|
// no crate attributes, print out an error and exit
|
||||||
return Compilation::Continue;
|
return Compilation::Continue;
|
||||||
};
|
};
|
||||||
|
let t_outputs = rustc_interface::util::build_output_filenames(attrs, sess);
|
||||||
let id = rustc_session::output::find_crate_name(sess, attrs);
|
let id = rustc_session::output::find_crate_name(sess, attrs);
|
||||||
let t_outputs = rustc_interface::util::build_output_filenames(sess, id.to_string());
|
|
||||||
let crate_types = collect_crate_types(sess, attrs);
|
let crate_types = collect_crate_types(sess, attrs);
|
||||||
for &style in &crate_types {
|
for &style in &crate_types {
|
||||||
let fname =
|
let fname =
|
||||||
|
|
|
@ -135,7 +135,7 @@ impl<'tcx> Queries<'tcx> {
|
||||||
sess.opts.cg.metadata.clone(),
|
sess.opts.cg.metadata.clone(),
|
||||||
sess.cfg_version,
|
sess.cfg_version,
|
||||||
);
|
);
|
||||||
let outputs = util::build_output_filenames(sess, crate_name.to_string());
|
let outputs = util::build_output_filenames(&pre_configured_attrs, sess);
|
||||||
let dep_graph = setup_dep_graph(sess, crate_name, stable_crate_id)?;
|
let dep_graph = setup_dep_graph(sess, crate_name, stable_crate_id)?;
|
||||||
|
|
||||||
let cstore = FreezeLock::new(Box::new(CStore::new(
|
let cstore = FreezeLock::new(Box::new(CStore::new(
|
||||||
|
|
|
@ -471,7 +471,7 @@ fn multiple_output_types_to_stdout(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilenames {
|
pub fn build_output_filenames(attrs: &[ast::Attribute], sess: &Session) -> OutputFilenames {
|
||||||
if multiple_output_types_to_stdout(
|
if multiple_output_types_to_stdout(
|
||||||
&sess.opts.output_types,
|
&sess.opts.output_types,
|
||||||
sess.io.output_file == Some(OutFileName::Stdout),
|
sess.io.output_file == Some(OutFileName::Stdout),
|
||||||
|
@ -479,6 +479,12 @@ pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilen
|
||||||
sess.emit_fatal(errors::MultipleOutputTypesToStdout);
|
sess.emit_fatal(errors::MultipleOutputTypesToStdout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let crate_name = sess
|
||||||
|
.opts
|
||||||
|
.crate_name
|
||||||
|
.clone()
|
||||||
|
.or_else(|| rustc_attr::find_crate_name(attrs).map(|n| n.to_string()));
|
||||||
|
|
||||||
match sess.io.output_file {
|
match sess.io.output_file {
|
||||||
None => {
|
None => {
|
||||||
// "-" as input file will cause the parser to read from stdin so we
|
// "-" 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
|
||||||
let dirpath = sess.io.output_dir.clone().unwrap_or_default();
|
let dirpath = sess.io.output_dir.clone().unwrap_or_default();
|
||||||
|
|
||||||
// If a crate name is present, we use it as the link name
|
// If a crate name is present, we use it as the link name
|
||||||
let stem = crate_name.clone();
|
let stem = crate_name.clone().unwrap_or_else(|| sess.io.input.filestem().to_owned());
|
||||||
|
|
||||||
OutputFilenames::new(
|
OutputFilenames::new(
|
||||||
dirpath,
|
dirpath,
|
||||||
crate_name,
|
crate_name.unwrap_or_else(|| stem.replace('-', "_")),
|
||||||
stem,
|
stem,
|
||||||
None,
|
None,
|
||||||
sess.io.temps_dir.clone(),
|
sess.io.temps_dir.clone(),
|
||||||
|
@ -520,7 +526,7 @@ pub fn build_output_filenames(sess: &Session, crate_name: String) -> OutputFilen
|
||||||
out_file.filestem().unwrap_or_default().to_str().unwrap().to_string();
|
out_file.filestem().unwrap_or_default().to_str().unwrap().to_string();
|
||||||
OutputFilenames::new(
|
OutputFilenames::new(
|
||||||
out_file.parent().unwrap_or_else(|| Path::new("")).to_path_buf(),
|
out_file.parent().unwrap_or_else(|| Path::new("")).to_path_buf(),
|
||||||
crate_name,
|
crate_name.unwrap_or_else(|| out_filestem.replace('-', "_")),
|
||||||
out_filestem,
|
out_filestem,
|
||||||
ofile,
|
ofile,
|
||||||
sess.io.temps_dir.clone(),
|
sess.io.temps_dir.clone(),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue