Bug #7695

Constant Lookup - For goodness sake it should at least see itself!

Added by Thomas Sawyer over 3 years ago. Updated over 3 years ago.

ruby -v:
ruby 1.9.3p327 (2012-11-10 revision 37606) [x86_64-linux]



module Foo; end
module Foo::Bar
p Bar
NameError: uninitialized constant Foo::Bar::Bar
from (irb):3:in <module:Bar>'
from (irb):2
from /opt/Ruby/1.9.3-p327/bin/irb:12:in

While I understand the technical details of constant lookup and why this happens, it just seems plan wrong on the face of it. Why wouldn't a module/class not at least see ((itself))!?

For use case -- I was writing some code and I determined that a whole set of classes should be under a secondary namespace. It was convenient to go from module Realms to class Realms::Library, but alas, it broke the code, because none of the code inside could see Library anymore. So I had to go through all the files, use two lines instead on one, i.e. module Realms then class Library, indent every line another tab and finally add another end at the bottom of each file. A pain in the arse!

While it might not technically be a "bug", I am going to go ahead and file it as one b/c to me it really seems like one. And if I didn't know exactly how constant lookup worked I would think it one too.


#1 [ruby-core:51452] Updated by Alexey Muranov over 3 years ago

Just to link to an older discussion: #6810.

#2 [ruby-core:52408] Updated by Koichi Sasada over 3 years ago

  • Assignee set to Nobuyoshi Nakada

Also available in: Atom PDF