Struct magnus::Range

source ·
pub struct Range(/* private fields */);
Expand description

Wrapper type for a Value known to be an instance of Ruby’s Range class.

See the ReprValue and Object traits for additional methods available on this type. See Ruby for methods to create a Range.

Implementations§

source§

impl Range

source

pub fn from_value(val: Value) -> Option<Self>

Return Some(Range) if val is an Range, None otherwise.

§Examples
use magnus::eval;

assert!(magnus::Range::from_value(eval("2..7").unwrap()).is_some());
assert!(magnus::Range::from_value(eval("1").unwrap()).is_none());
source

pub fn new<T, U>(beg: T, end: U, excl: bool) -> Result<Self, Error>
where T: IntoValue, U: IntoValue,

Create a new Range.

Returns Err if beg and end are not comparable.

§Panics

Panics if called from a non-Ruby thread. See Ruby::range_new for the non-panicking version.

§Examples
use magnus::rb_assert;

let range = magnus::Range::new(2, 7, false).unwrap();
rb_assert!("range == (2..7)", range);
use magnus::rb_assert;

let range = magnus::Range::new(2, 7, true).unwrap();
rb_assert!("range == (2...7)", range);
source

pub fn beg<T>(self) -> Result<T, Error>
where T: TryConvert,

Return the value that defines the beginning of the range, converting it to a T.

Errors if the conversion fails.

§Examples
use magnus::eval;

let range: magnus::Range = eval("2..7").unwrap();
assert_eq!(range.beg::<i64>().unwrap(), 2);
source

pub fn end<T>(self) -> Result<T, Error>
where T: TryConvert,

Return the value that defines the end of the range, converting it to a T.

Errors if the conversion fails.

§Examples
use magnus::eval;

let range: magnus::Range = eval("2..7").unwrap();
assert_eq!(range.end::<i64>().unwrap(), 7);
source

pub fn excl(self) -> bool

Returns true if the range excludes its end value, false if the end value is included.

§Examples
use magnus::eval;

let range: magnus::Range = eval("2..7").unwrap();
assert_eq!(range.excl(), false);
source

pub fn beg_len(self, length: usize) -> Result<(usize, usize), Error>

Given a total length, returns a beginning index and length of the range within that total length.

Returns Err if self is a non-numerical range, or the range is out of range for length.

§Examples
use magnus::eval;

let range: magnus::Range = eval("2..").unwrap();
assert_eq!(range.beg_len(10).unwrap(), (2, 8));
use magnus::eval;

let range: magnus::Range = eval("..7").unwrap();
assert_eq!(range.beg_len(10).unwrap(), (0, 8));
use magnus::eval;

let range: magnus::Range = eval("-3..-1").unwrap();
assert_eq!(range.beg_len(10).unwrap(), (7, 3));
source

pub fn to_range_with_len(self, length: usize) -> Result<StdRange<usize>, Error>

Given a total length, converts the Ruby Range to a Rust std::ops::Range.

length is required to account for Ruby conventions such as a range from -2..-1 returning the end of a collection.

Returns Err if self is a non-numerical range, or the range is out of range for length.

§Examples
use magnus::eval;

// Ruby's .. range is inclusive
let range: magnus::Range = eval("2..7").unwrap();
// Rust's .. range in exclusive
assert_eq!(range.to_range_with_len(10).unwrap(), 2..8);
use magnus::eval;

let range: magnus::Range = eval("2..").unwrap();
assert_eq!(range.to_range_with_len(10).unwrap(), 2..10);
use magnus::eval;

let range: magnus::Range = eval("..7").unwrap();
assert_eq!(range.to_range_with_len(10).unwrap(), 0..8);
use magnus::eval;

let range: magnus::Range = eval("-3..-1").unwrap();
assert_eq!(range.to_range_with_len(10).unwrap(), 7..10);

Trait Implementations§

source§

impl Clone for Range

source§

fn clone(&self) -> Range

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 Range

source§

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

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

impl Display for Range

source§

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

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

impl IntoValue for Range

source§

fn into_value_with(self, handle: &Ruby) -> Value

Convert self into Value.
source§

fn into_value(self) -> Value

Convert self into Value. Read more
source§

unsafe fn into_value_unchecked(self) -> Value

Convert self into Value. Read more
source§

impl Object for Range

source§

fn define_singleton_method<M>(self, name: &str, func: M) -> Result<(), Error>
where M: Method,

Define a singleton method in self’s scope. Read more
source§

fn ivar_get<T, U>(self, name: T) -> Result<U, Error>
where T: IntoId, U: TryConvert,

Get the value for the instance variable name within self’s scope. Read more
source§

fn ivar_set<T, U>(self, name: T, value: U) -> Result<(), Error>
where T: IntoId, U: IntoValue,

Set the value for the instance variable name within self’s scope. Read more
source§

fn singleton_class(self) -> Result<RClass, Error>

Finds or creates the singleton class of self. Read more
source§

fn extend_object(self, module: RModule) -> Result<(), Error>

Extend self with module. Read more
source§

impl ReprValue for Range

source§

fn as_value(self) -> Value

Return self as a Value.
source§

fn is_nil(self) -> bool

Returns whether self is Ruby’s nil value. Read more
source§

fn equal<T>(self, other: T) -> Result<bool, Error>
where T: ReprValue,

Checks for equality, delegating to the Ruby method #==. Read more
source§

fn eql<T>(self, other: T) -> Result<bool, Error>
where T: ReprValue,

Checks for equality, delegating to the Ruby method #eql?. Read more
source§

fn hash(self) -> Result<Integer, Error>

Returns an integer non-uniquely identifying self. Read more
source§

fn class(self) -> RClass

Returns the class that self is an instance of. Read more
source§

fn is_frozen(self) -> bool

Returns whether self is ‘frozen’. Read more
source§

fn check_frozen(self) -> Result<(), Error>

Returns an error if self is ‘frozen’. Read more
source§

fn freeze(self)

Mark self as frozen. Read more
source§

fn to_bool(self) -> bool

Convert self to a bool, following Ruby’s rules of false and nil as boolean false and everything else boolean true. Read more
source§

fn funcall<M, A, T>(self, method: M, args: A) -> Result<T, Error>
where M: IntoId, A: ArgList, T: TryConvert,

Call the method named method on self with args. Read more
source§

fn funcall_public<M, A, T>(self, method: M, args: A) -> Result<T, Error>
where M: IntoId, A: ArgList, T: TryConvert,

Call the public method named method on self with args. Read more
source§

fn check_funcall<M, A, T>(self, method: M, args: A) -> Option<Result<T, Error>>
where M: IntoId, A: ArgList, T: TryConvert,

If self responds to the method named method, call it with args. Read more
source§

fn funcall_with_block<M, A, T>( self, method: M, args: A, block: Proc ) -> Result<T, Error>
where M: IntoId, A: ArgList, T: TryConvert,

Call the method named method on self with args and block. Read more
source§

fn block_call<M, A, R, T>( self, method: M, args: A, block: fn(_: &[Value], _: Option<Proc>) -> R ) -> Result<T, Error>
where M: IntoId, A: ArgList, R: BlockReturn, T: TryConvert,

Call the method named method on self with args and block. Read more
source§

fn respond_to<M>(self, method: M, include_private: bool) -> Result<bool, Error>
where M: IntoId,

Check if self responds to the given Ruby method. Read more
source§

fn to_r_string(self) -> Result<RString, Error>

Convert self to a Ruby String. Read more
source§

unsafe fn to_s(&self) -> Result<Cow<'_, str>, Error>

Convert self to a Rust string. Read more
source§

fn inspect(self) -> String

Convert self to its Ruby debug representation. Read more
source§

unsafe fn classname(&self) -> Cow<'_, str>

Return the name of self’s class. Read more
source§

fn is_kind_of<T>(self, class: T) -> bool
where T: ReprValue + Module,

Returns whether or not self is an instance of class. Read more
source§

fn enumeratorize<M, A>(self, method: M, args: A) -> Enumerator
where M: IntoSymbol, A: ArgList,

Generate an Enumerator from method on self, passing args to method. Read more
source§

impl TryConvert for Range

source§

fn try_convert(val: Value) -> Result<Self, Error>

Convert val into Self.
source§

impl Copy for Range

Auto Trait Implementations§

§

impl Freeze for Range

§

impl RefUnwindSafe for Range

§

impl Send for Range

§

impl Sync for Range

§

impl Unpin for Range

§

impl UnwindSafe for Range

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> AsRawValue for T
where T: ReprValue,

source§

fn as_raw(self) -> u64

Available on crate feature rb-sys only.
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> Inspect for T
where T: Debug,

source§

fn inspect(&self) -> String

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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.
source§

impl<T> BlockReturn for T
where T: BlockReturn,

source§

impl<T> Locate for T
where T: ReprValue,

source§

impl<T> Mark for T
where T: ReprValue,

source§

impl<T> ReturnValue for T
where T: ReturnValue,