use rustc_hir::def_id::{CrateNum, LOCAL_CRATE};
use rustc_index::IndexVec;
use rustc_middle::bug;
-@@ -159,46 +159,19 @@ fn calculate_type(tcx: TyCtxt<'_>, ty: CrateType) -> DependencyList {
- }
+@@ -161,45 +161,19 @@ fn calculate_type(tcx: TyCtxt<'_>, ty: CrateType) -> DependencyList {
Linkage::Dynamic | Linkage::IncludedFromDylib => {}
}
--
+
- let all_dylibs = || {
- tcx.crates(()).iter().filter(|&&cnum| {
-- !tcx.dep_kind(cnum).macros_only()
+- !tcx.crate_dep_kind(cnum).macros_only()
- && (tcx.used_crate_source(cnum).dylib.is_some()
- || tcx.used_crate_source(cnum).sdylib_interface.is_some())
- })
info!("adding dylib: {}", name);
add_library(tcx, cnum, RequireDynamic, &mut formats, &mut unavailable_as_static);
let deps = tcx.dylib_dependency_formats(cnum);
-@@ -207,6 +182,7 @@ fn calculate_type(tcx: TyCtxt<'_>, ty: CrateType) -> DependencyList {
+@@ -208,6 +182,7 @@ fn calculate_type(tcx: TyCtxt<'_>, ty: CrateType) -> DependencyList {
add_library(tcx, depnum, style, &mut formats, &mut unavailable_as_static);
}
}
index 0688a1d689..066e6bf53f 100644
--- a/src/bootstrap/src/core/builder/cargo.rs
+++ b/src/bootstrap/src/core/builder/cargo.rs
-@@ -1146,7 +1146,7 @@ impl Builder<'_> {
+@@ -1347,7 +1347,7 @@ impl Builder<'_> {
// When we build Rust dylibs they're all intended for intermediate
// usage, so make sure we pass the -Cprefer-dynamic flag instead of
// linking all deps statically into the dylib.
-// We need this feature as it changes `dylib` linking behavior and allows us to link to `rustc_driver`.
-#![feature(rustc_private)]
-
- fn main() {
- rustdoc::main()
- }
+ use std::process::ExitCode;
+
+ fn main() -> ExitCode {
diff --git a/src/tools/rustfmt/src/git-rustfmt/main.rs b/src/tools/rustfmt/src/git-rustfmt/main.rs
index b8b0432aa9..b5bd71e015 100644
--- a/src/tools/rustfmt/src/git-rustfmt/main.rs
index 27bbc8bd8f..a6fc4df2eb 100644
--- a/src/bootstrap/src/core/build_steps/compile.rs
+++ b/src/bootstrap/src/core/build_steps/compile.rs
-@@ -2158,23 +2158,7 @@
+@@ -2356,23 +2356,7 @@
for f in builder.read_dir(&src_libdir) {
let filename = f.file_name().into_string().unwrap();
RUST_VERSION ?= "${@d.getVar('PV').split('-')[0]}"
-SRC_URI += "https://static.rust-lang.org/dist/2026-01-19/rustc-nightly-src.tar.xz;name=rust \
+SRC_URI += "https://static.rust-lang.org/dist/2026-02-18/rustc-nightly-src.tar.xz;name=rust \
file://0001-Define-more-ioctl-codes-on-riscv32gc-unknown-linux-g.patch;patchdir=${RUSTSRC} \
file://rust-oe-selftest.patch;patchdir=${RUSTSRC} \
file://oeqa-selftest-Increase-timeout-in-process-sigpipe-ru.patch;patchdir=${RUSTSRC} \
file://revert-link-std-statically-in-rustc_driver-feature.patch;patchdir=${RUSTSRC} \
file://disable-rustfmt-check.patch;patchdir=${RUSTSRC} \
- file://revert-destabilise-target-spec-json.patch;patchdir=${RUSTSRC} \
"
-SRC_URI[rust.sha256sum] = "15125be18eb452d2891d87190f84298a9c03b1c1493b566f23b0f08d2f69adb0"
+SRC_URI[rust.sha256sum] = "2a068a25560fac48527facabead4edfc30a4e344a3b3323139990124580921cf"
RUSTSRC = "${UNPACKDIR}/rustc-nightly-src"
process = subprocess.Popen(["bash", "-c", cmd])
process.wait()
- if process.returncode != 0:
+ #tweak to scan the log file for failure
+ failed = False
+ with open(log_file, "r") as f:
+ for line in f:
+ if line.startswith("ERROR:") or "Task failed" in line:
+ failed = True
+ break
+
+ if process.returncode != 0 or failed:
print(f"FAILED: {recipe} for {machine}")
return False
print("Failures detected:")
for machine, recipes in all_failures.items():
print(f" {machine}: {', '.join(recipes)}")
+ sys.exit(-1)
if __name__ == "__main__":
main()