ruby-dev (Japanese) list archive (unofficial mirror)
 help / color / mirror / Atom feed
* [ruby-dev:50736] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
@ 2018-12-30  4:07 ` shuujii
  2018-12-30  4:28 ` [ruby-dev:50737] " manga.osyo
                   ` (5 subsequent siblings)
  6 siblings, 0 replies; 7+ messages in thread
From: shuujii @ 2018-12-30  4:07 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been reported by shuujii (Shuji KOBAYASHI).

----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488

* Author: shuujii (Shuji KOBAYASHI)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: UNKNOWN, 2.5: UNKNOWN, 2.6: UNKNOWN
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50737] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
  2018-12-30  4:07 ` [ruby-dev:50736] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動 shuujii
@ 2018-12-30  4:28 ` manga.osyo
  2018-12-30  5:06 ` [ruby-dev:50738] " manga.osyo
                   ` (4 subsequent siblings)
  6 siblings, 0 replies; 7+ messages in thread
From: manga.osyo @ 2018-12-30  4:28 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by osyo (manga osyo).


`File.const_defined?` だと `true` になるようですね。

```ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false

p File.const_get("NULL")       #=> "/dev/null"
p File.const_defined?("NULL")  #=> true
``` 

----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-76001

* Author: shuujii (Shuji KOBAYASHI)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: UNKNOWN, 2.5: UNKNOWN, 2.6: UNKNOWN
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50738] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
  2018-12-30  4:07 ` [ruby-dev:50736] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動 shuujii
  2018-12-30  4:28 ` [ruby-dev:50737] " manga.osyo
@ 2018-12-30  5:06 ` manga.osyo
  2018-12-30  6:09 ` [ruby-dev:50739] " shuujii
                   ` (3 subsequent siblings)
  6 siblings, 0 replies; 7+ messages in thread
From: manga.osyo @ 2018-12-30  5:06 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by osyo (manga osyo).


ちょっと調べてみたんですが、次のように `include` したモジュールの定数の場合は `false` が返ってくるのが原因なようですね。

```ruby
module M
  HOGE = 42
end

class X
  include M
end

p Object.const_get("X::HOGE")        # => 42
p Object.const_defined?("X::HOGE")   # => false
```

`File::NULL` も実際には `File::Constants::NULL` で定義されており、`File::Constants` を `include` しているようです。
see: https://docs.ruby-lang.org/ja/latest/class/File=3a=3aConstants.html

```ruby
p Object.const_defined?("File::NULL")             # => false
p Object.const_defined?("File::Constants::NULL")  # => true
```


----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-76002

* Author: shuujii (Shuji KOBAYASHI)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: UNKNOWN, 2.5: UNKNOWN, 2.6: UNKNOWN
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50739] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
                   ` (2 preceding siblings ...)
  2018-12-30  5:06 ` [ruby-dev:50738] " manga.osyo
@ 2018-12-30  6:09 ` shuujii
  2018-12-30  8:18 ` [ruby-dev:50740] " manga.osyo
                   ` (2 subsequent siblings)
  6 siblings, 0 replies; 7+ messages in thread
From: shuujii @ 2018-12-30  6:09 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by shuujii (Shuji KOBAYASHI).


なるほどー。そういう違いがあるんですね。

そうすると、`File.const_defined?("NULL")` は `true` になることと、
`Object.const_get("File::NULL")` との一貫性の観点から
`Object.const_defined?("File::NULL")` も `true` になるほうが良いような気がします。

----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-76003

* Author: shuujii (Shuji KOBAYASHI)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: UNKNOWN, 2.5: UNKNOWN, 2.6: UNKNOWN
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50740] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
                   ` (3 preceding siblings ...)
  2018-12-30  6:09 ` [ruby-dev:50739] " shuujii
@ 2018-12-30  8:18 ` manga.osyo
  2019-01-29  5:00 ` [ruby-dev:50775] " naruse
  2019-03-13  0:03 ` [ruby-dev:50782] " nagachika00
  6 siblings, 0 replies; 7+ messages in thread
From: manga.osyo @ 2018-12-30  8:18 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by osyo (manga osyo).


挙動を修正したパッチを書いてみました。
ただ、意図的にそのような実装にしていた節があるのでこれが仕様なのかバグなのかは現時点で判断するのはちょっとむずかしそうですね。
該当箇所を消してもテストはパスしていたんですが…。
わたしも処理に一貫性を持たせるためには `true` を返したほうがいいと思います。

* pull requst : https://github.com/ruby/ruby/pull/2061

また、元々は以下の issues で議論されていたようです。

