From 82f5f65076e604ec70a6e09cdbe8dddb8b3b7c44 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Thu, 17 Oct 2013 21:13:56 -0700 Subject: Move sys::refcount to managed::refcount More progress on #2240 --- src/libstd/managed.rs | 7 +++++++ src/libstd/sys.rs | 10 ---------- 2 files changed, 7 insertions(+), 10 deletions(-) (limited to 'src/libstd') diff --git a/src/libstd/managed.rs b/src/libstd/managed.rs index 57230b2fd24..a27c8aa4a76 100644 --- a/src/libstd/managed.rs +++ b/src/libstd/managed.rs @@ -17,6 +17,13 @@ use ptr::to_unsafe_ptr; pub static RC_MANAGED_UNIQUE : uint = (-2) as uint; pub static RC_IMMORTAL : uint = 0x77777777; +/// Returns the refcount of a shared box (as just before calling this) +#[inline] +pub fn refcount(t: @T) -> uint { + use unstable::raw::Repr; + unsafe { (*t.repr()).ref_count } +} + /// Determine if two shared boxes point to the same object #[inline] pub fn ptr_eq(a: @T, b: @T) -> bool { diff --git a/src/libstd/sys.rs b/src/libstd/sys.rs index 0299ca0b49a..0f38671bfc2 100644 --- a/src/libstd/sys.rs +++ b/src/libstd/sys.rs @@ -13,22 +13,12 @@ #[allow(missing_doc)]; use c_str::ToCStr; -use cast; use libc::size_t; use libc; use repr; use rt::task; use str; -/// Returns the refcount of a shared box (as just before calling this) -#[inline] -pub fn refcount(t: @T) -> uint { - unsafe { - let ref_ptr: *uint = cast::transmute_copy(&t); - *ref_ptr - 1 - } -} - pub fn log_str(t: &T) -> ~str { use rt::io; use rt::io::Decorator; -- cgit 1.4.1-3-g733a5