From: matz@... Date: 2017-03-13T06:12:54+00:00 Subject: [ruby-core:80102] [Ruby trunk Feature#13109][Rejected] `using` in refinements is required to be physically placed before the refined method call Issue #13109 has been updated by Yukihiro Matsumoto. Status changed from Open to Rejected There may be an idea to use refinement without explicit `using`. But that's out of the scope of this issue. Matz. ---------------------------------------- Feature #13109: `using` in refinements is required to be physically placed before the refined method call https://bugs.ruby-lang.org/issues/13109#change-63528 * Author: Akira Matsuda * Status: Rejected * Priority: Normal * Assignee: Shugo Maeda * Target version: ---------------------------------------- When using refinements in one file, the `using` call needs to be physically placed before the refined method call. For example, this works: ``` using Module.new { refine Object do def foo() p 'hello'; end end } class Object def bar() foo; end end Object.new.bar ``` but this doesn't work: ``` class Object def bar() foo; end end using Module.new { refine Object do def foo() p 'hello'; end end } Object.new.bar #=> doesnot_work.rb:2:in `bar': undefined local variable or method `foo' for # (NameError) ``` I know that current refinements has a unique scope called "file scope", but I don't think this is expected behavior. At least I expect it to work so far as `using` is evaluated in runtime, no matter where in the file it is. I confirmed that this reproduces in all stable versions of 2.0, 2.1, 2.2, 2.3, 2.4, and today's trunk (2.5). -- https://bugs.ruby-lang.org/ Unsubscribe: