Struct rutie::AnyObject

source ·
#[repr(C)]
pub struct AnyObject { /* private fields */ }
Expand description

Representation of any Ruby object while its type is unknown

As Ruby is a dynamically typed language, at some points Rutie does not know the exact Ruby type of the object, for example:

  • Retrieving an object from array;

  • Retrieving an object from hash;

  • Receiving arguments to a method;

  • Initializing a new instance of a non-built-in class.

In these cases you should cast AnyObject to the required type.

Examples

Retrieving an object from Array

use rutie::{Array, Fixnum, Object, VM};

let array = Array::new().push(Fixnum::new(1));
let value = array.at(0).try_convert_to::<Fixnum>(); // `Array::at()` returns `AnyObject`

assert_eq!(value, Ok(Fixnum::new(1)));

Retrieving an object from Hash

use rutie::{Fixnum, Hash, Object, Symbol, VM};

let mut hash = Hash::new();

hash.store(Symbol::new("key"), Fixnum::new(1));

// `Hash::at()` returns `AnyObject`
let value = hash.at(&Symbol::new("key")).try_convert_to::<Fixnum>();

assert_eq!(value, Ok(Fixnum::new(1)));

You can find more examples in Class, Object and VerifiedObject documentation.

Methods from Deref<Target = Value>§

source

pub fn is_true(&self) -> bool

source

pub fn is_false(&self) -> bool

source

pub fn is_nil(&self) -> bool

source

pub fn is_node(&self) -> bool

source

pub fn is_undef(&self) -> bool

source

pub fn is_symbol(&self) -> bool

source

pub fn is_fixnum(&self) -> bool

source

pub fn is_flonum(&self) -> bool

source

pub fn is_frozen(&self) -> bool

source

pub fn ty(&self) -> ValueType

Trait Implementations§

source§

impl AsRef<AnyObject> for AnyObject

source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl AsRef<Value> for AnyObject

source§

fn as_ref(&self) -> &Value

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Borrow<Value> for AnyObject

source§

fn borrow(&self) -> &Value

Immutably borrows from an owned value. Read more
source§

impl Clone for AnyObject

source§

fn clone(&self) -> AnyObject

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for AnyObject

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T: Object> From<&T> for AnyObject

source§

fn from(value: &T) -> Self

Converts to this type from the input type.
source§

impl From<Value> for AnyObject

source§

fn from(value: Value) -> Self

Converts to this type from the input type.
source§

impl FromIterator<AnyObject> for Array

Converts an iterator into Array.

Examples

use rutie::{Array, Fixnum, Object, VM};

let array: Array = (1..6)
    .map(|num| num * 2)
    .map(|num| Fixnum::new(num).to_any_object())
    .collect();

assert_eq!(array.length(), 5);

for i in 0..5 {
    let expected_number = (i + 1) * 2;

    assert_eq!(array.at(i).try_convert_to::<Fixnum>().unwrap().to_i64(), expected_number);
}
source§

fn from_iter<I: IntoIterator<Item = AnyObject>>(iter: I) -> Self

Creates a value from an iterator. Read more
source§

impl Into<AnyObject> for AnyException

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Array

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Binding

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Boolean

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Class

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Encoding

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Enumerator

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Fixnum

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Float

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Hash

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Integer

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Module

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for NilClass

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Proc

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for RString

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Symbol

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<AnyObject> for Thread

source§

fn into(self) -> AnyObject

Converts this type into the (usually inferred) input type.
source§

impl Into<Value> for AnyObject

source§

fn into(self) -> Value

Converts this type into the (usually inferred) input type.
source§

impl Object for AnyObject

source§

fn value(&self) -> Value

Returns internal value of current object. Read more
source§

fn class(&self) -> Class

Returns a class of current object. Read more
source§

fn singleton_class(&self) -> Class

Returns a singleton class of current object. Read more
source§

fn get_data<'a, T>(&'a self, wrapper: &'a dyn DataTypeWrapper<T>) -> &T

Gets an immutable reference to the Rust structure which is wrapped into a Ruby object. Read more
source§

fn get_data_mut<'a, T>( &'a mut self, wrapper: &'a dyn DataTypeWrapper<T> ) -> &mut T

Gets a mutable reference to the Rust structure which is wrapped into a Ruby object.
source§

fn define<F: Fn(&mut Self)>(&mut self, f: F) -> &Self

Wraps calls to the object. Read more
source§

fn define_method<I: Object, O: Object>( &mut self, name: &str, callback: Callback<I, O> )

Defines an instance method for the given class or object. Read more
source§

fn define_private_method<I: Object, O: Object>( &mut self, name: &str, callback: Callback<I, O> )

Defines a private instance method for the given class or object. Read more
source§

fn define_singleton_method<I: Object, O: Object>( &mut self, name: &str, callback: Callback<I, O> )

Defines a class method for given class or singleton method for object. Read more
source§

fn def<I: Object, O: Object>(&mut self, name: &str, callback: Callback<I, O>)

An alias for define_method (similar to Ruby syntax def some_method).
source§

fn def_private<I: Object, O: Object>( &mut self, name: &str, callback: Callback<I, O> )

An alias for define_private_method (similar to Ruby syntax private def some_method).
source§

fn def_self<I: Object, O: Object>( &mut self, name: &str, callback: Callback<I, O> )

An alias for define_singleton_method (similar to Ruby def self.some_method).
source§

unsafe fn send(&self, method: &str, arguments: &[AnyObject]) -> AnyObject

Calls a given method on an object similarly to Ruby Object#send method Read more
source§

fn equals<T: Object>(&self, other: &T) -> bool

Alias for Ruby’s == Read more
source§

fn case_equals<T: Object>(&self, other: &T) -> bool

Alias for Ruby’s === Read more
source§

fn is_eql<T: Object>(&self, other: &T) -> bool

Alias for Ruby’s eql? Read more
source§

fn is_equal<T: Object>(&self, other: &T) -> bool

Alias for Ruby’s equal? Read more
source§

fn respond_to(&self, method: &str) -> bool

Checks whether the object responds to given method Read more
source§

fn protect_send( &self, method: &str, arguments: &[AnyObject] ) -> Result<AnyObject, AnyException>

protect_send returns Result<AnyObject, AnyObject> Read more
source§

fn protect_public_send( &self, method: &str, arguments: &[AnyObject] ) -> Result<AnyObject, AnyException>

protect_public_send returns Result<AnyObject, AnyObject> Read more
source§

fn is_nil(&self) -> bool

Checks whether the object is nil Read more
source§

fn to_any_object(&self) -> AnyObject

Converts struct to AnyObject Read more
source§

fn instance_variable_get(&self, variable: &str) -> AnyObject

Gets an instance variable of object Read more
source§

fn instance_variable_set<T: Object>( &mut self, variable: &str, value: T ) -> AnyObject

Sets an instance variable for object Read more
source§

fn is_frozen(&self) -> bool

Returns the freeze status of the object. Read more
source§

fn freeze(&mut self) -> Self

Prevents further modifications to the object. Read more
source§

unsafe fn to<T: Object>(&self) -> T

Unsafely casts current object to the specified Ruby type Read more
source§

fn try_convert_to<T: VerifiedObject>(&self) -> Result<T, AnyException>

Safely casts current object to the specified Ruby type Read more
source§

fn ty(&self) -> ValueType

Determines the value type of the object Read more
source§

impl PartialEq for AnyObject

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl TryConvert<AnyObject> for AnyException

§

type Nil = NilClass

The type returned in the event of a conversion error.
source§

fn try_convert(obj: AnyObject) -> Result<Self, NilClass>

Performs the conversion.
source§

impl TryConvert<AnyObject> for RString

Implicit or nil conversion

Examples

use rutie::{RString, Fixnum, VM, TryConvert, NilClass, Object};

let four = Fixnum::new(4);
let result = RString::try_convert(four.to_any_object());

assert_eq!(result, Err(NilClass::new()));

let five = RString::new_utf8("5");
let result2 = RString::try_convert(five.to_any_object());

if let Ok(r) = result2 {
  assert_eq!(r.to_str(), "5")
} else {
  unreachable!()
}

Ruby:

four = 4
result = String.try_convert(four)

result == nil

five = "5"
result = String.try_convert(five)

result == "5"
§

type Nil = NilClass

The type returned in the event of a conversion error.
source§

fn try_convert(obj: AnyObject) -> Result<Self, NilClass>

Performs the conversion.
source§

impl VerifiedObject for AnyObject

source§

impl Deref for AnyObject

§

type Target = Value

The resulting type after dereferencing.
source§

fn deref(&self) -> &Value

Dereferences the value.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.