-
Notifications
You must be signed in to change notification settings - Fork 520
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
rewrite bootstrapping stages #1458
Conversation
e629f4e
to
f4bcf2b
Compare
I did put in time and thought and feeling into this rewrite and I feel it's an improvement with regards to passing of information and use of language. Yet, it should go technical review, because I'm not savvy in most of what is involved. |
src/building/bootstrapping.md
Outdated
Stage 3 is optional. To sanity check our new compiler, we | ||
can build the libraries with the stage2 compiler. The result ought | ||
to be identical to before, unless something has broken. | ||
To verify that the stage 2 libraries that were copied from stage 1 are indeed | ||
identical to those which would otherwise have been compiled in stage 2, the | ||
stage 2 compiler is used to compile them and a comparison is made. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess emphasizing that stage 3 is optional is important here as most contributors don't need it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is it, more specifically, that would require one to compile or use this stage compiler?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please determine whether it is resolved in HEAD.
@JohnTitor said this on the other pull request, but I'll repeat it here:
I'm sorry you put in a lot of effort to this work, but it's a lot of effort to review as well, and it's unclear how it will help people reading the guide. |
It should be clear to a reviewer how it will help people reading the guide. |
Is there really nothing I can do to have this reviewed? Pinging someone specific? Asking for a budget for contracting a documentation expert? |
will have a look within the next week |
src/building/bootstrapping.md
Outdated
## Stages of bootstrapping | ||
Each stage involves: | ||
- An existing compiler and its set of dependencies. | ||
- Targets ([objects][objects]): `std` and `rustc`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this can lead to confusion due to target
being used differently in Rust... x86_64-unknown-linux-gnu
would be an example of a target
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All occurrences of variants of "compile" as a verb in sections that this PR edits have been changed to "produce". Please confirm resolution.
src/building/bootstrapping.md
Outdated
Note: the compiler of a stage—e.g. "the stage 1 compiler"—refers to the | ||
compiler that is compiled at that stage, not the one that already exists. | ||
|
||
In the first stage (stage 0) the compiler is usually obtained by downloading a |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
usually makes me wonder if other ways should be mentioned or linked to
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree. But I'm not familiar with other ways. And this doesn't seem like an issue created in this PR. Also, I've changed it to "typically". Resolve?
src/building/bootstrapping.md
Outdated
|
||
### Stage 1 | ||
The stage 0 compiler compiles from current code `rustbuild` and `std` and uses | ||
them to compile from current code a compiler. This is the stage 1 compiler. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
produce (or an equivalent) is an important word to keep here... makes it more clear what is happenin
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Resolve in favor of #1458 (comment) ?
src/building/bootstrapping.md
Outdated
This means that the symbol names used in the compiler source | ||
may not match the symbol names that would have been made by the stage1 compiler, | ||
which can cause problems for dynamic libraries and tests. | ||
The stage 1 compiler is used to compile from current code a compiler. This is |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
produce (or equivalent) also missing here
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Resolve in favor of #1458 (comment) ?
src/building/bootstrapping.md
Outdated
Between the stage 2 and the stage 1 compiler are subtle differences: | ||
|
||
The symbol names used in the compiler source may not match the symbol names | ||
that would have been made by the stage1 compiler. This is important when using | ||
dynamic linking and due to the lack of ABI compatibility between versions. This | ||
primarily manifests when tests try to link with any of the `rustc_*` crates or | ||
use the (now deprecated) plugin infrastructure. These tests are marked with | ||
`ignore-stage1`. | ||
|
||
Also, the stage 2 compiler benefits from the compile-time optimizations | ||
generated by a compiler that is of the current code. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would create 2 bullet points from the paragraphs, to show that they flow from "... differences"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done. Resolve?
Thanks a lot @tshepang! I will amend. |
Triage: Friendly-ping @mightyiam, is there any progress since your last comment? |
Sorry. Thank you, @JohnTitor. Will get back to this. |
Scheduled for tomorrow. |
f29e27e
to
e85d43c
Compare
e85d43c
to
c74e2b5
Compare
Sorry about my confusion regarding requesting of a review. Apparently, requesting review from one person removes the request for review from another... Anyway, @tshepang , please review. |
@mightyiam sorry to make you sad given your efforts and leading you on (by suggesting improvements you have now accepted), but this change does not feel like an overall improvement to existing text. |
The one change that may be worth submitting separately as a PR is the following, as it adds new info (but I would not be a proper reviewer for it as am not familiar)...
|
No, I'm sorry. Please provide feedback. Specific feedback, @tshepang. I am certain that this is an improvement. |
One example is you are saying the same thing, but making it more verbose, and/or less readable...
The explicit mention of current code feels overkill since no one is talking about old code. One thing you may also submit as a separate PR, if not mentioned elsewhere, is...
|
The existence of a compiler that is from earlier code is central to the concept of bootstrapping. What I am doing is giving each stage a title:
The phrasing "current code" originates in this context. And in this context I feel it is useful. I have amended that sentence to include commas:
|
@mightyiam This is not an acceptable tone to use with people volunteering their time. Don't repeat it again in the future. |
We are not obligated to merge your code. The time you have spent so far has no impact on whether or not we merge your code. The only reason we would accept this change is because we think it is an improvement, not because you've worked hard on it. |
@mightyiam I hope this does not discourage you... feel free to submit future improvements, and try to keep them small, as that will make them more easy to review, and provide better feedback in case of disagreement |
Documentation rewrites are sometimes the right thing to do. Are they impossible to review? This is not that long. I dispute the rejection of it. |
@mightyiam you still 6 months later have not answered this question. |
The burden of proof is on you to show that it is an improvement, not on us to find fault with it. |
Continuing from #1327.