diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:13 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:13 +0000 |
commit | 218caa410aa38c29984be31a5229b9fa717560ee (patch) | |
tree | c54bd55eeb6e4c508940a30e94c0032fbd45d677 /src/test/incremental/reorder_vtable.rs | |
parent | Releasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff) | |
download | rustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip |
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/incremental/reorder_vtable.rs')
-rw-r--r-- | src/test/incremental/reorder_vtable.rs | 41 |
1 files changed, 0 insertions, 41 deletions
diff --git a/src/test/incremental/reorder_vtable.rs b/src/test/incremental/reorder_vtable.rs deleted file mode 100644 index 8dacba633..000000000 --- a/src/test/incremental/reorder_vtable.rs +++ /dev/null @@ -1,41 +0,0 @@ -// revisions:rpass1 rpass2 - -// This test case makes sure re-order the methods in a vtable will -// trigger recompilation of codegen units that instantiate it. -// -// See https://github.com/rust-lang/rust/issues/89598 - -trait Foo { - #[cfg(rpass1)] - fn method1(&self) -> u32; - - fn method2(&self) -> u32; - - #[cfg(rpass2)] - fn method1(&self) -> u32; -} - -impl Foo for u32 { - fn method1(&self) -> u32 { 17 } - fn method2(&self) -> u32 { 42 } -} - -fn main() { - // Before #89598 was fixed, the vtable allocation would be cached during - // a MIR optimization pass and then the codegen pass for the main object - // file would not register a dependency on it (because of the missing - // dep-tracking). - // - // In the rpass2 session, the main object file would not be re-compiled, - // thus the mod1::foo(x) call would pass in an outdated vtable, while the - // mod1 object would expect the new, re-ordered vtable, resulting in a - // call to the wrong method. - let x: &dyn Foo = &0u32; - assert_eq!(mod1::foo(x), 17); -} - -mod mod1 { - pub(super) fn foo(x: &dyn super::Foo) -> u32 { - x.method1() - } -} |