Skip to content

Conversation

@Shunpoco
Copy link
Contributor

@Shunpoco Shunpoco commented Sep 17, 2025

Fix #141903

Currently x.py help (--help) builds bootstrap binary everytime, so it takes some seconds to print help.
This PR does:

  • Saves current help text into a file (x.py run generate-help)
  • Changes bootstrap.py to print the help in the saved file and to exit without touching bootstrap binary
  • Modifies x.py test bootstrap to check if the help file is up-to-date

@rustbot rustbot added A-testsuite Area: The testsuite used to check the correctness of rustc S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. T-bootstrap Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap) labels Sep 17, 2025
@rust-log-analyzer

This comment has been minimized.

@Shunpoco Shunpoco changed the title [WIP] Save x.py's help text for saving output time Save x.py's help text for saving output time Sep 17, 2025
@Shunpoco Shunpoco marked this pull request as ready for review September 17, 2025 23:48
@rustbot
Copy link
Collaborator

rustbot commented Sep 17, 2025

This PR modifies src/bootstrap/src/core/config.

If appropriate, please update CONFIG_CHANGE_HISTORY in src/bootstrap/src/utils/change_tracker.rs.

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. labels Sep 17, 2025
@rustbot
Copy link
Collaborator

rustbot commented Sep 17, 2025

r? @Mark-Simulacrum

rustbot has assigned @Mark-Simulacrum.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@jieyouxu
Copy link
Member

I'm on the fence on this. I'm slightly leaning towards "I don't feel like the extra complexity and having to remember another point of potential outdatedness pulls its weight". But if another bootstrap reviewer feels okay about this, that is fine with me too.

@Kobzol
Copy link
Member

Kobzol commented Sep 18, 2025

I also wasn't a super big fan of this, tbh. But while testing this PR, I realized that this approach actually cannot work in the way it was designated in the original issue, or at least not generally. Because it assumes that bootstrap options and flags are unified, but that is no longer the case. Since we switched to clap, some subcommands actually have their own arguments, and thus also different help.

For example, here is the output of x perf --help:

Perform profiling and benchmarking of the compiler using `rustc-perf`

Usage: x.py perf [OPTIONS] [PATHS]... [-- <ARGS>...] <COMMAND>

Commands:
  eprintln    Run `profile_local eprintln`. This executes the compiler on the given benchmarks and stores its stderr output
  samply      Run `profile_local samply` This executes the compiler on the given benchmarks and profiles it with `samply`. You need to install `samply`, e.g. using `cargo install samply`
  cachegrind  Run `profile_local cachegrind`. This executes the compiler on the given benchmarks under `Cachegrind`
  benchmark   Run compile benchmarks with a locally built compiler
  compare     Compare the results of two previously executed benchmark runs

Arguments:
  [PATHS]...
          paths for the subcommand

  [ARGS]...
          arguments passed to subcommands

Options:
  -v, --verbose...
          use verbose output (-vv for very verbose)

  -i, --incremental
          use incremental compilation

      --config <FILE>
          TOML configuration file for build

      --build-dir <DIR>
          Build directory, overrides `build.build-dir` in `bootstrap.toml`

... many shared bootstrap flags

But with this PR, when I do x perf --help, it will only print the saved help of x --help, which is wrong.

So for this to work generically, the Python wrapper would have to:

  1. Recognize which bootstrap command is being executed (at least for the commands that have some custom arguments/options/subcommands)
  2. Save the help output for each such command specifically

Even 1) is annoying, as the Python wrapper would have to reimplement CLI parsing logic, to recognize e.g. things like ./x --stage 1 build. But in any case, I don't think we should have that kind of complexity in the Python layer.

Sorry for not catching that earlier, but I think that this is not going to work. CC @jyn514 if you have other opinions.

@Shunpoco
Copy link
Contributor Author

Shunpoco commented Sep 18, 2025

Thanks, I didn't catch x <subcommand> --help also goes to the saved file.

And

