a87a0d089e
Relevant commit messages from squashed history in order: Add initial version of ThinBox update test to actually capture failure swap to middle ptr impl based on matthieu-m's design Fix stack overflow in debug impl The previous version would take a `&ThinBox<T>` and deref it once, which resulted in a no-op and the same type, which it would then print causing an endless recursion. I've switched to calling `deref` by name to let method resolution handle deref the correct number of times. I've also updated the Drop impl for good measure since it seemed like it could be falling prey to the same bug, and I'll be adding some tests to verify that the drop is happening correctly. add test to verify drop is behaving add doc examples and remove unnecessary Pointee bounds ThinBox: use NonNull ThinBox: tests for size Apply suggestions from code review Co-authored-by: Alphyr <47725341+a1phyr@users.noreply.github.com> use handle_alloc_error and fix drop signature update niche and size tests add cfg for allocating APIs check null before calculating offset add test for zst and trial usage prevent optimizer induced ub in drop and cleanup metadata gathering account for arbitrary size and alignment metadata Thank you nika and thomcc! Update library/alloc/src/boxed/thin.rs Co-authored-by: Josh Triplett <josh@joshtriplett.org> Update library/alloc/src/boxed/thin.rs Co-authored-by: Josh Triplett <josh@joshtriplett.org>
86 lines
2.2 KiB
Rust
86 lines
2.2 KiB
Rust
#![feature(allocator_api)]
|
|
#![feature(alloc_layout_extra)]
|
|
#![feature(assert_matches)]
|
|
#![feature(box_syntax)]
|
|
#![feature(cow_is_borrowed)]
|
|
#![feature(const_box)]
|
|
#![feature(const_convert)]
|
|
#![feature(const_cow_is_borrowed)]
|
|
#![feature(const_heap)]
|
|
#![feature(const_intrinsic_copy)]
|
|
#![feature(const_mut_refs)]
|
|
#![feature(const_nonnull_slice_from_raw_parts)]
|
|
#![feature(const_ptr_write)]
|
|
#![feature(const_try)]
|
|
#![feature(core_intrinsics)]
|
|
#![feature(drain_filter)]
|
|
#![feature(exact_size_is_empty)]
|
|
#![feature(new_uninit)]
|
|
#![feature(pattern)]
|
|
#![feature(trusted_len)]
|
|
#![feature(try_reserve_kind)]
|
|
#![feature(unboxed_closures)]
|
|
#![feature(associated_type_bounds)]
|
|
#![feature(binary_heap_into_iter_sorted)]
|
|
#![feature(binary_heap_drain_sorted)]
|
|
#![feature(slice_ptr_get)]
|
|
#![feature(binary_heap_retain)]
|
|
#![feature(binary_heap_as_slice)]
|
|
#![feature(inplace_iteration)]
|
|
#![feature(iter_advance_by)]
|
|
#![feature(round_char_boundary)]
|
|
#![feature(slice_group_by)]
|
|
#![feature(slice_partition_dedup)]
|
|
#![feature(string_remove_matches)]
|
|
#![feature(const_btree_new)]
|
|
#![feature(const_default_impls)]
|
|
#![feature(const_trait_impl)]
|
|
#![feature(const_str_from_utf8)]
|
|
#![feature(nonnull_slice_from_raw_parts)]
|
|
#![feature(panic_update_hook)]
|
|
#![feature(slice_flatten)]
|
|
#![feature(thin_box)]
|
|
|
|
use std::collections::hash_map::DefaultHasher;
|
|
use std::hash::{Hash, Hasher};
|
|
|
|
mod arc;
|
|
mod binary_heap;
|
|
mod borrow;
|
|
mod boxed;
|
|
mod btree_set_hash;
|
|
mod const_fns;
|
|
mod cow_str;
|
|
mod fmt;
|
|
mod heap;
|
|
mod linked_list;
|
|
mod rc;
|
|
mod slice;
|
|
mod str;
|
|
mod string;
|
|
mod thin_box;
|
|
mod vec;
|
|
mod vec_deque;
|
|
|
|
fn hash<T: Hash>(t: &T) -> u64 {
|
|
let mut s = DefaultHasher::new();
|
|
t.hash(&mut s);
|
|
s.finish()
|
|
}
|
|
|
|
// FIXME: Instantiated functions with i128 in the signature is not supported in Emscripten.
|
|
// See https://github.com/kripken/emscripten-fastcomp/issues/169
|
|
#[cfg(not(target_os = "emscripten"))]
|
|
#[test]
|
|
fn test_boxed_hasher() {
|
|
let ordinary_hash = hash(&5u32);
|
|
|
|
let mut hasher_1 = Box::new(DefaultHasher::new());
|
|
5u32.hash(&mut hasher_1);
|
|
assert_eq!(ordinary_hash, hasher_1.finish());
|
|
|
|
let mut hasher_2 = Box::new(DefaultHasher::new()) as Box<dyn Hasher>;
|
|
5u32.hash(&mut hasher_2);
|
|
assert_eq!(ordinary_hash, hasher_2.finish());
|
|
}
|