Expand description
High-level overview of how fix
works:
The main goal is to run cargo check
to get rustc to emit JSON
diagnostics with suggested fixes that can be applied to the files on the
filesystem, and validate that those changes didn’t break anything.
Cargo begins by launching a LockServer
thread in the background to
listen for network connections to coordinate locking when multiple targets
are built simultaneously. It ensures each package has only one fix running
at once.
The RustfixDiagnosticServer
is launched in a background thread (in
JobQueue
) to listen for network connections to coordinate displaying
messages to the user on the console (so that multiple processes don’t try
to print at the same time).
Cargo begins a normal cargo check
operation with itself set as a proxy
for rustc by setting primary_unit_rustc
in the build config. When
cargo launches rustc to check a crate, it is actually launching itself.
The FIX_ENV_INTERNAL
environment variable is set so that cargo knows it is in
fix-proxy-mode.
Each proxied cargo-as-rustc detects it is in fix-proxy-mode (via FIX_ENV_INTERNAL
environment variable in main
) and does the following:
- Acquire a lock from the
LockServer
from the master cargo process. - Launches the real rustc (
rustfix_and_fix
), looking at the JSON output for suggested fixes. - Uses the
rustfix
crate to apply the suggestions to the files on the file system. - If rustfix fails to apply any suggestions (for example, they are overlapping), but at least some suggestions succeeded, it will try the previous two steps up to 4 times as long as some suggestions succeed.
- Assuming there’s at least one suggestion applied, and the suggestions
applied cleanly, rustc is run again to verify the suggestions didn’t
break anything. The change will be backed out if it fails (unless
--broken-code
is used). - If there are any warnings or errors, rustc will be run one last time to show them to the user.
Structs
- FixArgs 🔒Various command-line options and settings used when
cargo
is running as a proxy forrustc
during the fix operation.
Constants
- Internal only. For passing
FixOptions::broken_code
through to cargo running in proxy mode. - Internal only. For passing
FixOptions::edition
through to cargo running in proxy mode. - Internal only. Indicates Cargo is in fix-proxy-mode if presents. The value of it is the socket address of the
LockServer
being used. See the module-level documentation for more. - Internal only. For passing
FixOptions::idioms
through to cargo running in proxy mode.
Functions
- Entry point for
cargo
running as a proxy forrustc
. - Provide the lock address when running in proxy mode
- Executes
rustc
to apply one round of suggestions to the crate in question. - Attempts to apply fixes to a single crate.