Recognize which bootstrap command is being executed (at least for the commands that have some custom arguments/options/subcommands)

I agree, this is inevitable if all subcommands' helps are also loaded from files. I don't think this is a good way.

I think we can make only root help (x help|--help|-h) use a saved file by changing help_triggered in bootstrap.py. In that case, only the root speeds up to print the help but other subcommands still use helps from the binary.
Of course I need to confirm if that is enough valuable to bring the complexity, though.

@Mark-Simulacrum
Copy link
Member

Per above I think we can probably close this?

One thought is we could plausibly generate e.g. the man pages that clap supports and check those in, but it all seems fairly complicated for not as much value.

@jyn514
Copy link
Member

jyn514 commented Sep 23, 2025

I think if we only do this for the very top-level x.py --help that's fine. We can still delegate to the rust code for subcommand help (anything other than the exact string -h or --help), that doesn't require the python to be smart.

@Shunpoco
Copy link
Contributor Author

Shunpoco commented Sep 23, 2025

@jyn514 Thanks for the confirmation,
fb5b849 makes only root help use a saved file (help for subcommands go to the binary)

@rust-log-analyzer

This comment has been minimized.

--skip-std-check-if-no-download-rustc
Skip checking the standard library if `rust.download-rustc` isn't available. This is mostly for RA as building the stage1 compiler to check the library tree on each code change might be too much for some computers
-h, --help
Print help (see more with '--help')
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Probably not relevant to this PR, but I wonder if we should really be showing all of this in help... e.g., the PGO options don't feel relevant to 99% of x.py users, and there's enough options here that we end up scrolling off screen for the actually-useful collection of subcommands test/doc/check/etc.

It might mean that we want a verbose and non-verbose help for the top level?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It makes sense to me for both > not relevant to this PR and > want a verbose and non-verbose help for the top level

Although I don't know if Clap supports such detailed/brief help, can I make an issue ticket for it (Check Clap's features, then modify the top-level help if we can)

@Mark-Simulacrum Mark-Simulacrum added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Sep 28, 2025
@rust-log-analyzer

This comment has been minimized.

@Shunpoco
Copy link
Contributor Author

Shunpoco commented Oct 1, 2025

@rustbot review

Note: I will clean up the commit history after the review

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. labels Oct 1, 2025

# If the user is asking for help, let them know that the whole download-and-build
# Root help (e.g., x.py --help) prints help from the saved file to save the time
if len(sys.argv) == 1 or sys.argv[1] in ["-h", "--help"]:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The second part of this seems like it's not quite right, it needs (sys.argv[1] in ["-h", "--help"] and len(sys.argv) == 2), right? Otherwise x.py --help check wouldn't do the right thing?

Copy link
Contributor Author

@Shunpoco Shunpoco Oct 1, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Currently x.py --help check prints the top level help, not check's help. So I think we don't need len(sys.argv) == 2 for it.
Or, do you think x.py --help check should be identical with x.py check --help?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Or, do you think~

I guess if we dispatch x.py --help check to bootstrap binary. Clap returns the top level help for it unless we modify the behaviour.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Or, do you think x.py --help check should be identical with x.py check --help?

Yeah, that's what I'd expect. Printing the top-level output for x.py --help check seems quite odd to me.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But if clap has this behavior, then I'm OK sticking with that decision (would be interesting to see if that's intentional). It's probably a rare case either way.

Copy link
Contributor Author

@Shunpoco Shunpoco Oct 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I checked that:

  • clap checks arguments from left to right
  • If an argument is help (--help or -h), it prints help of the current level (e.g., ./x --help is for top level, and ./x check --help is for check level) and exit immediately

So x.py --help check prints the top level help, and argument check is just ignored.

@Mark-Simulacrum
Copy link
Member

r=me with commits squashed

@rustbot

This comment has been minimized.

Currently x.py help (or x.py --help) builds bootstrap binary everytime, but it delays printing help.
This change saves the current top level help text into a file. x.py help prints the file and doesn't touch bootstrap binary.
x.py test bootstrap checks if the file is up to date.
Note that subcommand level helps (e.g., x.py check --help) aren't saved.
@rustbot
Copy link
Collaborator

