Project

General

Profile

Actions

Feature #20609

open

Nested module namespace misses fallback to top level

Added by abdullah.arif (Abdullah Arif) 5 months ago. Updated 5 months ago.

Status:
Open
Assignee:
-
Target version:
-
[ruby-core:118465]

Description

Currently, Ruby falls back to the top-level constants if it cannot find the Module in the local scope. This can cause it to behave unintuitively.

module A
  module B
    MY_CONST = 'defined in A::B'
  end
end

module X
end

module X::Y
  # Ruby treats A::B the same as ::A::B, because module X::Y::A is not defined. IMO this should raise a Name error or atleast a warning.
  module A::B
    # This was meant to be scoped to X::Y::A::B'
    MY_CONST = 'defined in X::Y::A::B'
  end
  puts(::A::B::MY_CONST) # => defined in X::Y::A::B
  puts(A::B::MY_CONST) # => defined in X::Y::A::B
end

puts(X::Y::A::B::MY_CONST) # uninitialized constant X::Y::A (NameError)

I think Ruby should raise an error or atleast a clear warning explaining the module it is using has different nesting than what the coder might expect.

Actions

Also available in: Atom PDF

Like0
Like0