-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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 #98075 - JohnTitor:rollup-nqwodnk, r=JohnTitor
Rollup of 4 pull requests Successful merges: - #95211 (Improve parser diagnostics) - #95243 (Add Apple WatchOS compile targets) - #97385 (Add WIP stable MIR crate) - #97508 (Harden bad placeholder checks on statics/consts) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
- Loading branch information
Showing
56 changed files
with
621 additions
and
51 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
target |
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,28 @@ | ||
[package] | ||
name = "rustc_smir" | ||
version = "0.0.0" | ||
edition = "2021" | ||
|
||
[dependencies] | ||
rustc_borrowck = { path = "../rustc_borrowck", optional = true } | ||
rustc_driver = { path = "../rustc_driver", optional = true } | ||
rustc_hir = { path = "../rustc_hir", optional = true } | ||
rustc_interface = { path = "../rustc_interface", optional = true } | ||
rustc_middle = { path = "../rustc_middle", optional = true } | ||
rustc_mir_dataflow = { path = "../rustc_mir_dataflow", optional = true } | ||
rustc_mir_transform = { path = "../rustc_mir_transform", optional = true } | ||
rustc_serialize = { path = "../rustc_serialize", optional = true } | ||
rustc_trait_selection = { path = "../rustc_trait_selection", optional = true } | ||
|
||
[features] | ||
default = [ | ||
"rustc_borrowck", | ||
"rustc_driver", | ||
"rustc_hir", | ||
"rustc_interface", | ||
"rustc_middle", | ||
"rustc_mir_dataflow", | ||
"rustc_mir_transform", | ||
"rustc_serialize", | ||
"rustc_trait_selection", | ||
] |
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,75 @@ | ||
This crate is regularly synced with its mirror in the rustc repo at `compiler/rustc_smir`. | ||
|
||
We use `git subtree` for this to preserve commits and allow the rustc repo to | ||
edit these crates without having to touch this repo. This keeps the crates compiling | ||
while allowing us to independently work on them here. The effort of keeping them in | ||
sync is pushed entirely onto us, without affecting rustc workflows negatively. | ||
This may change in the future, but changes to policy should only be done via a | ||
compiler team MCP. | ||
|
||
## Instructions for working on this crate locally | ||
|
||
Since the crate is the same in the rustc repo and here, the dependencies on rustc_* crates | ||
will only either work here or there, but never in both places at the same time. Thus we use | ||
optional dependencies on the rustc_* crates, requiring local development to use | ||
|
||
``` | ||
cargo build --no-default-features -Zavoid-dev-deps | ||
``` | ||
|
||
in order to compile successfully. | ||
|
||
## Instructions for syncing | ||
|
||
### Updating this repository | ||
|
||
In the rustc repo, execute | ||
|
||
``` | ||
git subtree push --prefix=compiler/rustc_smir url_to_your_fork_of_project_stable_mir some_feature_branch | ||
``` | ||
|
||
and then open a PR of your `some_feature_branch` against https://github.com/rust-lang/project-stable-mir | ||
|
||
### Updating the rustc library | ||
|
||
First we need to bump our stack limit, as the rustc repo otherwise quickly hits that: | ||
|
||
``` | ||
ulimit -s 60000 | ||
``` | ||
|
||
#### Maximum function recursion depth (1000) reached | ||
|
||
Then we need to disable `dash` as the default shell for sh scripts, as otherwise we run into a | ||
hard limit of a recursion depth of 1000: | ||
|
||
``` | ||
sudo dpkg-reconfigure dash | ||
``` | ||
|
||
and then select `No` to disable dash. | ||
|
||
|
||
#### Patching your `git worktree` | ||
|
||
The regular git worktree does not scale to repos of the size of the rustc repo. | ||
So download the `git-subtree.sh` from https://github.com/gitgitgadget/git/pull/493/files and run | ||
|
||
``` | ||
sudo cp --backup /path/to/patched/git-subtree.sh /usr/lib/git-core/git-subtree | ||
sudo chmod --reference=/usr/lib/git-core/git-subtree~ /usr/lib/git-core/git-subtree | ||
sudo chown --reference=/usr/lib/git-core/git-subtree~ /usr/lib/git-core/git-subtree | ||
``` | ||
|
||
#### Actually doing a sync | ||
|
||
In the rustc repo, execute | ||
|
||
``` | ||
git subtree pull --prefix=compiler/rustc_smir https://github.com/rust-lang/project-stable-mir smir | ||
``` | ||
|
||
Note: only ever sync to rustc from the project-stable-mir's `smir` branch. Do not sync with your own forks. | ||
|
||
Then open a PR against rustc just like a regular PR. |
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,3 @@ | ||
[toolchain] | ||
channel = "nightly-2022-06-01" | ||
components = [ "rustfmt", "rustc-dev" ] |
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,17 @@ | ||
//! The WIP stable interface to rustc internals. | ||
//! | ||
//! For more information see https://github.com/rust-lang/project-stable-mir | ||
//! | ||
//! # Note | ||
//! | ||
//! This API is still completely unstable and subject to change. | ||
#![doc( | ||
html_root_url = "https://doc.rust-lang.org/nightly/nightly-rustc/", | ||
test(attr(allow(unused_variables), deny(warnings))) | ||
)] | ||
#![cfg_attr(not(feature = "default"), feature(rustc_private))] | ||
|
||
pub mod mir; | ||
|
||
pub mod very_unstable; |
Oops, something went wrong.