やること: チケット
https://dev.mikutter.hachune.net/
https://dev.mikutter.hachune.net/favicon.ico?1619448608
2022-01-09T06:48:18Z
やること
Redmine
mikutter - バグ #1577 (終了): 抽出タブ絞り込み条件で「投稿したクライアントアプリケーション名」に「含む」を設定するとクラッシュする
https://dev.mikutter.hachune.net/issues/1577
2022-01-09T06:48:18Z
toshi_a 初音
toshi.alternative@gmail.com
<p>再現手順の通り実行すると、抽出タブの絞り込みでクラッシュする。<br />Mastodonのstatusはclient情報をもっていない ( <code>nil</code> )ことがある。<br />この抽出条件は<br /><pre><code class="ruby syntaxhl"><span class="n">message</span><span class="p">.</span><span class="nf">client</span><span class="p">.</span><span class="nf">include?</span><span class="p">(</span><span class="s1">'mikutter'</span><span class="p">)</span>
</code></pre><br />のようなコードにコンパイルされる。clientがnilを返す場合も考慮する必要がある。</p>
<p>Twitterでは、すべてのMessageがsourceの戻り値として空文字列を返すようにしていた気がするので再現しないと思う。<br />また、「=」の場合は <code>==</code> で比較されるので、クラッシュしない。</p>
mikutter - 提案 #1575 (終了): rubocopで定めたコーディング規約の適用方針・範囲の決定
https://dev.mikutter.hachune.net/issues/1575
2022-01-08T08:25:24Z
toshi_a 初音
toshi.alternative@gmail.com
<p>将来的にすべてのソースコードがrubocopのlintに合格しないとmergeできないようにして、常にコーディング規約を満たした状態に持っていく。</p>
<a name="方針"></a>
<h1 >方針<a href="#方針" class="wiki-anchor">¶</a></h1>
<p>10年くらい前までやっていた行末endなどのコーディング規約は既に廃止しているが、一気にやるとdiffがえらいことになってblameなどで若干面倒になるので、少しでも編集したメソッドに関してだけ修正していっている。<br />雑に全部auto correctすると、相当なdiffが発生する。diffの量を小さくするため、次のようにファイルを優先度で分類し、やる価値が高いと判断したものにだけ適用する。</p>
1. 優先度低: 何年もの間、全く開発者から参照されず、書き換えられていないファイル
<ul>
<li>古いコードほど今と異なる規約でコーディングされているので、diffが大きくなっていく傾向にある</li>
<li>そもそも誰も読まないので、コーディング規約を守っていても違反していてもあんまり関係がない</li>
<li>diffが大きいことからリグレッションの可能性が相対的に上がり、検証がだるい</li>
</ul>
2. 優先度高: 頻繁に開発者から参照され、書き換えが行われるようなファイル
<ul>
<li>歴史が浅いため、規約を適用しても小さなdiffですむ</li>
<li>書き換えが最近行われているので、直近で開発者が読む可能性が高く、コーディング規約を守る重要性が高い</li>
<li>リグレッションが発生しても、最近修正した機能ならまだ覚えているので、修正が容易</li>
</ul>
<a name="手順"></a>
<h1 >手順<a href="#手順" class="wiki-anchor">¶</a></h1>
<p>一気にやるとdiffがえらいことになってblameなどで若干面倒になるので、新規ファイルや著しい変更があったファイルに限定したい。<br />これを満たすために、rubocop対象のファイルをブラックリスト形式で管理する。ブラックリストは、作成した後は減らすことしかしないため、全体のエラー率は時間の経過とともに下がっていく。</p>
<p>ブラックリストは以下の条件で作成する:</p>
<ul>
<li>mikutter 4.1.0(rubocop導入したひとつ前のバージョン)で存在したすべてのファイル</li>
</ul>
<p>今後、以下の条件を満たすものは即座にブラックリストから削除する:</p>
<ul>
<li>mikutter 4.1.0以降で50%以上の行が変更されたファイル(割合はいろいろ変えて様子を見て決定する)<br /> 大幅にリファクタリングしたファイルなどはどうせdiffがでかくなっていてblameのとき邪魔なので、いっそのこと機械的にやってしまう</li>
</ul>
<a name="このIssueでやること"></a>
<h1 >このIssueでやること<a href="#このIssueでやること" class="wiki-anchor">¶</a></h1>
<ol>
<li>ブラックリストの作成</li>
<li>ブラックリストを除外したファイルのルールを検証する方法の確立</li>
<li>ブラックリストから除外対象となったファイルを除く方法の確立</li>
<li>2を使ってコードをリファクタリングする</li>
</ol>
<p>適用するバージョンは5.0(メンテナンスしている最も古いバージョン)にする。gtk3のコードに適用したいが、そうするとそれなりのdiffが発生してしまい、mergeが困難となることが予想されるため。</p>
<a name="懸念"></a>
<h1 >懸念<a href="#懸念" class="wiki-anchor">¶</a></h1>
<p>開発者が参照するコードは、頻繁に変更もされているはずだという前提に立っているが、なかには長い間変更されていないが参照されるコードというものも存在する。<br />この基準ではそういったコードをフォローできていない。</p>
<a name="他の方法"></a>
<h1 >他の方法<a href="#他の方法" class="wiki-anchor">¶</a></h1>
<p>rubocop todoは、コードの古さに応じてルールの適用方針を変えていく考え方とはあまり相性がよくなさそうなので、利用を断念した。</p>
mikutter - バグ #1574 (終了): TCPコネクションが確立できないときにmastodon_sse_stramingがクラッシュする
https://dev.mikutter.hachune.net/issues/1574
2022-01-02T08:18:12Z
toshi_a 初音
toshi.alternative@gmail.com
<p>mastodon_sse_stramingが、コネクションを切断された | 確立できなかった場合の処理を実装していない。</p>
mikutter - バグ #1569 (終了): ruby3.1.0環境で新規confでの起動に失敗する
https://dev.mikutter.hachune.net/issues/1569
2022-01-01T11:31:10Z
あひる 家鴨
<p>ruby 3.1.0 環境で新規confで起動しようとすると、下記エラーで落ちます。<br /><pre>
/home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:178:in `require': cannot load such file -- mathn (LoadError)
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:178:in `next_prime'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:217:in `save_to_stream'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:292:in `block in save_to_file'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:292:in `open'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/mo.rb:292:in `save_to_file'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/tools/msgfmt.rb:58:in `run'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/gettext-3.4.1/lib/gettext/tools/msgfmt.rb:38:in `run'
from /home/ahiru/work/mikutter/mikutter/plugin/uitranslator/uitranslator.rb:37:in `block in spec='
from /home/ahiru/work/mikutter/mikutter/plugin/uitranslator/uitranslator.rb:34:in `each'
from /home/ahiru/work/mikutter/mikutter/plugin/uitranslator/uitranslator.rb:34:in `spec='
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:156:in `block (2 levels) in load'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/pluggaloid-1.7.0/lib/pluggaloid/plugin.rb:39:in `instance_eval'
from /home/ahiru/work/mikutter/mikutter/vendor/bundle/ruby/3.1.0/gems/pluggaloid-1.7.0/lib/pluggaloid/plugin.rb:39:in `create'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:155:in `block in load'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `block in atomic'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `synchronize'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `atomic'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:147:in `load'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:149:in `block (2 levels) in load'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:148:in `each'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:148:in `block in load'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `block in atomic'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `synchronize'
from /home/ahiru/work/mikutter/mikutter/core/utils.rb:288:in `atomic'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:147:in `load'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:99:in `block in load_all'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:40:in `block in each_spec'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:35:in `each'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:35:in `each'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:38:in `each_spec'
from /home/ahiru/work/mikutter/mikutter/core/miquire_plugin.rb:98:in `load_all'
from /home/ahiru/work/mikutter/mikutter/core/boot/load_plugin.rb:14:in `<top (required)>'
from mikutter.rb:55:in `require'
from mikutter.rb:55:in `<main>'
</pre></p>
ruby3.1.0からgettextがrequireしているprime gemがdefault gemsからbundle gemsに移行されたことが原因のようです。<br />具体的にはprimeをrequireしようとした結果、LoadErrorとなりエラーハンドリングでmathnがrequireされているが、そんな依存はないのでmathnもLoadErrorとなり上記エラーを発生させています。<br />参考までにprime gemがdefault gemからbundle gemに移行した情報は下記のとおりです。
<ul>
<li><a class="external" href="https://bugs.ruby-lang.org/issues/17873">https://bugs.ruby-lang.org/issues/17873</a></li>
<li><a class="external" href="https://stdgems.org/#bundled-gems-in-ruby-310">https://stdgems.org/#bundled-gems-in-ruby-310</a></li>
</ul>
mikutter - 提案 #1567 (終了): commandの「引用」を削除する
https://dev.mikutter.hachune.net/issues/1567
2021-12-31T14:49:05Z
toshi_a 初音
toshi.alternative@gmail.com
<p>非公式リツイート…なにもかもみな懐かしい</p>
mikutter - 提案 #1556 (終了): Gtk::Widget#applyを削除する
https://dev.mikutter.hachune.net/issues/1556
2021-12-12T06:11:49Z
toshi_a 初音
toshi.alternative@gmail.com
<p>core/mui/gtk_extension.rb に定義されているapplyは削除し、tapなどで代用する。</p>
mikutter - 提案 #1532 (終了): gtk3: gladeファイルの使用は続ける?中止する?
https://dev.mikutter.hachune.net/issues/1532
2021-11-03T05:25:58Z
Shibafu Midorino
<p>gtk3ブランチではいくつかのWindowのレイアウトが.glade拡張子のXMLファイルによって記述されています。<br />GladeはGTK界隈のUIデザインツールですが、理由があってgtk2時代には採用しなかった話を聞いた覚えがあります。</p>
<p>このまま使う気があるのか、やっぱりやめる方向でRubyコードでレイアウトを組むように戻すか意思確認をしたいです。</p>
mikutter - 提案 #1484 (終了): CLIコマンドのプラグインサポート
https://dev.mikutter.hachune.net/issues/1484
2021-01-24T05:10:42Z
Shibafu Midorino
<p>プラグインからCLIコマンドを提供し、実行できるようにする手段が欲しいです。<br />これがあると、GUIなしでWorldを生成するインタラクティブ処理が提供できたりします。(昔の account サブコマンドみたいな)</p>
<p>以前に <a class="issue tracker-1 status-2 priority-4 priority-default" title="バグ: mikutter account コマンドが使えなくなっている (実装待ち)" href="https://dev.mikutter.hachune.net/issues/1238">#1238</a> などを見て、需要はあるけどユーザからは簡単に手が出せないから諦めになってるのかなと思っています。</p>
<p>雑に考えた感じだと、プラグインのロードを伴わずにCLIコマンドを列挙するための仕組みとか、実際にプラグインに処理を渡す時にはコアルーチンと最低限の依存関係のロードが済んだ状態の作りこみなんかは必要かなと。<br />今ある core/boot/shell だとその辺はかなり割り切っているので、ちゃんと仕組みにしないといけないですね…</p>
mikutter - 提案 #1427 (終了): 起動時、直近のリプライが読み込まれない
https://dev.mikutter.hachune.net/issues/1427
2020-01-07T12:16:22Z
toshi_a 初音
toshi.alternative@gmail.com
<p><a class="issue tracker-12 status-2 priority-4 priority-default" title="提案: mastodon プラグインに追加したい機能 (実装待ち)" href="https://dev.mikutter.hachune.net/issues/1424">#1424</a> より</p>
<ul>
<li>mikutter 起動時に、mastodon の reply タブに起動時点から過去に遡って一定数のリプライを表示する
<ul>
<li>TwitterだとAPIがそういう仕様だったということかもしれませんが、<br /> 現状の mastdon plugin では起動以降のリプライのみの表示<br /> (ただし、Twitter APIも今は「過去xx個のリプライ」ではなく「過去N日間のリプライ」に変わっている気がする)</li>
</ul></li>
</ul>
<p>とのことだが、普通に不便なので実装する。</p>
mikutter - バグ #1251 (終了): mikutterの説明文が適切ではない
https://dev.mikutter.hachune.net/issues/1251
2018-05-22T06:28:51Z
Yuto Tokunaga
yuntan.sub1@gmail.com
<p>mikutterがどのようなソフトウェアであるかということに関して,現在以下のような説明がなされています.</p>
<ul>
<li>simple, powerful and moeful twitter client (README)</li>
<li>全てのミク廃、そしてTwitter中毒者へ贈る、至高のTwitter Clientを目指すTwitter Client。略して至高のTwitter Client。 (README)</li>
<li>simply, powerfully, and moefully twitter client (<a class="external" href="https://mikutter.hachune.net/">https://mikutter.hachune.net/</a> )</li>
<li>plugin-extensible Twitter client (debian package <a class="external" href="https://packages.debian.org/ja/sid/mikutter">https://packages.debian.org/ja/sid/mikutter</a> )</li>
<li>至高のTwitterクライアント (debian mikutter.desktop)</li>
</ul>
<p>しかし,以下の事実によりTwitter以外のWebサービスも扱えるようになったことで,Twitter clientである点のみに触れたこれらの説明は最早適切ではないと考えられます.</p>
<ul>
<li>サードパーティプラグインがModelを定義し,それをタイムラインに表示できる機能を追加</li>
<li>World機能の追加</li>
</ul>
mikutter - 機能 #722 (終了): 機能追加:ユーザスキンの適用
https://dev.mikutter.hachune.net/issues/722
2014-10-19T15:42:13Z
Satoshi Okuno
moguno12@gmail.com
<p>TLで言っていた件です。<br />下記仕様のユーザスキンの仕組みを提案します。</p>
<p>(1)ユーザースキンディレクトリ<br />ユーザースキンは~/.mikutter/skin/のサブディレクトリに格納する事にします。</p>
<p>ユーザースキンディレクトリはUserConfig[:skin_dir]に相対パスで指定する事とします。</p>
<p>(2)設定画面<br />設定画面はプラグインとして実装します。<br />肝は前述のUserConfig[:skin_dir]の設定です。</p>
<p>設定画面は複数インストールされたスキンから1つを選ぶI/Fを持ちます。<br />現状は*.pngのあるディレクトリをユーザースキンディレクトリ候補としています。</p>
<p>これは最近出てきたスキン「miq」をそのまま展開して使える様にと言うポリシーです。<br />(miq/darkgray/64/*.pngとかそんな階層になってるので)</p>
<p>でも、これだとWebでのプレビュー用pngを置いているディレクトリもピックアップされるのでイマイチです。</p>
<p>ディレクトリ構成を決めてしまってもいいかも知れません。</p>
<p>ユーザースキンの変更は再起動にて反映される様にします。</p>
<p>(3)画像ファイルの優先度<br />ユーザースキンは全画像を用意する必要は無く、存在しない画像はデフォルトのスキンが適用されます。<br />それでもダメならデフォルトの画像(後述)を表示します。</p>
<p>(4)プラグインへのSkinの解放<br />miqでは一部のプラグインのアイコンも提供してくれています。<br />折角なのでプラグインもスキンの恩恵を受けられる様にしたいです。</p>
<p>具体的にはSkin::get()にデフォルト画像を渡せる様にします。</p>
<p>プラグインからはこんな感じに使います。第二引数がデフォルトの画像のパスです。</p>
<p>Skin.get(“hoge.png”, "プラグイン自前のhoge.png”))</p>
<p>ユーザースキンもしくはデフォルトスキンに該当する名前の画像があればそれを採用し、無ければプラグイン内蔵の画像を返す様にしたいなと。</p>
<p>なお、Skin.getの第二引数を省略した場合、従来通り、デフォルトスキンのnotfound.pngが適用されます。</p>
<p>こんな感じで実働する物を作ってみましたので添付します。<br />ぜひ一度揉んで頂ければと思います。</p>
mikutter - 最適化 #561 (終了): 大量の実行待ちイベントが発生した時の処理速度の改善
https://dev.mikutter.hachune.net/issues/561
2013-01-23T15:48:52Z
toshi_a 初音
toshi.alternative@gmail.com
<a name="割り込み実行"></a>
<h1 >割り込み実行<a href="#割り込み実行" class="wiki-anchor">¶</a></h1>
<p>現在はDelayerに登録されたブロックは登録された順に実行されているが、大量のイベントがキューイングされるとユーザの入力によって発生するイベントや、GUI関連のイベントの実行が遅れる。<br />この場合でも、ユーザの入力のレスポンスを割り込み実行できれば早くなりそう。</p>
<a name="まとめて実行"></a>
<h1 >まとめて実行<a href="#まとめて実行" class="wiki-anchor">¶</a></h1>
<p>updateイベントなど、複数のデータを一つのデータにまとめられるイベントが大量にキューイングされているなら、それらが別々のプラグインの別々の処理によって発生していたとしても、まとめて単一のイベントにしてしまって良い。<br />Pluginクラスにそのような仕組みを導入できないか検討する。</p>
mikutter - 機能 #448 (却下): 関連ツイートを検出するフィルタ
https://dev.mikutter.hachune.net/issues/448
2012-03-27T17:08:17Z
toshi_a 初音
toshi.alternative@gmail.com
<p>smartthreadを拡張して、スレッドに特定のツイートに関係するツイートを追加することができるフィルタを定義する。</p>
mikutter - バグ #198 (終了): ダークマターの討伐
https://dev.mikutter.hachune.net/issues/198
2011-05-29T16:31:06Z
toshi_a 初音
toshi.alternative@gmail.com
<p>長時間起動していると、際限なくメモリを消費していく。</p>
mikutter - 機能 #14 (終了): つぶやきフィルタリング条件設定用のウィジェットを作る
https://dev.mikutter.hachune.net/issues/14
2010-12-22T18:58:20Z
toshi_a 初音
toshi.alternative@gmail.com
<p>つぶやきをフィルタリングする複雑な条件を指定できるようにする。<br />UIはこんなかんじ。</p>
<p><a class="external" href="https://docs.google.com/drawings/edit?id=1fWpvdCMi8jZfyzXFASpQ6Nq1WD69t6TGky6Dg213xRs&hl=en&authkey=CPW80b0G">https://docs.google.com/drawings/edit?id=1fWpvdCMi8jZfyzXFASpQ6Nq1WD69t6TGky6Dg213xRs&hl=en&authkey=CPW80b0G</a></p>
できることは:
<ul>
<li>ユーザのスクリーンネーム</li>
<li>本文</li>
<li>投稿クライアント名<br />演算子は</li>
<li>=(完全一致)</li>
<li>≠(不一致)</li>
<li>〜(正規表現で一致)</li>
<li>⊆(部分集合・include?)</li>
</ul>