Project

General

Profile

Actions

環境対応 #1199

closed

gtk2 3.2.3を利用する

Added by Akira Ouchi over 6 years ago. Updated over 6 years ago.

Status:
終了
Priority:
通常
Assignee:
-
Target version:
Start date:
2018-04-04
Due date:
% Done:

0%

プラグイン名:

Description

ruby-gnome2 3.2.2と3.2.3がリリースされたので、3.2.3を利用するよう変更する。

3.2.2 NEWS
https://github.com/ruby-gnome2/ruby-gnome2/blob/3.2.2/NEWS
3.2.3 NEWS
https://github.com/ruby-gnome2/ruby-gnome2/blob/3.2.3/NEWS


Related issues

Related to 提案 #1292: gtk2 3.2.9を利用する終了Akira OuchiActions
Actions #1

Updated by Akira Ouchi over 6 years ago

単純にcore/plugin/gtk/Gemfileを3.2.0→3.2.2もしくは3.2.3と書き換えて、bundle updateしたあと起動しようとすると、以下の通り起動しませんでした。

notice: {MIKUTTER_DIR}/core/miquire_plugin.rb:155:in `block in load': plugin loaded: {MIKUTTER_DIR}/core/plugin/gtk/gtk.rb
Traceback (most recent call last):
    51: from mikutter.rb:42:in `<main>'
    50: from /Users/akkie/mikutter/core/miquire.rb:18:in `miquire'
    49: from /Users/akkie/mikutter/core/miquire.rb:75:in `miquire'
    48: from /Users/akkie/mikutter/core/miquire.rb:75:in `each'
    47: from /Users/akkie/mikutter/core/miquire.rb:76:in `block in miquire'
    46: from /Users/akkie/mikutter/core/miquire.rb:95:in `file_or_directory_require'
    45: from /Users/akkie/mikutter/core/miquire.rb:98:in `miquire_original_require'
    44: from /Users/akkie/mikutter/core/miquire.rb:98:in `require'
    43: from /Users/akkie/mikutter/core/boot/load_plugin.rb:10:in `<top (required)>'
    42: from /Users/akkie/mikutter/core/miquire_plugin.rb:96:in `load_all'
    41: from /Users/akkie/mikutter/core/miquire_plugin.rb:36:in `each_spec'
    40: from /Users/akkie/mikutter/core/miquire_plugin.rb:33:in `each'
    39: from /Users/akkie/mikutter/core/miquire_plugin.rb:33:in `each'
    38: from /Users/akkie/mikutter/core/miquire_plugin.rb:38:in `block in each_spec'
    37: from /Users/akkie/mikutter/core/miquire_plugin.rb:98:in `block in load_all'
    36: from /Users/akkie/mikutter/core/miquire_plugin.rb:146:in `load'
    35: from /Users/akkie/mikutter/core/utils.rb:278:in `atomic'
    34: from /Users/akkie/.rbenv/versions/2.5.0/lib/ruby/2.5.0/monitor.rb:226:in `mon_synchronize'
    33: from /Users/akkie/mikutter/core/utils.rb:278:in `block in atomic'
    32: from /Users/akkie/mikutter/core/miquire_plugin.rb:147:in `block in load'
    31: from /Users/akkie/mikutter/core/miquire_plugin.rb:147:in `each'
    30: from /Users/akkie/mikutter/core/miquire_plugin.rb:149:in `block (2 levels) in load'
    29: from /Users/akkie/mikutter/core/miquire_plugin.rb:146:in `load'
    28: from /Users/akkie/mikutter/core/utils.rb:278:in `atomic'
    27: from /Users/akkie/.rbenv/versions/2.5.0/lib/ruby/2.5.0/monitor.rb:226:in `mon_synchronize'
    26: from /Users/akkie/mikutter/core/utils.rb:278:in `block in atomic'
    25: from /Users/akkie/mikutter/core/miquire_plugin.rb:147:in `block in load'
    24: from /Users/akkie/mikutter/core/miquire_plugin.rb:147:in `each'
    23: from /Users/akkie/mikutter/core/miquire_plugin.rb:149:in `block (2 levels) in load'
    22: from /Users/akkie/mikutter/core/miquire_plugin.rb:146:in `load'
    21: from /Users/akkie/mikutter/core/utils.rb:278:in `atomic'
    20: from /Users/akkie/.rbenv/versions/2.5.0/lib/ruby/2.5.0/monitor.rb:226:in `mon_synchronize'
    19: from /Users/akkie/mikutter/core/utils.rb:278:in `block in atomic'
    18: from /Users/akkie/mikutter/core/miquire_plugin.rb:158:in `block in load'
    17: from /Users/akkie/mikutter/core/miquire_plugin.rb:158:in `load'
    16: from /Users/akkie/mikutter/core/plugin/gtk/gtk.rb:7:in `<top (required)>'
    15: from /Users/akkie/mikutter/core/miquire.rb:18:in `miquire'
    14: from /Users/akkie/mikutter/core/miquire.rb:75:in `miquire'
    13: from /Users/akkie/mikutter/core/miquire.rb:75:in `each'
    12: from /Users/akkie/mikutter/core/miquire.rb:76:in `block in miquire'
    11: from /Users/akkie/mikutter/core/miquire.rb:95:in `file_or_directory_require'
    10: from /Users/akkie/mikutter/core/miquire.rb:98:in `miquire_original_require'
     9: from /Users/akkie/mikutter/core/miquire.rb:98:in `require'
     8: from /Users/akkie/mikutter/core/mui/cairo_cell_renderer_message.rb:3:in `<top (required)>'
     7: from /Users/akkie/mikutter/core/miquire.rb:18:in `miquire'
     6: from /Users/akkie/mikutter/core/miquire.rb:75:in `miquire'
     5: from /Users/akkie/mikutter/core/miquire.rb:75:in `each'
     4: from /Users/akkie/mikutter/core/miquire.rb:76:in `block in miquire'
     3: from /Users/akkie/mikutter/core/miquire.rb:95:in `file_or_directory_require'
     2: from /Users/akkie/mikutter/core/miquire.rb:98:in `miquire_original_require'
     1: from /Users/akkie/mikutter/core/miquire.rb:98:in `require'
/Users/akkie/mikutter/core/mui/cairo_miracle_painter.rb:21:in `<top (required)>': uninitialized constant Gtk::Object (NameError)
Did you mean?  Object

githubで変更点をにらめっこしてみましたが私のRuby力は53なのでむりでした。

Actions #2

Updated by Izumi Tsutsui over 6 years ago

debian でも ruby-gnome2 3.2.3 + mikutter 3.6.5 では同じエラーで起動しないそうです
https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=894816

Actions #3

Updated by dai lxr over 6 years ago

debian でも ruby-gnome2 3.2.3 + mikutter 3.6.5 では同じエラーで起動しないそうです

ruby-gnome2 3.2.1 + mikutter 3.6.5 ならば起動しました。

Actions #4

Updated by Akira Ouchi over 6 years ago

ruby-gnome2 3.2.1の動作確認状況は #1084 でコメントがあり、3.2.1までは特に問題なかったようです。 # 関連チケットの追加ができない(?)

Actions #5

Updated by Izumi Tsutsui over 6 years ago

NetBSD/i386 7.1.2 + pkgsrc-2018Q1 で ruby-gnome2 3.2.3 を手動で作ってみましたが
同様に

/usr/pkg/share/mikutter/core/mui/cairo_miracle_painter.rb:21:in `<top (required)>': uninitialized constant Gtk::Object (NameError)
Did you mean?  Object

ですね……

Actions #6

Updated by Izumi Tsutsui over 6 years ago

いろいろ試行錯誤してみましたが、 ruby-gnome2 3.2.1 → 3.2.2 の間の glib2 の以下の変更
https://github.com/ruby-gnome2/ruby-gnome2/commit/9b76f52c47d87fce6d8b000e5777a830d81d5aa8#diff-9047fbc780bec1b9e7da7a0219e53865
を revert して ruby-gnome2 の glib2 gem を作ると mikutter 3.6.5 は問題なく起動するようです。

ruby-gnome2 側で非互換な変更が入っているという気はしますが、理屈をわかっていません……

Actions #7

Updated by toshi_a 初音 over 6 years ago

Gtk::ObjectはGtk2のGObjectに対応するクラスで、Gtk3では消えているやつですね。
アップデート内容まだ見てないのですが、名前が変わっているならmikutter側で新たな名前を参照するように変更して対応することになるはずです。

MiraclePainterがGtk::Objectを利用しているのは今となっては全く意味がなく、別で進めているGtk3対応の足かせにもなっているのでやめようと思っていたところでした。とはいえMiraclePainterの根本的な再実装を待っているとかなり時間がかかるので、先にこちらの問題を対応したいです。

Actions #8

Updated by Izumi Tsutsui over 6 years ago

ruby-gnome2 の gtk2 自体には特に API的変更は入っていないので、
https://github.com/ruby-gnome2/ruby-gnome2/commits/master/gtk2
glib2 側の変更がなにかしらイケてないという感じはします(根拠なし)

