From: v.ondruch@... Date: 2021-01-23T16:15:51+00:00 Subject: [ruby-core:102221] [Ruby master Feature#16978] Ruby should not use realpath for __FILE__ Issue #16978 has been updated by vo.x (Vit Ondruch). Eregon (Benoit Daloze) wrote in #note-10: > vo.x (Vit Ondruch) wrote in #note-7: > > In Fedora, to avoid duplication, we have openssl gem extracted into independent package, which links back to the StdLib to keep the Ruby functionality. > > What does it look like on the filesystem? This is how it is constructed. Here is where the OpenSSL structure is created in traditional gem directories: https://src.fedoraproject.org/rpms/ruby/blob/master/f/ruby.spec#_761 And here are the links back to the StdLib location: https://src.fedoraproject.org/rpms/ruby/blob/master/f/ruby.spec#_771 > Even if the package is split, the standard location could be used, no need for symlinks, isn't it? Not sure what do you mean specifically, because of course I'd prefer if there are no symlinks. The idea is that rubygem-openssl, should be replaced by newer version of openssl released on rubygems.org, without upgrading Ruby itself, therefore the files have to be located in the gem directory. Of course there are different possibilities, how to workaround that (e.g. #14737). The only question how sustainable they are. However, Fedora is orthogonal and just distraction to this issue, because I can imagine if I were ruby openssl developer, I'd like to replace content of Ruby build with my development version of OpenSSL from git snapshot via symlinks, e.g.: ~~~ $ cd ~ $ git clone https://github.com/ruby/openssl.git # rm /usr/local/lib/ruby/3.0.0/openssl* # ln -s ~/openssl/lib/openssl.rb . # ln -s ~/openssl/lib/openssl . $ /usr/local/bin/ruby --disable-gems -e 'require "openssl"; require "openssl/digest"' /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::MD4 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of MD4 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::MD5 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of MD5 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::RIPEMD160 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of RIPEMD160 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::SHA1 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of SHA1 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::SHA224 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of SHA224 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::SHA256 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of SHA256 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::SHA384 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of SHA384 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:45: warning: already initialized constant OpenSSL::Digest::SHA512 /builddir/openssl/lib/openssl/digest.rb:45: warning: previous definition of SHA512 was here /usr/local/lib/ruby/3.0.0/openssl/digest.rb:52:in `': superclass mismatch for class Digest (TypeError) from /usr/local/lib/ruby/3.0.0/openssl/digest.rb:16:in `' from /usr/local/lib/ruby/3.0.0/openssl/digest.rb:15:in `' from -e:1:in `require' from -e:1:in `
' ~~~ Everybody can try the example above? Is it artificial and should be prohibited? Should it fail? ---------------------------------------- Feature #16978: Ruby should not use realpath for __FILE__ https://bugs.ruby-lang.org/issues/16978#change-90069 * Author: vo.x (Vit Ondruch) * Status: Open * Priority: Normal ---------------------------------------- This is the simplest test case: ~~~ $ mkdir a $ echo "puts __FILE__" > a/test.rb $ ln -s a b $ ruby -Ib -e "require 'test'" /builddir/a/test.rb ~~~ This behavior is problematic, because Ruby should not know nothing about the `a` directory. It was not instructed to use it. I should always refer to the file using the original path and do not dig into the underlying details, otherwise depending on file system setup, one might be forced to used `File.realpath` everywhere trying to use `__FILE__`. -- https://bugs.ruby-lang.org/ Unsubscribe: