種類
- インスタンスメソッド (188)
- 特異メソッド (12)
キーワード
- < (3)
- <= (3)
- <=> (3)
- === (3)
- > (3)
- >= (3)
-
alias
_ method (3) - ancestors (3)
-
append
_ features (3) - attr (3)
-
attr
_ accessor (3) -
attr
_ reader (3) -
attr
_ writer (3) - autoload (3)
- autoload? (3)
-
class
_ eval (6) -
class
_ exec (3) -
class
_ variable _ defined? (3) -
class
_ variable _ get (3) -
class
_ variable _ set (3) -
class
_ variables (3) -
const
_ defined? (3) -
const
_ get (3) -
const
_ missing (3) -
const
_ set (3) - constants (6)
-
define
_ method (6) -
extend
_ object (3) - extended (3)
- include (3)
- include? (3)
- included (3)
-
included
_ modules (3) -
instance
_ method (3) -
instance
_ methods (3) -
method
_ added (3) -
method
_ defined? (3) -
method
_ removed (3) -
method
_ undefined (3) -
module
_ eval (6) -
module
_ exec (3) -
module
_ function (3) - name (3)
- nesting (3)
- new (6)
- private (3)
-
private
_ class _ method (3) -
private
_ constant (1) -
private
_ instance _ methods (3) -
private
_ method _ defined? (3) - protected (3)
-
protected
_ instance _ methods (3) -
protected
_ method _ defined? (3) - public (3)
-
public
_ class _ method (3) -
public
_ constant (1) -
public
_ instance _ methods (3) -
public
_ method _ defined? (3) -
remove
_ class _ variable (3) -
remove
_ const (3) -
remove
_ method (3) -
to
_ s (3) -
undef
_ method (3)
検索結果
先頭5件
-
Module
# <(other) -> bool | nil (3) -
比較演算子。self が other の子孫である場合、 true を返します。 self が other の先祖か同一のクラス/モジュールである場合、false を返します。
...
module Foo
end
class Bar
include Foo
end
class Baz < Bar
end
class Qux
end
p Bar < Foo # => true
p Baz < Bar # => true
p Baz < Foo # => true
p Baz < Qux # => nil
p Baz > Qux # => nil
p Foo < Object.new # => in `<': compared with non class/module... -
Module
# <=(other) -> bool | nil (3) -
比較演算子。self が other の子孫であるか、self と other が 同一クラスである場合、 true を返します。 self が other の先祖である場合、false を返します。
...ther の先祖である場合、false を返します。
継承関係にないクラス同士の比較では
nil を返します。
@param other 比較対象のモジュールやクラス
@raise TypeError other がクラスやモジュールではない場合に発生します。
@see Module#<... -
Module
# <=>(other) -> Integer | nil (3) -
self と other の継承関係を比較します。
...します。
other がクラスやモジュールでなければ
nil を返します。
@param other 比較対象のクラスやモジュール
module Foo
end
class Bar
include Foo
end
class Baz < Bar
end
class Qux
end
p Bar <=> Foo # => -1
p Baz <=> Bar # => -1... -
Module
# ===(obj) -> bool (3) -
指定された obj が自身かそのサブクラスのインスタンスであるとき真を返します。 また、obj が自身をインクルードしたクラスかそのサブクラスのインスタンスである場合にも 真を返します。上記のいずれでもない場合に false を返します。
指定された obj が自身かそのサブクラスのインスタンスであるとき真を返します。
また、obj が自身をインクルードしたクラスかそのサブクラスのインスタンスである場合にも
真を返します。上記のいずれでもない場合に false を返します。
言い替えると obj.kind_of?(self) が true の場合、 true を返します。
このメソッドは主に case 文での比較に用いられます。
case ではクラス、モジュールの所属関係をチェックすることになります。
str = String.new
case str
when String # String ===... -
Module
# >(other) -> bool | nil (3) -
比較演算子。 self が other の先祖である場合、true を返します。 self が other の子孫か同一クラスである場合、false を返します。
...一クラスである場合、false を返します。
継承関係にないクラス同士の比較では
nil を返します。
@param other 比較対象のモジュールやクラス
@raise TypeError other がクラスやモジュールではない場合に発生します。
@see Module#<... -
Module
# >=(other) -> bool | nil (3) -
比較演算子。self が other の先祖か同一クラスである場合、 true を返します。 self が other の子孫である場合、false を返します。
...ther の子孫である場合、false を返します。
継承関係にないクラス同士の比較では
nil を返します。
@param other 比較対象のモジュールやクラス
@raise TypeError other がクラスやモジュールではない場合に発生します。
@see Module#<... -
Module
# alias _ method(new , original) -> self (3) -
メソッドの別名を定義します。
メソッドの別名を定義します。
alias との違いは以下の通りです。
* メソッド名は String または Symbol で指定します
* グローバル変数の別名をつけることはできません
また、クラスメソッドに対して使用することはできません。
@param new 新しいメソッド名。String または Symbol で指定します。
@param original 元のメソッド名。String または Symbol で指定します。
@see d:spec/def#alias -
Module
# ancestors -> [Class , Module] (3) -
クラス、モジュールのスーパークラスとインクルードしているモジュール を優先順位順に配列に格納して返します。
...ル
を優先順位順に配列に格納して返します。
module Foo
end
class Bar
include Foo
end
class Baz < Bar
p ancestors
p included_modules
p superclass
end
# => [Baz, Bar, Foo, Object, Kernel]
# => [Foo, Kernel]
# => Bar
@see Module#included_modules... -
Module
# append _ features(module _ or _ class) -> self (3) -
モジュール(あるいはクラス)に self の機能を追加します。
...いはクラス)に self の機能を追加します。
このメソッドは Module#include の実体であり、
include を Ruby で書くと以下のように定義できます。
def include(*modules)
modules.each {|mod|
# append_features はプライベートメソッドなので... -
Module
# attr(name , assignable = false) -> nil (3) -
インスタンス変数読み取りのためのインスタンスメソッド name を定義します。
インスタンス変数読み取りのためのインスタンスメソッド name を定義します。
このメソッドで定義されるアクセスメソッドの定義は次の通りです。
def name
@name
end
省略可能な第 2 引数 assignable が指定されその値が真である
場合には、属性の書き込み用メソッド name= も同時に定義されます。
その定義は次の通りです。
def name=(val)
@name = val
end
@param name String または Symbol で指定します。
@param assignable true を指定するとイン... -
Module
# attr _ accessor(*name) -> nil (3) -
インスタンス変数 name に対する読み取りメソッドと書き込みメソッドの両方を 定義します。
インスタンス変数 name に対する読み取りメソッドと書き込みメソッドの両方を
定義します。
このメソッドで定義されるメソッドの定義は以下の通りです。
def name
@name
end
def name=(val)
@name = val
end
@param name String または Symbol を 1 つ以上指定します。 -
Module
# attr _ reader(*name) -> nil (3) -
インスタンス変数 name の読み取りメソッドを定義します。
インスタンス変数 name の読み取りメソッドを定義します。
このメソッドで定義されるメソッドの定義は以下の通りです。
def name
@name
end
@param name String または Symbol を 1 つ以上指定します。 -
Module
# attr _ writer(*name) -> nil (3) -
インスタンス変数 name への書き込みメソッド (name=) を定義します。
インスタンス変数 name への書き込みメソッド (name=) を定義します。
このメソッドで定義されるメソッドの定義は以下の通りです。
def name=(val)
@name = val
end
@param name String または Symbol を 1 つ以上指定します。 -
Module
# autoload(const _ name , feature) -> nil (3) -
定数 const_name を最初に参照した時に feature を Kernel.#require するように設定します。
定数 const_name を最初に参照した時に feature を Kernel.#require するように設定します。
@param const_name String または Symbol で指定します。
なお、const_name には、"::" 演算子を含めることはできません。
つまり、トップレベルの定数しか指定できません。
@param feature Kernel.#require と同様な方法で autoload する対象を指定する。
@see Kernel.#autoload -
Module
# autoload?(const _ name) -> String | nil (3) -
autoload 定数がまだ定義されてない(ロードされていない) ときにそのパス名を返します。 また、ロード済みなら nil を返します。
autoload 定数がまだ定義されてない(ロードされていない) ときにそのパス名を返します。
また、ロード済みなら nil を返します。
@param const_name String または Symbol で指定します。
@see Kernel.#autoload? -
Module
# class _ eval {|mod| . . . } -> object (3) -
モジュールのコンテキストで文字列 expr またはモジュール自身をブロックパラメータとするブロックを 評価してその結果を返します。
...ことです。
つまり、そのモジュールの定義式の中にあるかのように実行されます。
ただし、ローカル変数は module_eval/class_eval の外側のスコープと共有します。
文字列が与えられ場合には、定数とクラス変数のスコープは......クトレースの表示などを差し替えることができます。
例:
class C
end
a = 1
C.class_eval %Q{
def m # メソッドを動的に定義できる。
return :m, #{a}
end
}
p C.new.m #=> [:m, 1]
@see Object#instance_eval, Module.new... -
Module
# class _ eval(expr , fname = "(eval)" , lineno = 1) -> object (3) -
モジュールのコンテキストで文字列 expr またはモジュール自身をブロックパラメータとするブロックを 評価してその結果を返します。
...ことです。
つまり、そのモジュールの定義式の中にあるかのように実行されます。
ただし、ローカル変数は module_eval/class_eval の外側のスコープと共有します。
文字列が与えられ場合には、定数とクラス変数のスコープは......クトレースの表示などを差し替えることができます。
例:
class C
end
a = 1
C.class_eval %Q{
def m # メソッドを動的に定義できる。
return :m, #{a}
end
}
p C.new.m #=> [:m, 1]
@see Object#instance_eval, Module.new... -
Module
# class _ exec(*args) {|*vars| . . . } -> object (3) -
与えられたブロックを指定された args を引数としてモジュールのコンテキストで評価します。
...llo()
"Hello there!"
end
define_method(:foo) do # ローカル変数がブロックの外側を参照している
c
end
}
t = Thing.new
p t.hello() #=> "Hello there!"
p t.foo() #=> 1
@see Module#module_eval, Module#class_eval... -
Module
# class _ variable _ defined?(name) -> bool (3) -
name で与えられた名前のクラス変数がモジュールに存在する場合 true を 返します。
name で与えられた名前のクラス変数がモジュールに存在する場合 true を
返します。
@param name Symbol か String を指定します。
class Fred
@@foo = 99
end
Fred.class_variable_defined?(:@@foo) #=> true
Fred.class_variable_defined?(:@@bar) #=> false
Fred.class_variable_defined?('@@foo') #=> true
Fred.class_variab... -
Module
# class _ variable _ get(name) -> object (3) -
クラス/モジュールに定義されているクラス変数 name の値を返します。
クラス/モジュールに定義されているクラス変数 name の値を返します。
@param name String または Symbol を指定します。
@raise NameError クラス変数 name が定義されていない場合、発生します。
class Fred
@@foo = 99
end
def Fred.foo
class_variable_get(:@@foo)
end
p Fred.foo #=> 99 -
Module
# class _ variable _ set(name , val) -> object (3) -
クラス/モジュールにクラス変数 name を定義して、その値として val をセットします。val を返します。
クラス/モジュールにクラス変数 name を定義して、その値として
val をセットします。val を返します。
@param name String または Symbol を指定します。
class Fred
@@foo = 99
def foo
@@foo
end
end
def Fred.foo(val)
class_variable_set(:@@foo, val)
end
p Fred.foo(101) # => 101
p Fred.new.foo # => 101 -
Module
# class _ variables -> [String] (3) -
クラス/モジュールに定義されているクラス変数の名前の配列を返します。
...定義されているクラス変数の名前の配列を返します。
スーパークラスやインクルードしているモジュールのクラス変数も含みます。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#constants... -
Module
# class _ variables -> [Symbol] (3) -
クラス/モジュールに定義されているクラス変数の名前の配列を返します。
...定義されているクラス変数の名前の配列を返します。
スーパークラスやインクルードしているモジュールのクラス変数も含みます。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#constants... -
Module
# const _ defined?(name) -> bool (3) -
モジュールに name で指定される名前の定数が定義されている時真 を返します。
...)
@param name String, Symbol で指定される定数名。
module Kernel
FOO = 1
end
# Object は include したモジュールの定数に対しても
# true を返す
p Object.const_defined?(:FOO) # => true
module Bar
BAR = 1
end
class Object
include Bar
end... -
Module
# const _ defined?(name , inherit = true) -> bool (3) -
モジュールに name で指定される名前の定数が定義されている時真 を返します。
...定義された定数は対象にはなりません。
module Kernel
FOO = 1
end
# Object は include したモジュールの定数に対しても
# true を返す
p Object.const_defined?(:FOO) # => true
module Bar
BAR = 1
end
class Object
include Bar
end... -
Module
# const _ get(name) -> object (3) -
モジュールに定義されている name で指定される名前の定数の値を 取り出します。
...を
取り出します。
Module#const_defined? と違って Object を特別扱いすることはありません。
@param name 定数名。String か Symbol で指定します。
@raise NameError 定数が定義されていないときに発生します。
module Bar
BAR = 1
end
cla... -
Module
# const _ get(name , inherit = true) -> object (3) -
モジュールに定義されている name で指定される名前の定数の値を 取り出します。
...モジュールに定義されている name で指定される名前の定数の値を
取り出します。
Module#const_defined? と違って Object を特別扱いすることはありません。
@param name 定数名。String か Symbol で指定します。
@param inherit false を指定......で
定義された定数は対象にはなりません。
@raise NameError 定数が定義されていないときに発生します。
module Bar
BAR = 1
end
class Object
include Bar
end
# Object では include されたモジュールに定義された定数を見付け... -
Module
# const _ missing(name) (3) -
定義されていない定数を参照したときに Ruby インタプリタが このメソッドを呼びます。
定義されていない定数を参照したときに Ruby インタプリタが
このメソッドを呼びます。
@param name 参照した定数名の Symbol
@raise NameError このメソッドを呼び出した場合、デフォルトで発生する例外
class Foo
def Foo.const_missing(id)
warn "undefined constant #{id.inspect}"
end
Bar
end
Foo::Bar
# => undefined constant :Bar
undefined constan... -
Module
# const _ set(name , value) -> object (3) -
モジュールに name で指定された名前の定数を value とい う値として定義し、value を返します。
モジュールに name で指定された名前の定数を value とい
う値として定義し、value を返します。
そのモジュールにおいてすでにその名前の定数が定義されている場合、警
告メッセージが出力されます。
@param name Symbol,String で定数の名前を指定します。
@param value セットしたい値を指定します。 -
Module
# constants -> [String] (3) -
そのモジュール(またはクラス)で定義されている定数名の配列を返します。 スーパークラスやインクルードしているモジュールの定数も含みます。
...。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#class_variables
Module.constants と Module#constants の違い
# 出力の簡略化のため起動時の定数一覧を取得して後で差し引く
$clist = Module.constants......p Module.constants - $clist # => ["BAR", "Bar", "Foo"]
class Baz
# Baz は定数を含まない
p constants - $clist # => []
# ネストしたクラスでは、外側のクラスで定義した定数は
# 参照可能なので、BAR は、Module.co......nstants には含まれる
# (クラス Baz も Bar の定数なので同様)
p Module.constants - $clist # => ["BAR", "Baz", "Bar", "Foo"]
end
end... -
Module
# constants(inherit = true) -> [Symbol] (3) -
そのモジュール(またはクラス)で定義されている定数名の配列を返します。
...ん。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#class_variables
Module.constants と Module#constants の違い
# 出力の簡略化のため起動時の定数一覧を取得して後で差し引く
$clist = Module.constants......p Module.constants - $clist # => [:BAR, :Bar, :Foo]
class Baz
# Baz は定数を含まない
p constants - $clist # => []
# ネストしたクラスでは、外側のクラスで定義した定数は
# 参照可能なので、BAR は、Module.con......stants には含まれる
# (クラス Baz も Bar の定数なので同様)
p Module.constants - $clist # => [:BAR, :Baz, :Foo, :Bar]
end
end... -
Module
# define _ method(name) { . . . } -> Proc (3) -
インスタンスメソッド name を定義します。
インスタンスメソッド name を定義します。
ブロックを与えた場合、定義したメソッドの実行時にブロックが
レシーバクラスのインスタンスの上で Object#instance_eval されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod の
いずれかのインスタンスを指定します。
@return 引数 method を与えたときはそれを、ブロック付きで
呼びだしたときはブロックを Proc 化したオブジェクトを、
そ... -
Module
# define _ method(name , method) -> Proc | Method | UnboundMethod (3) -
インスタンスメソッド name を定義します。
インスタンスメソッド name を定義します。
ブロックを与えた場合、定義したメソッドの実行時にブロックが
レシーバクラスのインスタンスの上で Object#instance_eval されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod の
いずれかのインスタンスを指定します。
@return 引数 method を与えたときはそれを、ブロック付きで
呼びだしたときはブロックを Proc 化したオブジェクトを、
そ... -
Module
# extend _ object(module) -> Module (3) -
Object#extend の実体です。オブジェクトにモジュールの機能を追加します。
...def extend(*modules)
modules.each {|mod| mod.__send__ :extend_object, self }
end
extend_object のデフォルトの実装では、self に定義されて
いるメソッドを object の特異メソッドとして追加します。
@param module Enumerable など Module クラスのイ......ンスタンスを指定します。
@return module で指定されたモジュールを返します。... -
Module
# extended(class _ or _ module) -> () (3) -
self が他のオブジェクト に Object#extend されたときに 呼ばれます。引数には extend を行ったオブジェクトが渡されます。
...たときに
呼ばれます。引数には extend を行ったオブジェクトが渡されます。
@param class_or_module Object#extend を行ったオブジェクト
module Foo
def self.extended(mod)
p "#{mod} extend #{self}"
end
end
Object.new.extend Foo
# => "#<Objec... -
Module
# include(*mod) -> self (3) -
モジュール mod をインクルードします。
...ドします。
@param mod Module のインスタンス( Enumerable など)を指定します。
@raise ArgumentError 継承関係が循環してしまうような include を行った場合に発生します。
module M
end
module M2
include M
end
module M
include M2
end
実......モジュールのほうが
先に行われます
(上の例の Module#ancestors の結果がメソッド探索の順序です)。
同じモジュールを二回以上 include すると二回目以降は無視されます。
module M
end
class C1
include M
end
class C2 < C1
inclu... -
Module
# include?(mod) -> bool (3) -
self かその親クラス / 親モジュールがモジュール mod を インクルードしていれば true を返します。
...その親クラス / 親モジュールがモジュール mod を
インクルードしていれば true を返します。
@param mod Module を指定します。
module M
end
class C1
include M
end
class C2 < C1
end
p C1.include?(M) # => true
p C2.include?(M) # => true... -
Module
# included(class _ or _ module) -> () (3) -
self が Module#include されたときに対象のクラスまたはモジュー ルを引数にしてインタプリタがこのメソッドを呼び出します。
...self が Module#include されたときに対象のクラスまたはモジュー
ルを引数にしてインタプリタがこのメソッドを呼び出します。
@param class_or_module Module#include を実行したオブジェクト
module Foo
def self.included(mod)
p "#{mod} in...
