// Copyright 2012 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. //! Operations on managed box types use ptr::to_unsafe_ptr; #[cfg(not(test))] use cmp::*; 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 - 1 } } /// Determine if two shared boxes point to the same object #[inline] pub fn ptr_eq(a: @T, b: @T) -> bool { let (a_ptr, b_ptr): (*T, *T) = (to_unsafe_ptr(&*a), to_unsafe_ptr(&*b)); a_ptr == b_ptr } /// Determine if two mutable shared boxes point to the same object #[inline] pub fn mut_ptr_eq(a: @mut T, b: @mut T) -> bool { let (a_ptr, b_ptr): (*T, *T) = (to_unsafe_ptr(&*a), to_unsafe_ptr(&*b)); a_ptr == b_ptr } #[cfg(not(test))] impl Eq for @T { #[inline] fn eq(&self, other: &@T) -> bool { *(*self) == *(*other) } #[inline] fn ne(&self, other: &@T) -> bool { *(*self) != *(*other) } } #[cfg(not(test))] impl Eq for @mut T { #[inline] fn eq(&self, other: &@mut T) -> bool { *(*self) == *(*other) } #[inline] fn ne(&self, other: &@mut T) -> bool { *(*self) != *(*other) } } #[cfg(not(test))] impl Ord for @T { #[inline] fn lt(&self, other: &@T) -> bool { *(*self) < *(*other) } #[inline] fn le(&self, other: &@T) -> bool { *(*self) <= *(*other) } #[inline] fn ge(&self, other: &@T) -> bool { *(*self) >= *(*other) } #[inline] fn gt(&self, other: &@T) -> bool { *(*self) > *(*other) } } #[cfg(not(test))] impl Ord for @mut T { #[inline] fn lt(&self, other: &@mut T) -> bool { *(*self) < *(*other) } #[inline] fn le(&self, other: &@mut T) -> bool { *(*self) <= *(*other) } #[inline] fn ge(&self, other: &@mut T) -> bool { *(*self) >= *(*other) } #[inline] fn gt(&self, other: &@mut T) -> bool { *(*self) > *(*other) } } #[cfg(not(test))] impl TotalOrd for @T { #[inline] fn cmp(&self, other: &@T) -> Ordering { (**self).cmp(*other) } } #[cfg(not(test))] impl TotalOrd for @mut T { #[inline] fn cmp(&self, other: &@mut T) -> Ordering { (**self).cmp(*other) } } #[cfg(not(test))] impl TotalEq for @T { #[inline] fn equals(&self, other: &@T) -> bool { (**self).equals(*other) } } #[cfg(not(test))] impl TotalEq for @mut T { #[inline] fn equals(&self, other: &@mut T) -> bool { (**self).equals(*other) } } #[test] fn test() { let x = @3; let y = @3; assert!((ptr_eq::(x, x))); assert!((ptr_eq::(y, y))); assert!((!ptr_eq::(x, y))); assert!((!ptr_eq::(y, x))); } #[test] fn refcount_test() { use clone::Clone; let x = @3; assert_eq!(refcount(x), 1); let y = x.clone(); assert_eq!(refcount(x), 2); assert_eq!(refcount(y), 2); }