diff options
| author | bjorn3 <17426603+bjorn3@users.noreply.github.com> | 2023-10-28 19:11:51 +0000 |
|---|---|---|
| committer | onur-ozkan <work@onurozkan.dev> | 2023-11-04 15:11:55 +0300 |
| commit | a9913ebed0befb09ed21725e1e30cdbd6a9c33ea (patch) | |
| tree | 3fde44643a2319f6d64a2b2214d7134a33b3715a /src | |
| parent | d82fdb6616207dff00af563508c6e6cc5aaa4ca3 (diff) | |
| download | rust-a9913ebed0befb09ed21725e1e30cdbd6a9c33ea.tar.gz rust-a9913ebed0befb09ed21725e1e30cdbd6a9c33ea.zip | |
Ensure the rustc-codegen-cranelift-preview component is never empty
Either generate it with the actual codegen backend dylib or omit it entirely when the cranelift backend is disabled for this build.
Diffstat (limited to 'src')
| -rw-r--r-- | src/bootstrap/src/core/build_steps/dist.rs | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/bootstrap/src/core/build_steps/dist.rs b/src/bootstrap/src/core/build_steps/dist.rs index b578c5ec295..197ce78d885 100644 --- a/src/bootstrap/src/core/build_steps/dist.rs +++ b/src/bootstrap/src/core/build_steps/dist.rs @@ -1305,6 +1305,10 @@ impl Step for CodegenBackend { return None; } + if !builder.config.rust_codegen_backends.contains(&self.backend) { + return None; + } + if self.backend == "cranelift" { if !target_supports_cranelift_backend(self.compiler.host) { builder.info("target not supported by rustc_codegen_cranelift. skipping"); @@ -1343,12 +1347,15 @@ impl Step for CodegenBackend { let backends_dst = PathBuf::from("lib").join(&backends_rel); let backend_name = format!("rustc_codegen_{}", backend); + let mut found_backend = false; for backend in fs::read_dir(&backends_src).unwrap() { let file_name = backend.unwrap().file_name(); if file_name.to_str().unwrap().contains(&backend_name) { tarball.add_file(backends_src.join(file_name), &backends_dst, 0o644); + found_backend = true; } } + assert!(found_backend); Some(tarball.generate()) } |
