やること: チケット
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 - 提案 #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 - 提案 #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 - 機能 #706 (却下): saved searchをデータソースとして提供する
https://dev.mikutter.hachune.net/issues/706
2014-08-05T01:53:45Z
toshi_a 初音
toshi.alternative@gmail.com
<p>saved searchプラグインは、タブの提供をやめて、抽出タブのデータソースを提供する。</p>
<p>saved searchデータソースは、利用されているときだけ自動更新をかける。<br />不要な検索タブが表示されないようになること、データソースとタブが分離するので、起動時にUI上に空のタブが生成されてしまう問題などを回避できる。</p>
<p>ただし、「保存した検索」を削除する機能をどこかにつけなければいけない。現状ではタブのコマンドになっているが、これは無くなる。</p>
mikutter - 最適化 #564 (終了): ダークマターが潜むプラグインの特定
https://dev.mikutter.hachune.net/issues/564
2013-02-12T15:39:36Z
toshi_a 初音
toshi.alternative@gmail.com
<p>実装しているとメモリリークするプラグインを特定する</p>
<a name="導入済みプラグインの取得方法"></a>
<h1 >導入済みプラグインの取得方法<a href="#導入済みプラグインの取得方法" class="wiki-anchor">¶</a></h1>
<p>以下の方法で導入されているプラグインのインスタンスを取得できる。ただし、現在のdevelopブランチにはバグで「.rb」が末尾についたスラッグのプラグインが生成されてしまう問題があるのでrejectを使う。<br /><pre>
Plugin.instances.reject{ |x| x.to_s.end_with?(".rb") }
</pre></p>
<a name="依存するプラグイン"></a>
<h1 >依存するプラグイン<a href="#依存するプラグイン" class="wiki-anchor">¶</a></h1>
<p>プラグインには依存関係があり、 <strong>親プラグインがロードされないと子プラグインはロードされない</strong> 。必ず --plugin オプションには親プラグインも同時に指定する(「--plugin=home_timeline」は誤り。「--plugin=gui,gtk,home_timeline」とする)。<br />依存関係はspecファイルによってのみ定義されていて、specファイルの内容は以下のようなコードで取得できる<br /><pre>
plugins[0].instance_eval{ @spec }
</pre></p>
<a name="ロードするプラグインを限定する"></a>
<h1 >ロードするプラグインを限定する<a href="#ロードするプラグインを限定する" class="wiki-anchor">¶</a></h1>
<p>特定のプラグインだけロードしたい場合は、「--plugin」オプションでスラッグを指定する。複数のプラグインを指定する場合はカンマで区切る。--pluginを二つ以上指定することはできない。<br /><pre>
./mikutter.rb --plugin="gui,gtk,rest,streaming,home_timeline,memory_profiler" --debug
</pre><br />この方法でプラグインスラッグを指定すると、そのスラッグにマッチしないプラグインはロードされない。</p>
<a name="バージョン"></a>
<h1 >バージョン<a href="#バージョン" class="wiki-anchor">¶</a></h1>
<p>0.2.2(develop ブランチ)の新機能なので、他のバージョンでは計測できない。</p>
<a name="その他"></a>
<h1 >その他<a href="#その他" class="wiki-anchor">¶</a></h1>
<p>ぺんぎんさんがんばれ<br />問題がわかった/わからなかったら、Twitterじゃなくてこっちで教えてください。<br />質問もIRCかこのチケットのコメントにしてください。</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 - 機能 #120 (終了): ふぁぼりを解除したら、favorited byのところから自分のアイコンを取り除く
https://dev.mikutter.hachune.net/issues/120
2011-04-26T16:24:52Z
toshi_a 初音
toshi.alternative@gmail.com
<p>ふぁぼり解除時に「xx Fav」のアイコンから、自分のアイコンを取り除くようにする。<br />テロ対策のために他のユーザのふぁぼ削除については一切対応しない</p>
mikutter - 機能 #119 (終了): リツイートを削除したら、retweeted byのところから自分のアイコンが消えるようにする
https://dev.mikutter.hachune.net/issues/119
2011-04-26T16:18:16Z
toshi_a 初音
toshi.alternative@gmail.com
<p>自分がリツイートを削除したら、そのつぶやきの「xx RT」のところの自分のアイコンを取り除く。</p>
mikutter - 機能 #118 (終了): リツイートのキャンセルがわかりにくい
https://dev.mikutter.hachune.net/issues/118
2011-04-26T16:16:20Z
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>