Thanks again to Open Source Security, inc and Embecosm for their ongoing support for this project.
Our two GSoC students are progressing nicely on their projects and are
both ahead of schedule. Zhi Heng’s work is allowing us to handle some
complex pattern matches present in core
, which the compiler would
previously ignore - while Ryutaro’s contributions are adding more
complex warning checkers while removing previous false positives. Thanks
to them, the compiler is getting more correct, and gets closer and
closer to real Rust code.
Speaking of this, this month marks an important milestone for gccrs
:
One of our earliest “real-code” milestone was an implementation of
SipHash
as is present in core
:
Link.
This algorithm relies on an important amount of code from core
, and we
have been trying to compile it for multiple
years. With Philip’s
recent work on fixing typechecker issues, the module now works and is
being compiled properly.
Overall, our progress on core
is great and things are moving fast. We
have completed the two milestones mentioned in last month’s report,
try
blocks and while-let
loops, which allows us to continue moving
forward with core
. We have also completed the work package on the
offset_of!()
builtin macro, which marks our first Rust-for-Linux
specific feature - as the macro does not exist in the Rust 1.49 standard
library.
This means that our goal of experimenting with compiling the kernel at the end of the summer is on track.
try blocks
The desugar for try
blocks is interesting as it ties in with the
desugar for the ?
operator to prevent an early return from the
enclosing function instead of the current block.
In Rust 1.49, the common desugar for the ?
operator is as follows:
fn foo() -> Result<i32, ()> {
let a = bar()?;
Ok(15i32);
}
// becomes
fn foo() -> Result<i32, ()> {
let a = match Try::into_result(bar()) {
Ok(value) => value,
Err(err) => return Try::from_err(From::from(err)),
};
Ok(15i32);
}
As explained in last month’s report, the desugar for try
blocks is
as follows:
try {
<stmts>;
<expr>
}
// becomes
{
<stmts>;
::std::ops::Try::from_ok(<expr>)
}
However, if we desugar the ?
operator inside of a try
block…
fn foo() -> Result<i32, ()> {
let a: Result<i32, ()> = try {
bar()?;
14i32
};
a
}
// becomes
fn foo() -> Result<i32, ()> {
let a: Result<i32, ()> = {
match Try::into_result(bar()) {
Ok(value) => value,
Err(err) => return Try::from_err(From::from(err)),
};
Try::from_ok(14i32)
}
Ok(15i32);
}
…we can easily see how this would cause an early return from the
function instead of the block, should the bar
function call return
an error. This is not the desired behavior, so the desugar must be
able to handle short-circuiting from the enclosing try
block
instead.
// expected desugar
fn foo() -> Result<i32, ()> {
let a: Result<i32, ()> = 'try_label {
match Try::into_result(bar()) {
Ok(value) => value,
Err(err) => {
break 'try_label Try::from_err(From::from(err));
}
};
Try::from_ok(14i32)
}
Ok(15i32);
}
We cannot yet handle this “complex” desugar, which would require
some changes to our desugaring infrastructure to keep some context
when desugaring the ?
operator. However, all of the try
blocks in core
1.49 only use the simple form of try { <expr> }
,
which makes our job easier!
We will have our next monthly community call on the 11th of August at 9am UTC. You can subscribe to our calendar to see when the next one will be held. The call is open to everyone, even if you would just like to sit-in and listen. You can also subscribe to our mailing-list or join our Zulip chat to be notified of upcoming events.
rust-parse-impl.h
in rust-parse.h
PR4037parse_path_meta_item
PR4036rust/typecheck
support
PR4011IfLetExprConseqElse
in DefaultResolver
PR3996ExpandVisitor::expand_macro_children
PR3989MacroInvocLexer
in AttributeParser
PR3890Late
visitor override for StructStruct
PR3873format_args
to accept a raw string literal
PR3872CfgStrip
phase
PR3871reinterpret_cast
usages in DefaultASTVisitor
PR3869Category | Last Month | This Month | Delta |
---|---|---|---|
TODO | 469 | 517 | +48 |
In Progress | 112 | 109 | -3 |
Completed | 1077 | 1114 | +37 |
Category | Last Month | This Month | Delta |
---|---|---|---|
TODO | 207 | 207 | - |
In Progress | 54 | 54 | -2 |
Completed | 526 | 526 | +5 |
TestCases | Last Month | This Month | Delta |
---|---|---|---|
Passing | 9949 | 10089 | +140 |
Failed | - | - | - |
XFAIL | 64 | 64 | - |
XPASS | - | - | - |
Milestone | Last Month | This Month | Delta | Start Date | Completion Date | Target | Target GCC |
---|---|---|---|---|---|---|---|
Explicit generics with impl Trait | 85% | 100% | - | 28th Feb 2025 | 21st Jul 2025 | 28th Mar 2025 | GCC 16.1 |
Final Inline assembly fixes | 0% | 65% | +65% | - | GCC 16.1 | ||
try blocks | 0% | 100% | +100% | 30th Jul 2025 | GCC 16.1 | ||
while-let loops | 0% | 100% | +100% | 30th Jul 2025 | GCC 16.1 | ||
offset_of!() builtin macro | 0% | 100% | +100% | 15th Mar 2025 | 4th Aug 2025 | 15th Aug 2025 | GCC 16.1 |
Upcoming Milestone | Last Month | This Month | Delta | Start Date | Completion Date | Target | Target GCC |
---|---|---|---|---|---|---|---|
Unstable RfL features | 0% | 0% | - | 7th Jan 2025 | - | 1st Aug 2025 | GCC 16.1 |
Generic Associated Types | 0% | 0% | - | 15th Mar 2025 | - | 15th Jun 2025 | GCC 16.1 |
RfL const generics | 0% | 0% | - | 1st May 2025 | - | 15th Jun 2025 | GCC 16.1 |
frontend plugin hooks | 0% | 0% | - | 15th May 2025 | - | 7th Jul 2025 | GCC 16.1 |
Handling the testsuite issues | 0% | 0% | - | 15th Sep 2024 | - | 15th Sep 2025 | GCC 16.1 |
main shim | 0% | 0% | - | 28th Jul 2025 | - | 15th Sep 2025 | GCC 16.1 |
Final core attributes | 0% | 0% | - | - | GCC 16.1 | ||
Core nightly features | 0% | 0% | - | - | GCC 16.1 | ||
Defered inference | 0% | 0% | - | - | GCC 16.1 | ||
Fn traits fixes | 0% | 0% | - | - | GCC 16.1 | ||
Recursive types | 0% | 0% | - | - | GCC 16.1 | ||
Drop | 0% | 0% | - | - | GCC 16.1 | ||
Pin, PinInit | 0% | 0% | - | - | GCC 16.1 |
Past Milestone | Last Month | This Month | Delta | Start Date | Completion Date | Target | Target GCC |
---|---|---|---|---|---|---|---|
Data Structures 1 - Core | 100% | 100% | - | 30th Nov 2020 | 27th Jan 2021 | 29th Jan 2021 | GCC 14.1 |
Control Flow 1 - Core | 100% | 100% | - | 28th Jan 2021 | 10th Feb 2021 | 26th Feb 2021 | GCC 14.1 |
Data Structures 2 - Generics | 100% | 100% | - | 11th Feb 2021 | 14th May 2021 | 28th May 2021 | GCC 14.1 |
Data Structures 3 - Traits | 100% | 100% | - | 20th May 2021 | 17th Sep 2021 | 27th Aug 2021 | GCC 14.1 |
Control Flow 2 - Pattern Matching | 100% | 100% | - | 20th Sep 2021 | 9th Dec 2021 | 29th Nov 2021 | GCC 14.1 |
Macros and cfg expansion | 100% | 100% | - | 1st Dec 2021 | 31st Mar 2022 | 28th Mar 2022 | GCC 14.1 |
Imports and Visibility | 100% | 100% | - | 29th Mar 2022 | 13th Jul 2022 | 27th May 2022 | GCC 14.1 |
Const Generics | 100% | 100% | - | 30th May 2022 | 10th Oct 2022 | 17th Oct 2022 | GCC 14.1 |
Initial upstream patches | 100% | 100% | - | 10th Oct 2022 | 13th Nov 2022 | 13th Nov 2022 | GCC 14.1 |
Upstream initial patchset | 100% | 100% | - | 13th Nov 2022 | 13th Dec 2022 | 19th Dec 2022 | GCC 14.1 |
Update GCC’s master branch | 100% | 100% | - | 1st Jan 2023 | 21st Feb 2023 | 3rd Mar 2023 | GCC 14.1 |
Final set of upstream patches | 100% | 100% | - | 16th Nov 2022 | 1st May 2023 | 30th Apr 2023 | GCC 14.1 |
Borrow Checking 1 | 100% | 100% | - | TBD | 8th Jan 2024 | 15th Aug 2023 | GCC 14.1 |
Procedural Macros 1 | 100% | 100% | - | 13th Apr 2023 | 6th Aug 2023 | 6th Aug 2023 | GCC 14.1 |
GCC 13.2 Release | 100% | 100% | - | 13th Apr 2023 | 22nd Jul 2023 | 15th Jul 2023 | GCC 14.1 |
GCC 14 Stage 3 | 100% | 100% | - | 1st Sep 2023 | 20th Sep 2023 | 1st Nov 2023 | GCC 14.1 |
GCC 14.1 Release | 100% | 100% | - | 2nd Jan 2024 | 2nd Jun 2024 | 15th Apr 2024 | GCC 14.1 |
format_args!() support | 100% | 100% | - | 15th Feb 2024 | - | 1st Apr 2024 | GCC 14.1 |
GCC 14.2 | 100% | 100% | - | 7th Jun 2024 | 15th Jun 2024 | 15th Jun 2024 | GCC 14.2 |
GCC 15.1 | 100% | 100% | - | 21st Jun 2024 | 31st Jun 2024 | 1st Jul 2024 | GCC 15.1 |
Unhandled attributes | 100% | 100% | - | 1st Jul 2024 | 15th Aug 2024 | 15th Aug 2024 | GCC 15.1 |
Inline assembly | 100% | 100% | - | 1st Jun 2024 | 26th Aug 2024 | 15th Sep 2024 | GCC 15.1 |
Rustc Testsuite Adaptor | 100% | 100% | - | 1st Jun 2024 | 26th Aug 2024 | 15th Sep 2024 | GCC 15.1 |
Borrow checker improvements | 100% | 100% | - | 1st Jun 2024 | 26th Aug 2024 | 15th Sep 2024 | GCC 15.1 |
Deref and DerefMut improvements | 100% | 100% | - | 28th Sep 2024 | 25th Oct 2024 | 28th Dec 2024 | GCC 15.1 |
Indexing fixes | 100% | 100% | - | 21st Jul 2024 | 25th Dec 2024 | 15th Nov 2024 | GCC 15.1 |
Iterator fixes | 100% | 100% | - | 21st Jul 2024 | 25th Dec 2024 | 15th Nov 2024 | GCC 15.1 |
Auto traits improvements | 100% | 100% | - | 15th Sep 2024 | 20th Jan 2025 | 21st Dec 2024 | GCC 15.1 |
Lang items | 100% | 100% | - | 1st Jul 2024 | 10th Jan 2025 | 21st Nov 2024 | GCC 15.1 |
alloc parser issues | 100% | 100% | - | 7th Jan 2025 | 31st Jun 2024 | 28th Jan 2025 | GCC 15.1 |
std parser issues | 100% | 100% | - | 7th Jan 2025 | 31st Jun 2024 | 28th Jan 2025 | GCC 16.1 |
Question mark operator | 100% | 100% | - | 15th Dec 2024 | 21st Feb 2025 | 21st Feb 2025 | GCC 15.1 |
Name resolution 2.0 rework | 100% | 100% | - | 1st Jun 2024 | - | 1st Apr 2025 | GCC 15.1 |
Macro expansion | 100% | 100% | - | 1st Jun 2024 | - | 1st Jan 2025 | GCC 15.1 |
Remaining typecheck issues | 100% | 100% | - | 21st Oct 2024 | - | 1st Mar 2025 | GCC 15.1 |
cfg-core | 100% | 100% | - | 1st Dec 2024 | 24th Mar 2025 | 1st Mar 2025 | GCC 15.1 |
Codegen fixes | 100% | 100% | - | 7th Oct 2024 | 1st Apr 2025 | 1st Mar 2025 | GCC 15.1 |
black_box intrinsic | 100% | 100% | - | 28th Oct 2024 | - | 28th Jan 2025 | GCC 15.1 |
let-else | 100% | 100% | - | 28th Jan 2025 | - | 28th Feb 2025 | GCC 15.1 |
Specialization | 100% | 100% | - | 1st Jan 2025 | 1st Apr 2025 | 1st Mar 2025 | GCC 15.1 |
cfg-rfl | 100% | 100% | - | 7th Jan 2025 | 19th Mar 2025 | 15th Feb 2025 | GCC 15.1 |
Downgrade to Rust 1.49 | 100% | 100% | - | 14th Mar 2025 | 26th Mar 2025 | 1st Apr 2025 | GCC 15.1 |
We must establish the list of GCC-common changes we need, as we will have to send them upstream before the start of Stage 3 around November. This is the only risk which could incur further problems and prevent more gccrs features from landing in 16.1.