about summary refs log tree commit diff
diff options
context:
space:
mode:
authorMark Rousskov <mark.simulacrum@gmail.com>2019-07-24 11:00:09 -0400
committerMark Rousskov <mark.simulacrum@gmail.com>2019-07-24 11:00:09 -0400
commitd749b5e2237abdb79494afc9c8d7c8280db9088c (patch)
treeec914bd100359037adfbd390947fcbf3add766b8
parenteafb42dc94b191fdd9f38b548f624184101182a2 (diff)
downloadrust-d749b5e2237abdb79494afc9c8d7c8280db9088c.tar.gz
rust-d749b5e2237abdb79494afc9c8d7c8280db9088c.zip
Gate binary dependency information behind -Zbinary-dep-depinfo
-rw-r--r--src/librustc/session/config.rs2
-rw-r--r--src/librustc/session/mod.rs3
-rw-r--r--src/librustc_interface/passes.rs24
3 files changed, 18 insertions, 11 deletions
diff --git a/src/librustc/session/config.rs b/src/librustc/session/config.rs
index 470a08fad23..9a8429733d1 100644
--- a/src/librustc/session/config.rs
+++ b/src/librustc/session/config.rs
@@ -1468,6 +1468,8 @@ options! {DebuggingOptions, DebuggingSetter, basic_debugging_options,
     symbol_mangling_version: SymbolManglingVersion = (SymbolManglingVersion::Legacy,
         parse_symbol_mangling_version, [TRACKED],
         "which mangling version to use for symbol names"),
+    binary_dep_depinfo: bool = (false, parse_bool, [TRACKED],
+        "include artifacts (sysroot, crate dependencies) used during compilation in dep-info"),
 }
 
 pub fn default_lib_output() -> CrateType {
diff --git a/src/librustc/session/mod.rs b/src/librustc/session/mod.rs
index 664926a152f..c88ca132184 100644
--- a/src/librustc/session/mod.rs
+++ b/src/librustc/session/mod.rs
@@ -545,6 +545,9 @@ impl Session {
     pub fn print_llvm_passes(&self) -> bool {
         self.opts.debugging_opts.print_llvm_passes
     }
+    pub fn binary_dep_depinfo(&self) -> bool {
+        self.opts.debugging_opts.binary_dep_depinfo
+    }
 
     /// Gets the features enabled for the current compilation session.
     /// DO NOT USE THIS METHOD if there is a TyCtxt available, as it circumvents
diff --git a/src/librustc_interface/passes.rs b/src/librustc_interface/passes.rs
index 469215563ac..772395bca2b 100644
--- a/src/librustc_interface/passes.rs
+++ b/src/librustc_interface/passes.rs
@@ -677,17 +677,19 @@ fn write_out_deps(compiler: &Compiler, outputs: &OutputFilenames, out_filenames:
             .map(|fmap| escape_dep_filename(&fmap.name))
             .collect();
 
-        for cnum in compiler.cstore.crates_untracked() {
-            let metadata = compiler.cstore.crate_data_as_rc_any(cnum);
-            let metadata = metadata.downcast_ref::<cstore::CrateMetadata>().unwrap();
-            if let Some((path, _)) = &metadata.source.dylib {
-                files.push(escape_dep_filename(&FileName::Real(path.clone())));
-            }
-            if let Some((path, _)) = &metadata.source.rlib {
-                files.push(escape_dep_filename(&FileName::Real(path.clone())));
-            }
-            if let Some((path, _)) = &metadata.source.rmeta {
-                files.push(escape_dep_filename(&FileName::Real(path.clone())));
+        if sess.binary_dep_depinfo() {
+            for cnum in compiler.cstore.crates_untracked() {
+                let metadata = compiler.cstore.crate_data_as_rc_any(cnum);
+                let metadata = metadata.downcast_ref::<cstore::CrateMetadata>().unwrap();
+                if let Some((path, _)) = &metadata.source.dylib {
+                    files.push(escape_dep_filename(&FileName::Real(path.clone())));
+                }
+                if let Some((path, _)) = &metadata.source.rlib {
+                    files.push(escape_dep_filename(&FileName::Real(path.clone())));
+                }
+                if let Some((path, _)) = &metadata.source.rmeta {
+                    files.push(escape_dep_filename(&FileName::Real(path.clone())));
+                }
             }
         }