-
Notifications
You must be signed in to change notification settings - Fork 168
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
プログレスバーの表示切り替え方法を変更して切り替えが正しく反映されるようにする #1727
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -56,6 +56,7 @@ class CMainStatusBar : public CDocListenerEx{ | |||||
|
||||||
//設定 | ||||||
bool SetStatusText(int nIndex, int nOption, const WCHAR* pszText, size_t textLen = SIZE_MAX); | ||||||
void ShowProgressBar(bool bShow) const; | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 対処しなくてよいですが、const付けたらいけなくないですかね。 ・const付けたメソッド = クラスが表現する何かの状態を変えないメソッド。 プログレスバーを表示するか否かは、「サクラエディタのメインステータスバー」の状態だと思います。 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. メンバ変数を書き換えないので付けたほうがいいかな?と思っていました。 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ここらへん微妙ですよね。handle 経由で状態を変更しているので付けない方が良いのか、それともメンバ変数の値は変更していないので付けたほうが良いのか。 ちょっと別のケースですが、引数に const を付けた方が可読性が上がるのに付けないコードをよく見かけます(どこで?)。モーなんだかconst教とかいう宗教法人作って節税して選挙に当選して法律でconst付加を義務付けてほしいぐらいです。 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
はい、その感覚は正しいと思います。 自分が言ってたのは逆で、メソッドの意味合い的に非constなメソッドだから、 修正量多くなりますし、対応する必要はないと思うんですが。 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. これも指摘じゃないですが、こんな考え方もあります。
Suggested change
こうしておくと、表示するとき「引数なし」で呼び出せるようになります。 メリットは「ShowProgressbar(true);のtrueってなんじゃ~?」を確認する必要がなくなることです。 |
||||||
private: | ||||||
CEditWnd* m_pOwner; | ||||||
HWND m_hwndStatusBar; | ||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
指摘(≒修正要求的な何か)ではないですが、条件式が若干悩ましいと思いました。
「ステータスバーがあるとき(ハンドルが0以外)、かつ、プログレスバーがあるとき(ハンドルが0以外)」
・・・つまり、プログレスバーが無かったらこのif文には入らないんですよね。
「Showする」ってことは「見えてない」んですけど、存在してなければならないっていう縛り。
「見えてないなら存在しないのと同じ」と言えるかどうかは少し微妙なんですが、
非表示のプログレスバーになにか使い道があるようには思えないので、
必要なときだけ作成するアプローチに変えてもいいんじゃないかなと思います。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
今の実装だと、ステータスバーとプログレスバーは同時に作成され同時に破棄されるように見えます。
(CMainStatusBar以外に作成・破棄をする箇所はなさそうです。)
したがって「見えてはいないが存在する」ことになるのでこの条件にしています。
不可視のプログレスバーに存在意義があるのかは僕も疑問を感じるので、プログレスバーの表示切り替え時に作成・破棄するようにして、ShowProgressBarは作成したプログレスバーのハンドルを返すようにしても良いかもしれません。