Actions #10

Updated by Akira Ouchi over 6 years ago

https://github.com/ruby-gnome2/ruby-gnome2/issues/1154#issuecomment-379468372 より、修正いただけたようです。
(daiさん、kouさん、ありがとうございます!)

上記コメントのworkaroundを参考にGLib::Type["GtkObject"].to_classの方を使って、
ruby-gnome2 3.2.3でmikutterが起動することを確認できました。

(追記) Gemfile変更ミスってて3.2.0でチェックしてました……3.2.3にして以下のパッチを当てると今度は「superclass mismatch for class Widget (TypeError)」が出るので、ruby-gnome2の修正も必要そうです。ヒーン

diff --git a/core/mui/cairo_miracle_painter.rb b/core/mui/cairo_miracle_painter.rb
index 673f382b..edbdba7b 100644
--- a/core/mui/cairo_miracle_painter.rb
+++ b/core/mui/cairo_miracle_painter.rb
@@ -18,7 +18,7 @@ miquire :lib, 'uithreadonly'

 # 一つのMessageをPixbufにレンダリングするためのクラス。名前は言いたかっただけ。クラス名まで全てはつね色に染めて♪
 # 情報を設定してから、 Gdk::MiraclePainter#pixbuf で表示用の GdkPixbuf::Pixbuf のインスタンスを得ることができる。
-class Gdk::MiraclePainter < Gtk::Object
+class Gdk::MiraclePainter < GLib::Type["GtkObject"].to_class
   extend Gem::Deprecate

   type_register
Actions #11

Updated by Izumi Tsutsui over 6 years ago

NetBSD/i386 7.1.2 + pkgsrc-2018Q1 で ruby-gnome2 3.2.3 に対して
https://github.com/ruby-gnome2/ruby-gnome2/commit/9db8371c0a9a7bca48bb3f2b57687d0c26e898e8
の修正を入れて手動で作って入れてみました。
→その状態で mikutter 3.6.5 は正常に起動しました。

なので 3.2.4 が出れば直ると思います。
(すぐ出るのならば pkgsrc 含め様子見ですが……)

Actions #12

Updated by dai lxr over 6 years ago

Akira Ouchi さんは書きました:

(追記) Gemfile変更ミスってて3.2.0でチェックしてました……3.2.3にして以下のパッチを当てると今度は「superclass mismatch for class Widget (TypeError)」が出るので、ruby-gnome2の修正も必要そうです。ヒーン

これならどうでしょうか?

% diff -u /usr/share/mikutter/core/mui/cairo_miracle_painter.rb.orig /usr/share/mikutter/core/mui/cairo_miracle_painter.rb
--- /usr/share/mikutter/core/mui/cairo_miracle_painter.rb.orig    2018-03-09 20:19:54.000000000 +0900
+++ /usr/share/mikutter/core/mui/cairo_miracle_painter.rb    2018-04-08 11:33:35.193776072 +0900
@@ -16,6 +16,8 @@
 miquire :mui, 'photo_pixbuf'
 miquire :lib, 'uithreadonly'

+Gtk::Object = GLib::Type["GtkObject"].to_class
+
 # 一つのMessageをPixbufにレンダリングするためのクラス。名前は言いたかっただけ。クラス名まで全てはつね色に染めて♪
 # 情報を設定してから、 Gdk::MiraclePainter#pixbuf で表示用の GdkPixbuf::Pixbuf のインスタンスを得ることができる。
 class Gdk::MiraclePainter < Gtk::Object
Actions #13

Updated by Akira Ouchi over 6 years ago

dai lxr さんは書きました:

これならどうでしょうか?

おお、動きました。ありがとうございます。
なるほど、ほかでもGtk::Objectを使うから、Workaroundの通りGtk::Objectに代入するやつをひとつ書いておけばいいわけですね(?)

Actions #14

Updated by toshi_a 初音 over 6 years ago

  • Status changed from 新規 to 終了

諸々ありがとうございます。
mikutterでは、gtk2 gem 3.2.0を使うように依存関係を明示しているため、3.2.3には移行せずに、この修正が入ったバージョンがリリースされたらアップデートを再検討しましょう。パッケージなのでgtk2 gemのバージョンを新しくせざるを得ない場合は #1199-12 のワークアラウンドでお願いします。

#3.2.1にするというチケット完全に忘れてた

Actions #15

Updated by Akira Ouchi about 6 years ago

Actions

Also available in: Atom PDF