Bug #16097
closed[PATCH] Don't accidentally name anonymous module/class
Description
My patch in #15765 accidentally introduced a behavior change.
ruby -ve 'Module.new { class self::A; end; p name }'
outputs a name
similar to Module#inspect
when it should output nil
like in Ruby 2.6.x.
I have a pull request to fix this: https://github.com/ruby/ruby/pull/2337
Updated by nobu (Nobuyoshi Nakada) over 5 years ago
Could you rebase the PR with adding this reference [Bug #16097]
to the commit log?
Updated by alanwu (Alan Wu) over 5 years ago
Done. The latest commit has a reference to this ticket.
Updated by alanwu (Alan Wu) over 5 years ago
- Status changed from Open to Closed
Applied in changeset git|c8f97596b7dd6ffbeb98970f9cc664b0a8a2336e.
Don't accidentally name anonymous module/class
b00f280d4b9569e7153365d7e1c522b3d6b3c6cf introduced
an accidental behavior change in that defining a module/class under
m
gives m
a name when m
is anonymous.
ruby -ve 'Module.new { class self::A; end; p name }'
outputs a name
similar to Module#inspect
when it should output nil
like in Ruby
2.6.x.
-
variable.c: Use
make_temporary_path
instead ofsave_temporary_path
when getting the name of the parent module. -
variable.c (rb_set_class_path): Delegate to
rb_set_class_path_string
instead of duplicating the logic.
[Bug #16097]