rustc supports remapping source paths prefixes as a best effort in all compiler generated output, including compiler diagnostics, debugging information, macro expansions, etc.
This is useful for normalizing build products, for example, by removing the current directory out of the paths emitted into object files.
The remapping is done via the --remap-path-prefix flag and can be customized via the --remap-path-scope flag.
--remap-path-prefixIt takes a value of the form FROM=TO where a path prefix equal to FROM is rewritten to the value TO. FROM may itself contain an = symbol, but TO value may not.
The replacement is purely textual, with no consideration of the current system's path separator.
When multiple remappings are given and several of them match, the last matching one is applied.
Some build systems, such as Cargo, may compile crates using relative paths (for example, src/main.rs instead of /home/user/project/src/main.rs).
rustc preserves these relative paths where possible. However, certain inputs (like #[path = "..."]) and outputs (such as debug information) may still contain absolute paths.
To ensure consistency, it’s recommended to remap both relative and absolute paths.
rustc --remap-path-prefix "src/=/redacted/src" --remap-path-prefix "/home/user/project=/redacted"
rustc --remap-path-prefix "/home/user/project=/redacted"
This example replaces all occurrences of /home/user/project in emitted paths with /redacted.
--remap-path-scopeDefines which scopes of paths should be remapped by --remap-path-prefix.
This flag accepts a comma-separated list of values and may be specified multiple times, in which case the scopes are aggregated together.
The valid scopes are:
macro - apply remappings to the expansion of std::file!() macro. This is where paths in embedded panic messages come fromdiagnostics - apply remappings to printed compiler diagnosticsdebuginfo - apply remappings to debug informationcoverage - apply remappings to coverage informationobject - apply remappings to all paths in compiled executables or libraries, but not elsewhere. Currently an alias for macro,coverage,debuginfo.all (default) - an alias for all of the above, also equivalent to supplying only --remap-path-prefix without --remap-path-scope.The scopes accepted by --remap-path-scope are not exhaustive - new scopes may be added in future releases for eventual stabilisation. This implies that the all scope can correspond to different scopes between releases.
# With `object` scope only the build outputs will be remapped, the diagnostics won't be remapped. rustc --remap-path-prefix=$(PWD)=/remapped --remap-path-scope=object main.rs
On some platforms like x86_64-pc-windows-msvc, the linker may embed absolute host paths and compiler arguments into debug info files (like .pdb) independently of rustc.
Additionally, on Apple platforms, linkers generate OSO entries which are not remapped by the compiler and need to be manually remapped with -oso_prefix.
The --remap-path-prefix option does not affect these linker-generated paths.
The remapping is strictly textual and does not account for different path separator conventions across platforms. Care must be taken when specifying prefixes, especially on Windows, where both / and \ may appear in paths.
Paths introduced by external tools or environment variables may not be covered by --remap-path-prefix unless explicitly accounted for.
For example, generated code introduced by Cargo's build script may still contain un-remapped paths.