ruby-dev (Japanese) list archive (unofficial mirror)
 help / color / mirror / Atom feed
* [ruby-dev:50262] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
       [not found] <redmine.issue-13931.20170923114534@ruby-lang.org>
@ 2017-09-23 11:45 ` kimuraw
  2018-09-11  0:10 ` [ruby-dev:50637] " ruby
  2018-10-17  8:18 ` [ruby-dev:50654] " usa
  2 siblings, 0 replies; 3+ messages in thread
From: kimuraw @ 2017-09-23 11:45 UTC (permalink / raw)
  To: ruby-dev

Issue #13931 has been reported by kimuraw (Wataru Kimura).

----------------------------------------
Bug #13931: correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
https://bugs.ruby-lang.org/issues/13931

* Author: kimuraw (Wataru Kimura)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.5.0dev (2017-09-23 trunk 60002) [x86_64-darwin16]
* Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN
----------------------------------------
ruby-dev:50256 で質問した件です。

ruby-2.4以降ではlibrubyのファイル名に実際のリリースバージョンのTEENYが反映されるようになったようですが
macOS上でlibrubyのinstall name(linuxでのsoname相当)がTEENYを含んだもののため、
rubyを2.4.1から2.4.2など更新すると以前のバージョンで作成した拡張ライブラリでLoadErrorが発生します。

linuxなどではsonameをTEENYを含まないものにしているようですので、
macOSでも同様にするのがよいと思います。

~~~
# ubuntu
$ uname -sr
Linux 3.16.0-4-amd64
$ objdump -p libruby.so.2.4.2 | grep SONAME
  SONAME               libruby.so.2.4
# macOS
$ uname -sr  
Darwin 16.7.0
$ otool -D libruby.2.4.2.dylib
libruby.2.4.2.dylib:
/Users/kimuraw/tmp_ruby/ruby24/lib/libruby.2.4.2.dylib # <= includes TEENY in "install name"
~~~

trunkと2.4で起きています。
2.3以前はlibrubyのファイル名のTEENYは常に"0"ですので問題ありません。

trunk r60002のconfigure.inへのパッチを添付します。

---Files--------------------------------
configure.in.diff (672 Bytes)


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

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

* [ruby-dev:50637] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
       [not found] <redmine.issue-13931.20170923114534@ruby-lang.org>
  2017-09-23 11:45 ` [ruby-dev:50262] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib) kimuraw
@ 2018-09-11  0:10 ` ruby
  2018-10-17  8:18 ` [ruby-dev:50654] " usa
  2 siblings, 0 replies; 3+ messages in thread
From: ruby @ 2018-09-11  0:10 UTC (permalink / raw)
  To: ruby-dev

Issue #13931 has been updated by tmm1 (Aman Gupta).

Backport changed from 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN to 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: REQUIRED

Requesting backport to 2.4

https://github.com/Homebrew/homebrew-core/pull/31967#issuecomment-420100406

----------------------------------------
Bug #13931: correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
https://bugs.ruby-lang.org/issues/13931#change-73974

* Author: kimuraw (Wataru Kimura)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.5.0dev (2017-09-23 trunk 60002) [x86_64-darwin16]
* Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: REQUIRED
----------------------------------------
ruby-dev:50256 で質問した件です。

ruby-2.4以降ではlibrubyのファイル名に実際のリリースバージョンのTEENYが反映されるようになったようですが
macOS上でlibrubyのinstall name(linuxでのsoname相当)がTEENYを含んだもののため、
rubyを2.4.1から2.4.2など更新すると以前のバージョンで作成した拡張ライブラリでLoadErrorが発生します。

linuxなどではsonameをTEENYを含まないものにしているようですので、
macOSでも同様にするのがよいと思います。

~~~
# ubuntu
$ uname -sr
Linux 3.16.0-4-amd64
$ objdump -p libruby.so.2.4.2 | grep SONAME
  SONAME               libruby.so.2.4
# macOS
$ uname -sr  
Darwin 16.7.0
$ otool -D libruby.2.4.2.dylib
libruby.2.4.2.dylib:
/Users/kimuraw/tmp_ruby/ruby24/lib/libruby.2.4.2.dylib # <= includes TEENY in "install name"
~~~

trunkと2.4で起きています。
2.3以前はlibrubyのファイル名のTEENYは常に"0"ですので問題ありません。

trunk r60002のconfigure.inへのパッチを添付します。

---Files--------------------------------
configure.in.diff (672 Bytes)


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

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

* [ruby-dev:50654] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
       [not found] <redmine.issue-13931.20170923114534@ruby-lang.org>
  2017-09-23 11:45 ` [ruby-dev:50262] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib) kimuraw
  2018-09-11  0:10 ` [ruby-dev:50637] " ruby
@ 2018-10-17  8:18 ` usa
  2 siblings, 0 replies; 3+ messages in thread
From: usa @ 2018-10-17  8:18 UTC (permalink / raw)
  To: ruby-dev

Issue #13931 has been updated by usa (Usaku NAKAMURA).

Backport changed from 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: REQUIRED to 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: DONE

ruby_2_4 r65112 merged revision(s) 60018.

----------------------------------------
Bug #13931: correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib)
https://bugs.ruby-lang.org/issues/13931#change-74473

* Author: kimuraw (Wataru Kimura)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.5.0dev (2017-09-23 trunk 60002) [x86_64-darwin16]
* Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: DONE
----------------------------------------
ruby-dev:50256 で質問した件です。

ruby-2.4以降ではlibrubyのファイル名に実際のリリースバージョンのTEENYが反映されるようになったようですが
macOS上でlibrubyのinstall name(linuxでのsoname相当)がTEENYを含んだもののため、
rubyを2.4.1から2.4.2など更新すると以前のバージョンで作成した拡張ライブラリでLoadErrorが発生します。

linuxなどではsonameをTEENYを含まないものにしているようですので、
macOSでも同様にするのがよいと思います。

~~~
# ubuntu
$ uname -sr
Linux 3.16.0-4-amd64
$ objdump -p libruby.so.2.4.2 | grep SONAME
  SONAME               libruby.so.2.4
# macOS
$ uname -sr  
Darwin 16.7.0
$ otool -D libruby.2.4.2.dylib
libruby.2.4.2.dylib:
/Users/kimuraw/tmp_ruby/ruby24/lib/libruby.2.4.2.dylib # <= includes TEENY in "install name"
~~~

trunkと2.4で起きています。
2.3以前はlibrubyのファイル名のTEENYは常に"0"ですので問題ありません。

trunk r60002のconfigure.inへのパッチを添付します。

---Files--------------------------------
configure.in.diff (672 Bytes)


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

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

end of thread, other threads:[~2018-10-17  8:18 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <redmine.issue-13931.20170923114534@ruby-lang.org>
2017-09-23 11:45 ` [ruby-dev:50262] [Ruby trunk Bug#13931] correct install_name of libruby on macOS (libruby.2.5.0.dylib -> libruby.2.5.dylib) kimuraw
2018-09-11  0:10 ` [ruby-dev:50637] " ruby
2018-10-17  8:18 ` [ruby-dev:50654] " usa

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).