Is there an obvious method for a module like
A::C
that would result in A::B?
Module.nesting came to mind, but no I didn’t see an obvious way to make
it work.
Daniel Brumbaugh K.
Is there an obvious method for a module like
A::C
that would result in A::B?
Module.nesting came to mind, but no I didn’t see an obvious way to make
it work.
Daniel Brumbaugh K.
On Jan 19, 2008, at 1:07 AM, Xavier N. wrote:
On Jan 19, 2008, at 12:29 AM, Daniel Brumbaugh K. wrote:
Is there an obvious method for a module like
A::C
that would result in A::B?What do you mean?
Oh, perhaps you just want something like Module#parent provided by
Active Support. There the parent is computed by hand from the module
name:
def parent
parent_name = name.split('::')[0..-2] * '::'
parent_name.empty? ? Object : parent_name.constantize
end
where String#constantize is
def constantize(camel_cased_word)
unless /\A(?:::)?([A-Z]\w*(?:::[A-Z]\w*)*)\z/ =~ camel_cased_word
raise NameError, "#{camel_cased_word.inspect} is not a valid
constant name!"
end
Object.module_eval("::#{$1}", __FILE__, __LINE__)
end
– fxn
On Jan 19, 2008, at 12:29 AM, Daniel Brumbaugh K. wrote:
Is there an obvious method for a module like
A::C
that would result in A::B?
What do you mean?
You know, modules are objects, constants are stored in modules. Given
those rules you can put a module almost anywhere. AFAICT what you
cannot change via API is its name, which is set in stone the first
time a module is assigned to a constant. That happens in regular
module definitions, or explicitly like this:
$ irb
irb(main):001:0> m = Module.new
=> #<Module:0x20eb6c>
irb(main):002:0> m.name
=> ""
irb(main):003:0> M = m
=> M
irb(main):004:0> m.name
=> "M"
irb(main):005:0> N = M
=> M
irb(main):006:0> N.name
=> "M"
– fxn
This forum is not affiliated to the Ruby language, Ruby on Rails framework, nor any Ruby applications discussed here.
Sponsor our Newsletter | Privacy Policy | Terms of Service | Remote Ruby Jobs