rustbot commented Oct 11, 2025

This PR was rebased onto a different master commit. Here's a range-diff highlighting what actually changed.

Rebasing is a normal part of keeping PRs up to date, so no action is needed—this note is just to help reviewers.

@Mark-Simulacrum
Copy link
Member

@bors r+

@bors
Copy link
Collaborator

bors commented Oct 11, 2025

📌 Commit 340702c has been approved by Mark-Simulacrum

It is now in the queue for this repository.

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Oct 11, 2025
Zalathar added a commit to Zalathar/rust that referenced this pull request Oct 12, 2025
…lacrum

Save x.py's help text for saving output time

Fix rust-lang#141903

Currently x.py help (--help) builds bootstrap binary everytime, so it takes some seconds to print help.
This PR does:
-  Saves current help text into a file (x.py run generate-help)
-  Changes bootstrap.py to print the help in the saved file and to exit without touching bootstrap binary
-  Modifies x.py test bootstrap to check if the help file is up-to-date
bors added a commit that referenced this pull request Oct 12, 2025
Rollup of 12 pull requests

Successful merges:

 - #138799 (core: simplify `Extend` for tuples)
 - #146692 (Save x.py's help text for saving output time)
 - #147168 (Don't unconditionally build alloc for `no-std` targets)
 - #147178 ([DebugInfo] Improve formatting of MSVC enum struct variants)
 - #147240 (Add an ACP list item to the library tracking issue template)
 - #147246 (Explain not existed key in BTreeMap::split_off)
 - #147393 (Extract most code from `define_feedable!`)
 - #147495 (Update wasm-component-ld to 0.5.18)
 - #147503 (Fix documentation of Instant::now on mac)
 - #147541 (Change int-to-ptr transmute lowering back to inttoptr)
 - #147549 (Replace `LLVMRustContextCreate` with normal LLVM-C API calls)
 - #147596 (Adjust the Arm targets in CI to reflect latest changes)

r? `@ghost`
`@rustbot` modify labels: rollup
bors added a commit that referenced this pull request Oct 12, 2025
Rollup of 8 pull requests

Successful merges:

 - #138799 (core: simplify `Extend` for tuples)
 - #145897 (Rehome 30 `tests/ui/issues/` tests to other subdirectories under `tests/ui/` [#4 of Batch #2])
 - #146692 (Save x.py's help text for saving output time)
 - #147240 (Add an ACP list item to the library tracking issue template)
 - #147246 (Explain not existed key in BTreeMap::split_off)
 - #147393 (Extract most code from `define_feedable!`)
 - #147503 (Fix documentation of Instant::now on mac)
 - #147549 (Replace `LLVMRustContextCreate` with normal LLVM-C API calls)

r? `@ghost`
`@rustbot` modify labels: rollup
@bors bors merged commit f64f890 into rust-lang:master Oct 12, 2025
10 checks passed
@rustbot rustbot added this to the 1.92.0 milestone Oct 12, 2025
rust-timer added a commit that referenced this pull request Oct 12, 2025
Rollup merge of #146692 - Shunpoco:issue-141903, r=Mark-Simulacrum

Save x.py's help text for saving output time

Fix #141903

Currently x.py help (--help) builds bootstrap binary everytime, so it takes some seconds to print help.
This PR does:
-  Saves current help text into a file (x.py run generate-help)
-  Changes bootstrap.py to print the help in the saved file and to exit without touching bootstrap binary
-  Modifies x.py test bootstrap to check if the help file is up-to-date
@Shunpoco Shunpoco deleted the issue-141903 branch October 12, 2025 16:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

A-testsuite Area: The testsuite used to check the correctness of rustc S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. T-bootstrap Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap)

Projects

None yet

Development

Successfully merging this pull request may close these issues.

x --help builds bootstrap

8 participants