[ruby-core:98472] [Ruby master Bug#16904] rubygems: psych: superclass mismatch for class Mark (TypeError)
From:
v.ondruch@...
Date:
2020-05-21 11:29:13 UTC
List:
ruby-core #98472
Issue #16904 has been updated by vo.x (Vit Ondruch).
BTW I don't understand how this could work:
~~~
$ for psych in psych{1..3}; do mkdir $psych; echo "puts '$psych'" > $psych/psych.rb; done
$ find .
..
./psych2
./psych2/psych.rb
./psych1
./psych1/psych.rb
./psych3
./psych3/psych.rb
$ ruby -e '(1..3).each {|psych| $:.unshift("psych#{psych}"); require "psych" }'
psych1
psych2
psych3
~~~
In my opinion, the call to `require "psych"` should succeed only once, no matter on the state of `$LOAD_PATH`. I can report this as separate ticket ...
----------------------------------------
Bug #16904: rubygems: psych: superclass mismatch for class Mark (TypeError)
https://bugs.ruby-lang.org/issues/16904#change-85747
* Author: jaruga (Jun Aruga)
* Status: Open
* Priority: Normal
* Backport: 2.5: UNKNOWN, 2.6: UNKNOWN, 2.7: UNKNOWN
----------------------------------------
Is it possible to backport the following commits into Ruby?
Remove explicit `psych` activation
https://github.com/rubygems/rubygems/commit/1ccf0912a161d20e0c4a7b139fd76e8739a411ba
bundler: Remove explicit `psych` activation.
https://github.com/rubygems/rubygems/commit/88478bb56945ffa9868491cacd0bc74d9d73c848
It causes the following kind of error when psych is installed as not default gem but regular gem. It's a Fedora Ruby specific case. **This is not the case of Ruby built from source normally.**
```
$ cat test.rb
require 'psych'
Gem.load_yaml # <= The error happens.
```
```
$ ruby test.rb
/usr/lib64/gems/ruby/psych-3.1.0/psych.so: warning: already initialized constant Psych::Parser::ANY
...
/usr/share/gems/gems/psych-3.1.0/lib/psych/parser.rb:34:in `<class:Parser>': superclass mismatch for class Mark (TypeError)
```
It is possibly also related to https://github.com/ruby/psych/issues/386 .
Thank you.
--
https://bugs.ruby-lang.org/
Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>