種類
- インスタンスメソッド (54)
- 特異メソッド (6)
ライブラリ
- ビルトイン (60)
キーワード
- < (3)
- <=> (3)
- === (3)
-
alias
_ method (3) -
class
_ eval (6) -
class
_ exec (3) -
class
_ variable _ set (3) -
define
_ method (6) - extended (3)
-
module
_ eval (6) -
module
_ exec (3) - name (3)
- new (6)
- private (3)
-
to
_ s (3) -
undef
_ method (3)
検索結果
先頭5件
-
Module
. new -> Module (62259) -
名前の付いていないモジュールを新しく生成して返します。
...ックに渡し、
モジュールのコンテキストでブロックを実行します。
mod = Module.new
mod.module_eval {|m| ... }
mod
と同じです。
ブロックの実行は Module#initialize が行います。
ブロックを与えた場合も生成したモジュールを返し......ます。
モジュールの名前は、
そのモジュールが代入されている定数名のいずれかです。
m = Module.new
p m # => #<Module 0lx40198a54>
p m.name # => "" # まだ名前は未定
Foo = m
# m.name # ここで m.name を呼べ......ます。
モジュールの名前は、
そのモジュールが代入されている定数名のいずれかです。
m = Module.new
p m # => #<Module 0lx40198a54>
p m.name # => nil # まだ名前は未定
Foo = m
# m.name # ここで m.name を呼べ... -
Module
. new {|mod| . . . } -> Module (62259) -
名前の付いていないモジュールを新しく生成して返します。
...ックに渡し、
モジュールのコンテキストでブロックを実行します。
mod = Module.new
mod.module_eval {|m| ... }
mod
と同じです。
ブロックの実行は Module#initialize が行います。
ブロックを与えた場合も生成したモジュールを返し......ます。
モジュールの名前は、
そのモジュールが代入されている定数名のいずれかです。
m = Module.new
p m # => #<Module 0lx40198a54>
p m.name # => "" # まだ名前は未定
Foo = m
# m.name # ここで m.name を呼べ......ます。
モジュールの名前は、
そのモジュールが代入されている定数名のいずれかです。
m = Module.new
p m # => #<Module 0lx40198a54>
p m.name # => nil # まだ名前は未定
Foo = m
# m.name # ここで m.name を呼べ... -
Module
# module _ eval {|mod| . . . } -> object (24133) -
モジュールのコンテキストで文字列 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 (24133) -
モジュールのコンテキストで文字列 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 _ exec(*args) {|*vars| . . . } -> object (24126) -
与えられたブロックを指定された 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
# extended(class _ or _ module) -> () (21120) -
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
# => "#<Object:0x401cbc3c> extend Foo"... -
Module
# alias _ method(new , original) -> self (21108) -
メソッドの別名を定義します。
...バル変数の別名をつけることはできません
また、クラスメソッドに対して使用することはできません。
@param new 新しいメソッド名。String または Symbol で指定します。
@param original 元のメソッド名。String または Symbol で指定... -
Module
# name -> String (21037) -
モジュールやクラスの名前を文字列で返します。
...は空文字列を返します。
module A
module B
end
p B.name #=> "A::B"
class C
end
end
p A.name #=> "A"
p A::B.name #=> "A::B"
p A::C.name #=> "A::C"
# 名前のないモジュール / クラス
p Module.new.name #=> ""
p Class.new.name #=> ""......ては nil を返します。
module A
module B
end
p B.name #=> "A::B"
class C
end
end
p A.name #=> "A"
p A::B.name #=> "A::B"
p A::C.name #=> "A::C"
# 名前のないモジュール / クラス
p Module.new.name #=> nil
p Class.new.name #=> nil... -
Module
# to _ s -> String (21037) -
モジュールやクラスの名前を文字列で返します。
...は空文字列を返します。
module A
module B
end
p B.name #=> "A::B"
class C
end
end
p A.name #=> "A"
p A::B.name #=> "A::B"
p A::C.name #=> "A::C"
# 名前のないモジュール / クラス
p Module.new.name #=> ""
p Class.new.name #=> ""......ては nil を返します。
module A
module B
end
p B.name #=> "A::B"
class C
end
end
p A.name #=> "A"
p A::B.name #=> "A::B"
p A::C.name #=> "A::C"
# 名前のないモジュール / クラス
p Module.new.name #=> nil
p Class.new.name #=> nil... -
Module
# class _ eval {|mod| . . . } -> object (21033) -
モジュールのコンテキストで文字列 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 (21033) -
モジュールのコンテキストで文字列 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
# undef _ method(*name) -> self (21031) -
このモジュールのインスタンスメソッド name を未定義にします。
...s B < A
def ok
puts 'B'
end
end
B.new.ok # => B
# undef_method の場合はスーパークラスに同名のメソッドがあっても
# その呼び出しはエラーになる
class B
undef_method :ok
end
B.new.ok # => NameError
# remove_method の場合は......と
# それが呼ばれる
class B
remove_method :ok
end
B.new.ok # => A
また、undef 文と undef_method の違いは、
メソッド名を String または Symbol で与えられることです。
module M1
def foo
end
def self.moo
undef foo
end
end
M......1.instance_methods false #=> ["foo"]
M1.moo
M1.instance_methods false #=> []
module M2
def foo
end
def self.moo
undef_method :foo
end
end
M2.instance_methods false #=> ["foo"]
M2.moo
M2.instance_methods false #=> []... -
Module
# class _ exec(*args) {|*vars| . . . } -> object (21026) -
与えられたブロックを指定された 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
# <(other) -> bool | nil (21019) -
比較演算子。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 (21013) -
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
# ===(obj) -> bool (21007) -
指定された obj が自身かそのサブクラスのインスタンスであるとき真を返します。 また、obj が自身をインクルードしたクラスかそのサブクラスのインスタンスである場合にも 真を返します。上記のいずれでもない場合に false を返します。
...の比較に用いられます。
case ではクラス、モジュールの所属関係をチェックすることになります。
str = String.new
case str
when String # String === str を評価する
p true # => true
end
@param obj 任意のオブジェクト
@see Objec... -
Module
# class _ variable _ set(name , val) -> object (21007) -
クラス/モジュールにクラス変数 name を定義して、その値として val をセットします。val を返します。
...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
# define _ method(name) { . . . } -> Proc (21007) -
インスタンスメソッド name を定義します。
...od を与えたときはそれを、ブロック付きで
呼びだしたときはブロックを Proc 化したオブジェクトを、
それぞれ返します。
class Foo
def foo() p :foo end
define_method(:bar, instance_method(:foo))
end
Foo.new.bar # => :foo... -
Module
# define _ method(name , method) -> Proc | Method | UnboundMethod (21007) -
インスタンスメソッド name を定義します。
...od を与えたときはそれを、ブロック付きで
呼びだしたときはブロックを Proc 化したオブジェクトを、
それぞれ返します。
class Foo
def foo() p :foo end
define_method(:bar, instance_method(:foo))
end
Foo.new.bar # => :foo... -
Module
# private(*name) -> self (21007) -
メソッドを private に設定します。
...# デフォルトでは public
private # 可視性を private に変更
def foo2() 2 end # foo2 は private メソッド
end
foo = Foo.new
p foo.foo1 # => 1
p foo.foo2 # => private method `foo2' called for #<Foo:0x401b7628> (NoMethodError)...