* [Feature #7414: Now that const_get supports `Foo::Bar`; syntax, so should const_defined?. - Ruby trunk - Ruby Issue Tracking System](https://bugs.ruby-lang.org/issues/7414)


## 挙動

### 修正前

```ruby
module M
  HOGE = 42
end

class X
  include M
end

# OK: 問題なく取得できる
p X.const_get("HOGE")           # => 42
p Object.const_get("X::HOGE")   # => 42

# OK: 期待する値が返ってくる
p X.const_defined?("HOGE")   # => true

# NG: const_get で値は取得できるが false が返ってくる
p Object.const_defined?("X::HOGE")   # => false
```

### 修正後

```ruby
module M
  HOGE = 42
end

class X
  include M
end

# OK: 問題なく取得できる
p X.const_get("HOGE")           # => 42
p Object.const_get("X::HOGE")   # => 42

# OK: 期待する値が返ってくる
p X.const_defined?("HOGE")   # => true

# OK: true が返ってくる
p Object.const_defined?("X::HOGE")   # => true

# OK: 第二引数に false を渡すと mixin が考慮されないようになるので false になる
p Object.const_defined?("X::HOGE", false)   # => false
```


## ユースケース

定数が存在しない場合に動的に mixin を行いたい場合は `include` が考慮されていてほしい。

```ruby
module Valuable
	VALUE = 42
end

class X
end

def get
	# 遅延して mixin する
	if !Object.const_defined?("X::VALUE")
		pp "homu"
		X.include Valuable
	end
	Object.const_get("X::VALUE")
end

# 最初のメソッド呼び出しでのみ mixin したい
p get
p get
p get
```



----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-76004

* Author: shuujii (Shuji KOBAYASHI)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: UNKNOWN, 2.5: UNKNOWN, 2.6: UNKNOWN
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50775] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
                   ` (4 preceding siblings ...)
  2018-12-30  8:18 ` [ruby-dev:50740] " manga.osyo
@ 2019-01-29  5:00 ` naruse
  2019-03-13  0:03 ` [ruby-dev:50782] " nagachika00
  6 siblings, 0 replies; 7+ messages in thread
From: naruse @ 2019-01-29  5:00 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by naruse (Yui NARUSE).

Backport changed from 2.4: REQUIRED, 2.5: REQUIRED, 2.6: REQUIRED to 2.4: REQUIRED, 2.5: REQUIRED, 2.6: DONE

ruby_2_6 r66939 merged revision(s) 66938.

----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-76562

* Author: shuujii (Shuji KOBAYASHI)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: REQUIRED, 2.5: REQUIRED, 2.6: DONE
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [ruby-dev:50782] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動
       [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
                   ` (5 preceding siblings ...)
  2019-01-29  5:00 ` [ruby-dev:50775] " naruse
@ 2019-03-13  0:03 ` nagachika00
  6 siblings, 0 replies; 7+ messages in thread
From: nagachika00 @ 2019-03-13  0:03 UTC (permalink / raw)
  To: ruby-dev

Issue #15488 has been updated by nagachika (Tomoyuki Chikanaga).


I have a little concern that this could be an imconpatibility issue. I will skip this change for the next teeny.

----------------------------------------
Bug #15488: const_defined?("File::NULL") の挙動
https://bugs.ruby-lang.org/issues/15488#change-77076

* Author: shuujii (Shuji KOBAYASHI)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.6.0p0 (2018-12-25 revision 66547) [x86_64-linux]
* Backport: 2.4: REQUIRED, 2.5: REQUIRED, 2.6: DONE
----------------------------------------
`const_get` と `const_defined?` について、例えば `Math::PI` では以下のようになり
どちらも期待通りの結果になります。

~~~ruby
p Object.const_get("Math::PI")         #=> 3.141592653589793
p Object.const_defined?("Math::PI")    #=> true
~~~

一方、`File::NULL` の場合は以下のように `const_get` で値が取得できるのに
`const_defined?` が `false` になります。

~~~ruby
p Object.const_get("File::NULL")       #=> "/dev/null"
p Object.const_defined?("File::NULL")  #=> false
~~~

これは意図的でしょうか。



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2019-03-13  0:03 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <redmine.issue-15488.20181230040701@ruby-lang.org>
2018-12-30  4:07 ` [ruby-dev:50736] [Ruby trunk Bug#15488] const_defined?("File::NULL") の挙動 shuujii
2018-12-30  4:28 ` [ruby-dev:50737] " manga.osyo
2018-12-30  5:06 ` [ruby-dev:50738] " manga.osyo
2018-12-30  6:09 ` [ruby-dev:50739] " shuujii
2018-12-30  8:18 ` [ruby-dev:50740] " manga.osyo
2019-01-29  5:00 ` [ruby-dev:50775] " naruse
2019-03-13  0:03 ` [ruby-dev:50782] " nagachika00

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).