[#66126] Creation/Conversion methods/functions table for Ruby types — SASADA Koichi <ko1@...>
Hi,
5 messages
2014/11/07
[#66248] [ruby-trunk - Feature #10423] [PATCH] opt_str_lit*: avoid literal string allocations — normalperson@...
Issue #10423 has been updated by Eric Wong.
3 messages
2014/11/13
[#66595] [ruby-trunk - Bug #10557] [Open] Block not given when the argument is a string — bartosz@...
Issue #10557 has been reported by Bartosz Kopinski.
3 messages
2014/11/30
[ruby-core:66489] [ruby-trunk - Bug #10488] [Closed] Consistency of Module#const_defined? and constant lookup
From:
eregontp@...
Date:
2014-11-26 12:38:09 UTC
List:
ruby-core #66489
Issue #10488 has been updated by Benoit Daloze.
Status changed from Open to Closed
Indeed, it looks consistent with `const_get` and it seems difficult to be more consistent while keeping the same API.
Let's close this then.
----------------------------------------
Bug #10488: Consistency of Module#const_defined? and constant lookup
https://bugs.ruby-lang.org/issues/10488#change-50106
* Author: Benoit Daloze
* Status: Closed
* Priority: Normal
* Assignee:
* Category: core
* Target version: current: 2.2.0
* ruby -v: ruby 2.2.0dev (2014-10-12 trunk 47890) [x86_64-darwin13]
* Backport:
----------------------------------------
Currently, if for some module `mod` and constant `Const`,
`mod.const_defined?(:Const)` is true does not imply `mod::Const` is not an error.
This is inconsistent for at least the following cases:
* if mod is a Module but not a class, `const_defined?` will look in `Object` and its ancestors, but constant access (::) will not look in `Object` or above.
~~~ruby
Enumerable.const_defined? :String
Enumerable::String #=> NameError: uninitialized constant Enumerable::String
* if `Const` is private, `const_defined?` will return true while `mod::Const` will raise an error.
~~~ruby
C = 42
Object.private_constant :C
String.const_defined? :C #=> true
String::C #=> NameError: private constant String::C referenced
# This works, but is due to the lexical scope lookup
class String
C #=> 42
end
Is this intended?
Should it not mirror the behavior of `defined?(mod::Const)`?
Or the behavior of `method_defined?`
--
https://bugs.ruby-lang.org/