forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#131848 - matthiaskrgr:rollup-l29a75j, r=matth…
…iaskrgr Rollup of 7 pull requests Successful merges: - rust-lang#129620 (Provide a more convinient way of developing rustc on NixOS) - rust-lang#131805 (rustc_llvm: Fix flattened CLI args) - rust-lang#131818 (Enable XRay instrumentation for LoongArch Linux targets) - rust-lang#131825 (SolverDelegate add assoc type for Infcx) - rust-lang#131833 (Add `must_use` to `CommandExt::exec`) - rust-lang#131835 (Do not run test where it cannot run) - rust-lang#131844 (Add mailmap entry for kobzol) r? `@ghost` `@rustbot` modify labels: rollup
- Loading branch information
Showing
17 changed files
with
157 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# If you want to use this as an .envrc file to create a shell with necessery components | ||
# to develop rustc, use the following command in the root of the rusr checkout: | ||
# | ||
# ln -s ./src/tools/nix-dev-shell/envrc-flake ./.envrc && echo .envrc >> .git/info/exclude | ||
|
||
if nix flake show path:./src/tools/nix-dev-shell &> /dev/null; then | ||
use flake path:./src/tools/nix-dev-shell | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# If you want to use this as an .envrc file to create a shell with necessery components | ||
# to develop rustc, use the following command in the root of the rusr checkout: | ||
# | ||
# ln -s ./src/tools/nix-dev-shell/envrc-shell ./.envrc && echo .envrc >> .git/info/exclude | ||
|
||
use nix ./src/tools/nix-dev-shell/shell.nix | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
{ | ||
description = "rustc dev shell"; | ||
|
||
inputs = { | ||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; | ||
flake-utils.url = "github:numtide/flake-utils"; | ||
}; | ||
|
||
outputs = { self, nixpkgs, flake-utils, ... }: | ||
flake-utils.lib.eachDefaultSystem (system: | ||
let | ||
pkgs = import nixpkgs { inherit system; }; | ||
x = import ./x { inherit pkgs; }; | ||
in | ||
{ | ||
devShells.default = with pkgs; mkShell { | ||
name = "rustc-dev-shell"; | ||
nativeBuildInputs = with pkgs; [ | ||
binutils cmake ninja pkg-config python3 git curl cacert patchelf nix | ||
]; | ||
buildInputs = with pkgs; [ | ||
openssl glibc.out glibc.static x | ||
]; | ||
# Avoid creating text files for ICEs. | ||
RUSTC_ICE = "0"; | ||
# Provide `libstdc++.so.6` for the self-contained lld. | ||
LD_LIBRARY_PATH = "${with pkgs; lib.makeLibraryPath [ | ||
stdenv.cc.cc.lib | ||
]}"; | ||
}; | ||
} | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
{ pkgs ? import <nixpkgs> {} }: | ||
let | ||
x = import ./x { inherit pkgs; }; | ||
in | ||
pkgs.mkShell { | ||
name = "rustc"; | ||
nativeBuildInputs = with pkgs; [ | ||
binutils cmake ninja pkg-config python3 git curl cacert patchelf nix | ||
]; | ||
buildInputs = with pkgs; [ | ||
openssl glibc.out glibc.static x | ||
]; | ||
# Avoid creating text files for ICEs. | ||
RUSTC_ICE = "0"; | ||
# Provide `libstdc++.so.6` for the self-contained lld. | ||
LD_LIBRARY_PATH = "${with pkgs; lib.makeLibraryPath [ | ||
stdenv.cc.cc.lib | ||
]}"; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
{ | ||
pkgs ? import <nixpkgs> { }, | ||
}: | ||
pkgs.stdenv.mkDerivation { | ||
name = "x"; | ||
|
||
src = ./x.rs; | ||
dontUnpack = true; | ||
|
||
nativeBuildInputs = with pkgs; [ rustc ]; | ||
|
||
buildPhase = '' | ||
PYTHON=${pkgs.lib.getExe pkgs.python3} rustc -Copt-level=3 --crate-name x $src --out-dir $out/bin | ||
''; | ||
|
||
meta = with pkgs.lib; { | ||
description = "Helper for rust-lang/rust x.py"; | ||
homepage = "https://github.com/rust-lang/rust/blob/master/src/tools/x"; | ||
license = licenses.mit; | ||
mainProgram = "x"; | ||
}; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
// git clone https://github.com/rust-lang/rust/blob/0ea7ddcc35a2fcaa5da8a7dcfc118c9fb4a63b95/src/tools/x/src/main.rs | ||
// patched to stop doing python probing, stop the probe, please dont, i have a python | ||
//! Run bootstrap from any subdirectory of a rust compiler checkout. | ||
//! | ||
//! We prefer `exec`, to avoid adding an extra process in the process tree. | ||
//! However, since `exec` isn't available on Windows, we indirect through | ||
//! `exec_or_status`, which will call `exec` on unix and `status` on Windows. | ||
//! | ||
//! We use `powershell.exe x.ps1` on Windows, and `sh -c x` on Unix, those are | ||
//! the ones that call `x.py`. We use `sh -c` on Unix, because it is a standard. | ||
//! We also don't use `pwsh` on Windows, because it is not installed by default; | ||
use std::env; | ||
use std::os::unix::process::CommandExt; | ||
use std::process::{self, Command}; | ||
|
||
fn main() { | ||
match env::args().skip(1).next().as_deref() { | ||
Some("--wrapper-version") => { | ||
println!("0.1.0"); | ||
return; | ||
} | ||
_ => {} | ||
} | ||
let current = match env::current_dir() { | ||
Ok(dir) => dir, | ||
Err(err) => { | ||
eprintln!("Failed to get current directory: {err}"); | ||
process::exit(1); | ||
} | ||
}; | ||
|
||
for dir in current.ancestors() { | ||
let candidate = dir.join("x.py"); | ||
if candidate.exists() { | ||
let mut cmd = Command::new(env!("PYTHON")); | ||
cmd.arg(dir.join("x.py")); | ||
cmd.args(env::args().skip(1)).current_dir(dir); | ||
|
||
let error = cmd.exec(); | ||
eprintln!("Failed to invoke `{:?}`: {}", cmd, error); | ||
} | ||
} | ||
|
||
eprintln!( | ||
"x.py not found. Please run inside of a checkout of `https://github.com/rust-lang/rust`." | ||
); | ||
|
||
process::exit(1); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters