cover?(obj) -> bool
[permalink][rdoc][edit]-
obj が範囲内に含まれている時に true を返します。
Range#include? と異なり <=> メソッドによる演算により範囲内かどうかを判定します。 Range#include? は原則として離散値を扱い、 Range#cover? は連続値を扱います。(数値については、例外として Range#include? も連続的に扱います。)
Range#exclude_end?がfalseなら「begin <= obj <= end」を、 trueなら「begin <= obj < end」を意味します。
- [PARAM] obj:
- 比較対象のオブジェクトを指定します。
(1.1..2.3).include?(1.0) # => false (1.1..2.3).include?(1.1) # => true (1.1..2.3).include?(1.555) # => true (1.1..2.3).cover?(1.0) # => false (1.1..2.3).cover?(1.1) # => true (1.1..2.3).cover?(1.555) # => true
('b'..'d').include?('d') # => true ('b'..'d').include?('ba') # => false ('b'..'d').cover?('d') # => true ('b'..'d').cover?('ba') # => true
require 'date' (Date.today - 365 .. Date.today + 365).include?(Date.today) #=> true (Date.today - 365 .. Date.today + 365).include?(DateTime.now) #=> false (Date.today - 365 .. Date.today + 365).cover?(Date.today) #=> true (Date.today - 365 .. Date.today + 365).cover?(DateTime.now) #=> true
cover?(range) -> bool
[permalink][rdoc][edit]-
2.6 以降の cover? は、Range#include? や Range#=== と異なり、引数に Range オブジェクトを指定して比較できます。
引数が Range オブジェクトの場合、引数の範囲が self の範囲に含まれる時に true を返します。
- [PARAM] range:
- 比較対象の Range クラスのインスタンスを指定します。
(1..5).cover?(2..3) #=> true (1..5).cover?(0..6) #=> false (1..5).cover?(1...6) #=> true
「(a..b).cover?(c...d)」のように終端を含まない Range オブジェクトが引数に渡されており、「a <= c && b < d」を満たし、cが数値ではない(つまり引数の Range の終端を求めるために succ メソッドの呼び出しが必要な)場合、パフォーマンスの問題が起きる可能性があります。
p ('aaaaa'..'zzzzy').cover?('aaaaa'...'zzzzz') # => true
[SEE_ALSO] Range#include?, Range#===