-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Drop impl on type reverses order of field destruction #16492
Comments
cc @cmr, who first hit this bug. |
The LLVM IR for the Drop glue for define internal void @_ZN13DropMe_NoImpl14glue_drop.148117h571786c88b10fe1dE(%"struct.DropMe_NoImpl<[]>"*) unnamed_addr #3 {
entry-block:
%1 = getelementptr inbounds %"struct.DropMe_NoImpl<[]>"* %0, i32 0, i32 0
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %1)
%2 = getelementptr inbounds %"struct.DropMe_NoImpl<[]>"* %0, i32 0, i32 1
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %2)
%3 = getelementptr inbounds %"struct.DropMe_NoImpl<[]>"* %0, i32 0, i32 2
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %3)
ret void
} The LLVM IR for the Drop glue for define internal void @_ZN11DropMe_Impl14glue_drop.146417h9f98bddab7694295E(%"struct.DropMe_Impl<[]>"*) unnamed_addr #3 {
entry-block:
%1 = alloca { i8*, i32 }
%2 = getelementptr inbounds %"struct.DropMe_Impl<[]>"* %0, i32 0, i32 3
%3 = load i8* %2, !range !0
%4 = trunc i8 %3 to i1
br i1 %4, label %cond, label %next
next: ; preds = %normal-return, %entry-block
ret void
cond: ; preds = %entry-block
%5 = getelementptr inbounds %"struct.DropMe_Impl<[]>"* %0, i32 0, i32 0
%6 = getelementptr inbounds %"struct.DropMe_Impl<[]>"* %0, i32 0, i32 1
%7 = getelementptr inbounds %"struct.DropMe_Impl<[]>"* %0, i32 0, i32 2
%8 = getelementptr inbounds %"struct.DropMe_Impl<[]>"* %0, i32 0, i32 3
invoke void @_ZN16DropMe_Impl.Drop4drop20hf5d4e9dbec49bd1eCaaE(%"struct.DropMe_Impl<[]>"* noalias nocapture dereferenceable(80) %0)
to label %normal-return unwind label %unwind_custom_
normal-return: ; preds = %cond
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %7)
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %6)
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %5)
br label %next
unwind_custom_: ; preds = %cond
%9 = landingpad { i8*, i32 } personality i32 (i32, i32, i64, %"struct.rustrt::libunwind::_Unwind_Exception<[]>[#9]"*, %"enum.rustrt::libunwind::_Unwind_Context<[]>[#9]"*)* @rust_eh_personality
cleanup
store { i8*, i32 } %9, { i8*, i32 }* %1
br label %clean_custom_
resume: ; preds = %clean_custom_
%10 = load { i8*, i32 }* %1
resume { i8*, i32 } %10
clean_custom_: ; preds = %unwind_custom_
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %7)
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %6)
call void @_ZN7DropMsg14glue_drop.146617h5eadde10e6a29588E(%"struct.DropMsg<[]>"* %5)
br label %resume
} I don't know why it's getting pointers to each field before calling |
Nominating. Seems pretty strange. |
I have an approved commit for this already, it's just failing on the pretty-rpass test at the moment. |
I'm OK with disabling the test. Going forward the pretty printer should mainly be used for compiler diagnostics and rustfmt should cover the reformatting use cases, IMO. |
When a struct implements Drop, its fields should still drop in declaration order (just as they do when the struct does not implement Drop). Fixes rust-lang#16492.
When a struct implements Drop, its fields should still drop in declaration order (just as they do when the struct does not implement Drop). Fixes #16492.
internal: Sync from downstream
When a type has no
Drop
impl, it fields appear to be destructed in order of declaration. When a type does have aDrop
impl, that order is apparently reversed. This is very surprising.Example:
Prints:
The text was updated successfully, but these errors were encountered: