関連するキーワード
キーワード
-
alias
_ method (3) -
class
_ exec (3) -
define
_ method (6) -
instance
_ method (3) -
instance
_ methods (3) -
method
_ added (3) -
method
_ defined? (3) -
method
_ removed (3) -
method
_ undefined (3) -
module
_ exec (3) -
module
_ function (3) - private (3)
-
private
_ class _ method (3) -
private
_ instance _ methods (3) -
private
_ method _ defined? (3) -
protected
_ instance _ methods (3) -
protected
_ method _ defined? (3) - public (3)
-
public
_ class _ method (3) -
public
_ instance _ methods (3) -
public
_ method _ defined? (3) -
rake
_ extension (2) -
remove
_ method (3) -
undef
_ method (3)
検索結果
先頭5件
-
Module
# define _ method(name , method) -> Proc | Method | UnboundMethod (6435) -
インスタンスメソッド name を定義します。
...されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod の
いずれかのインスタンスを指定します。
@return 引数 method を与えたときはそれを、ブロック付きで
呼びだした......ときはブロックを Proc 化したオブジェクトを、
それぞれ返します。
class Foo
def foo() p :foo end
define_method(:bar, instance_method(:foo))
end
Foo.new.bar # => :foo... -
Module
# instance _ method(name) -> UnboundMethod (6208) -
self のインスタンスメソッドをオブジェクト化した UnboundMethod を返します。
...タンスメソッドをオブジェクト化した UnboundMethod を返します。
@param name Symbol か String です。
@raise NameError self に存在しないメソッドを指定した場合に発生します。
@see Object#method... -
Module
# method _ undefined(name) -> () (6154) -
このモジュールのインスタンスメソッド name が Module#undef_method によって削除されるか、 undef 文により未定義にされると、インタプリタがこのメソッドを呼び出します。
...タンスメソッド name が
Module#undef_method によって削除されるか、
undef 文により未定義にされると、インタプリタがこのメソッドを呼び出します。
特異メソッドの削除をフックするには
Object#singleton_method_undefined
を使います。......ッド名が Symbol で渡されます。
class C
def C.method_undefined(name)
puts "method C\##{name} was undefined"
end
def foo
end
def bar
end
undef_method :foo
undef bar
end
実行結果:
method C#foo was undefined
method C#bar was undefined... -
Module
# method _ removed(name) -> () (6148) -
メソッドが Module#remove_method により削除 された時にインタプリタがこのメソッドを呼び出します。
...メソッドが Module#remove_method により削除
された時にインタプリタがこのメソッドを呼び出します。
特異メソッドの削除に対するフックには
Object#singleton_method_removed
を使います。
@param name 削除されたメソッド名が Symbol で渡......されます。
class Foo
def Foo.method_removed(name)
puts "method \"#{name}\" was removed"
end
def foo
end
remove_method :foo
end
=> method "foo" was removed... -
Module
# method _ added(name) -> () (6144) -
メソッド name が追加された時にインタプリタがこのメソッドを呼び出します。
...ton_method_added
を使います。
@param name 追加されたメソッドの名前が Symbol で渡されます。
class Foo
def Foo.method_added(name)
puts "method \"#{name}\" was added"
end
def foo
end
define_method :bar, instance_method(:foo)
end
=> method "f......oo" was added
method "bar" was added... -
Module
# undef _ method(*name) -> self (6138) -
このモジュールのインスタンスメソッド name を未定義にします。
...end
end
B.new.ok # => B
# undef_method の場合はスーパークラスに同名のメソッドがあっても
# その呼び出しはエラーになる
class B
undef_method :ok
end
B.new.ok # => NameError
# remove_method の場合はスーパークラスに同名の......ass 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
M1.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
# define _ method(name) { . . . } -> Proc (6135) -
インスタンスメソッド name を定義します。
...されます。
@param name String または Symbol を指定します。
@param method Proc、Method あるいは UnboundMethod の
いずれかのインスタンスを指定します。
@return 引数 method を与えたときはそれを、ブロック付きで
呼びだした......ときはブロックを Proc 化したオブジェクトを、
それぞれ返します。
class Foo
def foo() p :foo end
define_method(:bar, instance_method(:foo))
end
Foo.new.bar # => :foo... -
Module
# remove _ method(*name) -> self (6126) -
インスタンスメソッド name をモジュールから削除します。
...たは Symbol を一つ以上指定します。
@raise NameError 指定したメソッドが定義されていない場合に発生します。
class C
def foo
end
remove_method :foo
remove_method :no_such_method # 例外 NameError が発生
end
@see Module#undef_method... -
Module
# method _ defined?(name) -> bool (6120) -
モジュールにインスタンスメソッド name が定義されているとき true を返します。
...義されているとき
true を返します。
@param name Symbol か String を指定します。
@see Module#public_method_defined?, Module#private_method_defined?, Module#protected_method_defined?... -
Module
# private _ method _ defined?(name) -> bool (6108) -
インスタンスメソッド name がモジュールに定義されており、 しかもその可視性が private であるときに true を返します。 そうでなければ false を返します。
...るときに true を返します。
そうでなければ false を返します。
@param name Symbol か String を指定します。
@see Module#method_defined?... -
Module
# protected _ method _ defined?(name) -> bool (6108) -
インスタンスメソッド name がモジュールに定義されており、 しかもその可視性が protected であるときに true を返します。 そうでなければ false を返します。
...るときに true を返します。
そうでなければ false を返します。
@param name Symbol か String を指定します。
@see Module#method_defined?... -
Module
# public _ method _ defined?(name) -> bool (6108) -
インスタンスメソッド name がモジュールに定義されており、 しかもその可視性が public であるときに true を返します。 そうでなければ false を返します。
...るときに true を返します。
そうでなければ false を返します。
@param name Symbol か String を指定します。
@see Module#method_defined?... -
Module
# alias _ method(new , original) -> self (6102) -
メソッドの別名を定義します。
メソッドの別名を定義します。
alias との違いは以下の通りです。
* メソッド名は String または Symbol で指定します
* グローバル変数の別名をつけることはできません
また、クラスメソッドに対して使用することはできません。
@param new 新しいメソッド名。String または Symbol で指定します。
@param original 元のメソッド名。String または Symbol で指定します。
@see d:spec/def#alias -
Module
# private _ class _ method(*name) -> self (6102) -
name で指定したクラスメソッド (クラスの特異メソッド) の 可視性を private に変更します。
name で指定したクラスメソッド (クラスの特異メソッド) の
可視性を private に変更します。
@param name 0 個以上の String か Symbol を指定します。 -
Module
# public _ class _ method(*name) -> self (6102) -
name で指定したクラスメソッド (クラスの特異メソッド) の 可視性を public に変更します。
name で指定したクラスメソッド (クラスの特異メソッド) の
可視性を public に変更します。
@param name 0 個以上の String か Symbol を指定します。 -
Module
# instance _ methods(inherited _ too = true) -> [String] (6101) -
そのモジュールで定義されている public および protected メソッド名 の一覧を配列で返します。
...Object#methods
例1:
class Foo
private; def private_foo() end
protected; def protected_foo() end
public; def public_foo() end
end
# あるクラスのインスタンスメソッドの一覧を得る
p Foo.instance_methods(false)
p Foo.public_instance_methods(false......)
p Foo.private_instance_methods(false)
p Foo.protected_instance_methods(false)
class Bar < Foo
end
実行結果
["protected_foo", "public_foo"]
["public_foo"]
["private_foo"]
["protected_foo"]
例2:
class Bar
private; def private_foo() end
protected; d......nce_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_instance_methods(true)
p Bar.protected_instance_methods(true) - Object.protected_instance_methods(tr... -
Module
# instance _ methods(inherited _ too = true) -> [Symbol] (6101) -
そのモジュールで定義されている public および protected メソッド名 の一覧を配列で返します。
...Object#methods
例1:
class Foo
private; def private_foo() end
protected; def protected_foo() end
public; def public_foo() end
end
# あるクラスのインスタンスメソッドの一覧を得る
p Foo.instance_methods(false)
p Foo.public_instance_methods(false......)
p Foo.private_instance_methods(false)
p Foo.protected_instance_methods(false)
class Bar < Foo
end
実行結果
[:protected_foo, :public_foo]
[:public_foo]
[:private_foo]
[:protected_foo]
例2:
class Bar
private; def private_foo() end
protected; def pr......nce_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_instance_methods(true)
p Bar.protected_instance_methods(true) - Object.protected_instance_methods(tr... -
Module
# private _ instance _ methods(inherited _ too = true) -> [String] (6101) -
そのモジュールで定義されている private メソッド名 の一覧を配列で返します。
...erited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#private_methods, Module#instance_methods... -
Module
# private _ instance _ methods(inherited _ too = true) -> [Symbol] (6101) -
そのモジュールで定義されている private メソッド名 の一覧を配列で返します。
...erited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#private_methods, Module#instance_methods... -
Module
# protected _ instance _ methods(inherited _ too = true) -> [String] (6101) -
そのモジュールで定義されている protected メソッド名 の一覧を配列で返します。
...ited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#protected_methods, Module#instance_methods... -
Module
# protected _ instance _ methods(inherited _ too = true) -> [Symbol] (6101) -
そのモジュールで定義されている protected メソッド名 の一覧を配列で返します。
...ited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#protected_methods, Module#instance_methods... -
Module
# public _ instance _ methods(inherited _ too = true) -> [String] (6101) -
そのモジュールで定義されている public メソッド名 の一覧を配列で返します。
...herited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#public_methods, Module#instance_methods... -
Module
# public _ instance _ methods(inherited _ too = true) -> [Symbol] (6101) -
そのモジュールで定義されている public メソッド名 の一覧を配列で返します。
...herited_too false を指定するとそのモジュールで定義されているメソッドのみ返します。
@see Object#public_methods, Module#instance_methods... -
Module
# rake _ extension(method) { . . . } -> () (108) -
与えられたブロック内で既に存在するメソッドを再定義しようとした場合に 警告を表示します。この場合、ブロックは評価されません。
...するメソッドを再定義しようとした場合に
警告を表示します。この場合、ブロックは評価されません。
@param method ブロック内で再定義する予定のメソッド名を指定します。
例:
class String
rake_extension("xyz") do
def xyz... -
Module
# class _ exec(*args) {|*vars| . . . } -> object (7) -
与えられたブロックを指定された 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 (7) -
与えられたブロックを指定された 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 _ function(*name) -> self (7) -
メソッドをモジュール関数にします。
...すべてモジュール関数です。
self を返します。
@param name String または Symbol を 0 個以上指定します。
=== 注意
module_function はメソッドに「モジュール関数」という属性をつけるメ
ソッドではなく、プライベートメソッドとモ......もモジュール関数の別名は定義できません。
module M
def foo
p "foo"
end
module_function :foo
alias bar foo
end
M.foo # => "foo"
M.bar # => undefined method `bar' for Foo:Module (NoMethodError)
このコードでは、モジュール関数 foo......名を付けるには、
以下のように、先に別名を定義してから
それぞれをモジュール関数にしなければいけません。
module M
def foo
p "foo"
end
alias bar foo
module_function :foo, :bar
end
M.foo # => "foo"
M.bar # => "foo"... -
Module
# private(*name) -> self (7) -
メソッドを 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)... -
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....
