種類
- インスタンスメソッド (101)
- 特異メソッド (3)
ライブラリ
- ビルトイン (104)
キーワード
- < (3)
- <=> (3)
- === (3)
- ancestors (3)
-
class
_ eval (6) -
class
_ exec (3) -
class
_ variable _ get (3) -
class
_ variable _ set (3) -
class
_ variables (3) -
const
_ defined? (3) -
const
_ get (3) -
const
_ set (3) - constants (6)
-
define
_ method (6) -
extend
_ object (3) - extended (3)
- include (3)
-
instance
_ method (3) -
instance
_ methods (3) -
method
_ added (3) -
method
_ removed (3) -
method
_ undefined (3) -
module
_ eval (6) -
module
_ exec (3) -
private
_ constant (1) -
private
_ instance _ methods (3) -
protected
_ instance _ methods (3) - public (3)
-
public
_ constant (1) -
public
_ instance _ methods (3) -
remove
_ class _ variable (3) -
remove
_ const (3)
検索結果
先頭5件
-
Module
# extend _ object(module) -> Module (6142) -
Object#extend の実体です。オブジェクトにモジュールの機能を追加します。
...
Object#extend の実体です。オブジェクトにモジュールの機能を追加します。
Object#extend は、Ruby で書くと以下のように定義できます。
def extend(*modules)
modules.each {|mod| mod.__send__ :extend_object, self }
end
extend_object のデフォル......トの実装では、self に定義されて
いるメソッドを object の特異メソッドとして追加します。
@param module Enumerable など Module クラスのインスタンスを指定します。
@return module で指定されたモジュールを返します。... -
Module
# const _ get(name) -> object (132) -
モジュールに定義されている name で指定される名前の定数の値を 取り出します。
...す。
Module#const_defined? と違って Object を特別扱いすることはありません。
@param name 定数名。String か Symbol で指定します。
@raise NameError 定数が定義されていないときに発生します。
module Bar
BAR = 1
end
class Object
inclu......de Bar
end
# Object では include されたモジュールに定義された定数を見付ける
p Object.const_get(:BAR) # => 1
class Baz
include Bar
end
# Object以外でも同様
p Baz.const_get(:BAR) # => 1
# 定義されていない定数
p Baz.const_get(:NOT_DEF... -
Module
# const _ get(name , inherit = true) -> object (132) -
モジュールに定義されている name で指定される名前の定数の値を 取り出します。
...モジュールに定義されている name で指定される名前の定数の値を
取り出します。
Module#const_defined? と違って Object を特別扱いすることはありません。
@param name 定数名。String か Symbol で指定します。
@param inherit false を指定......いときに発生します。
module Bar
BAR = 1
end
class Object
include Bar
end
# Object では include されたモジュールに定義された定数を見付ける
p Object.const_get(:BAR) # => 1
class Baz
include Bar
end
# Object以外でも同様
p Baz.co... -
Module
# remove _ const(name) -> object (120) -
name で指定した定数を取り除き、その定数に設定されていた値を 返します。
....#autoload を指定した(まだロードしてない)定数を削除
できないという制約があります。
class Object
remove_const :Array
end
=> -:2:in `remove_const': cannot remove Object::Array (NameError)
@see Module#remove_class_variable, Object#remove_instance_variable... -
Module
# class _ eval {|mod| . . . } -> object (111) -
モジュールのコンテキストで文字列 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 (111) -
モジュールのコンテキストで文字列 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
# module _ eval {|mod| . . . } -> object (111) -
モジュールのコンテキストで文字列 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
# module _ eval(expr , fname = "(eval)" , lineno = 1) -> object (111) -
モジュールのコンテキストで文字列 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
# remove _ class _ variable(name) -> object (108) -
引数で指定したクラス変数を取り除き、そのクラス変数に設定さ れていた値を返します。
...そのモジュールやクラスに定義されていない場合に発生します。
class Foo
@@foo = 1
remove_class_variable(:@@foo) # => 1
p @@foo # => uninitialized class variable @@foo in Foo (NameError)
end
@see Module#remove_const, Object#remove_instance_variable... -
Module
# class _ exec(*args) {|*vars| . . . } -> object (103) -
与えられたブロックを指定された 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
# module _ exec(*args) {|*vars| . . . } -> object (103) -
与えられたブロックを指定された 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 _ get(name) -> object (102) -
クラス/モジュールに定義されているクラス変数 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 (102) -
クラス/モジュールにクラス変数 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
# const _ set(name , value) -> object (102) -
モジュールに name で指定された名前の定数を value とい う値として定義し、value を返します。
モジュールに name で指定された名前の定数を value とい
う値として定義し、value を返します。
そのモジュールにおいてすでにその名前の定数が定義されている場合、警
告メッセージが出力されます。
@param name Symbol,String で定数の名前を指定します。
@param value セットしたい値を指定します。 -
Module
# const _ defined?(name) -> bool (37) -
モジュールに name で指定される名前の定数が定義されている時真 を返します。
...Object だけは例外)
@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
# ユーザ定義のモジュールに対しても同様
p Object.const_defined?(:BAR) # => true
class Baz
include Bar
end
# Object 以外では自身の定数だけがチェック対象
p Baz.const_defined?(:BAR) # => false... -
Module
# instance _ methods(inherited _ too = true) -> [String] (37) -
そのモジュールで定義されている public および protected メソッド名 の一覧を配列で返します。
...返します。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#methods
例1:
class Foo
private; def private_foo() end
protected; def protected_foo() end
public; def public_foo() end......るが、Object のインスタンスメソッドは一覧から排除している。
p Bar.instance_methods(true) - Object.instance_methods(true)
p Bar.public_instance_methods(true) - Object.public_instance_methods(true)
p Bar.private_instance_methods(true) - Object.private_ins......tance_methods(true)
p Bar.protected_instance_methods(true) - Object.protected_instance_methods(true)
実行結果
["protected_foo", "public_foo"]
["public_foo"]
["private_foo"]
["protected_foo"]... -
Module
# instance _ methods(inherited _ too = true) -> [Symbol] (37) -
そのモジュールで定義されている public および protected メソッド名 の一覧を配列で返します。
...返します。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#methods
例1:
class Foo
private; def private_foo() end
protected; def protected_foo() end
public; def public_foo() end......るが、Object のインスタンスメソッドは一覧から排除している。
p Bar.instance_methods(true) - Object.instance_methods(true)
p Bar.public_instance_methods(true) - Object.public_instance_methods(true)
p Bar.private_instance_methods(true) - Object.private_ins......tance_methods(true)
p Bar.protected_instance_methods(true) - Object.protected_instance_methods(true)
実行結果
[:protected_foo, :public_foo]
[:public_foo]
[:private_foo]
[:protected_foo]... -
Module
# extended(class _ or _ module) -> () (35) -
self が他のオブジェクト に Object#extend されたときに 呼ばれます。引数には extend を行ったオブジェクトが渡されます。
...に Object#extend されたときに
呼ばれます。引数には extend を行ったオブジェクトが渡されます。
@param class_or_module Object#extend を行ったオブジェクト
module Foo
def self.extended(mod)
p "#{mod} extend #{self}"
end
end
Object.new.ex......tend Foo
# => "#<Object:0x401cbc3c> extend Foo"... -
Module
# const _ defined?(name , inherit = true) -> bool (31) -
モジュールに 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
# ユーザ定義......のモジュールに対しても同様
p Object.const_defined?(:BAR) # => true
class Baz
include Bar
end
# Object 以外でも同様になった
# 第二引数のデフォルト値が true であるため
p Baz.const_defined?(:BAR) # => true
# 第二引数を false にし... -
Module
# ===(obj) -> bool (13) -
指定された obj が自身かそのサブクラスのインスタンスであるとき真を返します。 また、obj が自身をインクルードしたクラスかそのサブクラスのインスタンスである場合にも 真を返します。上記のいずれでもない場合に false を返します。
...、モジュールの所属関係をチェックすることになります。
str = String.new
case str
when String # String === str を評価する
p true # => true
end
@param obj 任意のオブジェクト
@see Object#kind_of?, Object#instance_of?, d:spec/control#case... -
Module
# include(*mod) -> self (13) -
モジュール mod をインクルードします。
...ドします。
@param mod Module のインスタンス( Enumerable など)を指定します。
@raise ArgumentError 継承関係が循環してしまうような include を行った場合に発生します。
module M
end
module M2
include M
end
module M
include M2
end
実......られており、 mix-in とも呼びます。
class C
include FileTest
include Math
end
p C.ancestors
# => [C, Math, FileTest, Object, Kernel]
モジュールの機能追加は、クラスの継承関係の間にそのモジュールが挿入
されることで実現されて......モジュールのほうが
先に行われます
(上の例の Module#ancestors の結果がメソッド探索の順序です)。
同じモジュールを二回以上 include すると二回目以降は無視されます。
module M
end
class C1
include M
end
class C2 < C1
inclu... -
Module
# <(other) -> bool | nil (7) -
比較演算子。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) -> Integer | nil (7) -
self と other の継承関係を比較します。
...ラスやモジュール
module Foo
end
class Bar
include Foo
end
class Baz < Bar
end
class Qux
end
p Bar <=> Foo # => -1
p Baz <=> Bar # => -1
p Baz <=> Foo # => -1
p Baz <=> Qux # => nil
p Qux <=> Baz # => nil
p Baz <=> Object.new # => nil... -
Module
# ancestors -> [Class , Module] (7) -
クラス、モジュールのスーパークラスとインクルードしているモジュール を優先順位順に配列に格納して返します。
...ル
を優先順位順に配列に格納して返します。
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
# class _ variables -> [String] (7) -
クラス/モジュールに定義されているクラス変数の名前の配列を返します。
...定義されているクラス変数の名前の配列を返します。
スーパークラスやインクルードしているモジュールのクラス変数も含みます。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#constants... -
Module
# class _ variables -> [Symbol] (7) -
クラス/モジュールに定義されているクラス変数の名前の配列を返します。
...定義されているクラス変数の名前の配列を返します。
スーパークラスやインクルードしているモジュールのクラス変数も含みます。
@see Module.constants, Kernel.#local_variables, Kernel.#global_variables, Object#instance_variables, Module#constants... -
Module
# constants -> [String] (7) -
そのモジュール(またはクラス)で定義されている定数名の配列を返します。 スーパークラスやインクルードしているモジュールの定数も含みます。
...。
@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] (7) -
そのモジュール(またはクラス)で定義されている定数名の配列を返します。
...ん。
@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 (7) -
インスタンスメソッド name を定義します。
...す。
ブロックを与えた場合、定義したメソッドの実行時にブロックが
レシーバクラスのインスタンスの上で Object#instance_eval されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod... -
Module
# define _ method(name , method) -> Proc | Method | UnboundMethod (7) -
インスタンスメソッド name を定義します。
...す。
ブロックを与えた場合、定義したメソッドの実行時にブロックが
レシーバクラスのインスタンスの上で Object#instance_eval されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod... -
Module
# instance _ method(name) -> UnboundMethod (7) -
self のインスタンスメソッドをオブジェクト化した UnboundMethod を返します。
...。
@param name Symbol か String です。
@raise NameError self に存在しないメソッドを指定した場合に発生します。
@see Object#method... -
Module
# method _ added(name) -> () (7) -
メソッド name が追加された時にインタプリタがこのメソッドを呼び出します。
...ame が追加された時にインタプリタがこのメソッドを呼び出します。
特異メソッドの追加に対するフックには
Object#singleton_method_added
を使います。
@param name 追加されたメソッドの名前が Symbol で渡されます。
class Foo
def... -
Module
# method _ removed(name) -> () (7) -
メソッドが Module#remove_method により削除 された時にインタプリタがこのメソッドを呼び出します。
...メソッドが Module#remove_method により削除
された時にインタプリタがこのメソッドを呼び出します。
特異メソッドの削除に対するフックには
Object#singleton_method_removed
を使います。
@param name 削除されたメソッド名が Symbol で渡... -
Module
# method _ undefined(name) -> () (7) -
このモジュールのインスタンスメソッド name が Module#undef_method によって削除されるか、 undef 文により未定義にされると、インタプリタがこのメソッドを呼び出します。
...インスタンスメソッド name が
Module#undef_method によって削除されるか、
undef 文により未定義にされると、インタプリタがこのメソッドを呼び出します。
特異メソッドの削除をフックするには
Object#singleton_method_undefined
を使い... -
Module
# private _ constant(*name) -> Module (7) -
name で指定した定数の可視性を private に変更します。
...rror 存在しない定数を指定した場合に発生します。
@raise SecurityError セーフレベル($SAFE)が 4 以上で自身が
untrust なオブジェクトではない場合に発生します。
@return 自身を返します。
@see Module#public_constant, Object#untrusted?... -
Module
# private _ instance _ methods(inherited _ too = true) -> [String] (7) -
そのモジュールで定義されている private メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#private_methods, Module#instance_methods... -
Module
# private _ instance _ methods(inherited _ too = true) -> [Symbol] (7) -
そのモジュールで定義されている private メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#private_methods, Module#instance_methods... -
Module
# protected _ instance _ methods(inherited _ too = true) -> [String] (7) -
そのモジュールで定義されている protected メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#protected_methods, Module#instance_methods... -
Module
# protected _ instance _ methods(inherited _ too = true) -> [Symbol] (7) -
そのモジュールで定義されている protected メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#protected_methods, Module#instance_methods... -
Module
# public(*name) -> self (7) -
メソッドを public に設定します。
...。
def foo() 1 end
p foo # => 1
# the toplevel default is private
p self.foo # => private method `foo' called for #<Object:0x401c83b0> (NoMethodError)
def bar() 2 end
public :bar # visibility changed (all access allowed)
p bar # => 2
p self.bar... -
Module
# public _ constant(*name) -> Module (7) -
name で指定した定数の可視性を public に変更します。
...ror 存在しない定数を指定した場合に発生します。
@raise SecurityError セーフレベル($SAFE)が 4 以上で自身が
untrust なオブジェクトではない場合に発生します。
@return 自身を返します。
@see Module#private_constant, Object#untrusted?... -
Module
# public _ instance _ methods(inherited _ too = true) -> [String] (7) -
そのモジュールで定義されている public メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#public_methods, Module#instance_methods... -
Module
# public _ instance _ methods(inherited _ too = true) -> [Symbol] (7) -
そのモジュールで定義されている public メソッド名 の一覧を配列で返します。
...。
@param inherited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#public_methods, Module#instance_methods...
