[スレッド全体]

2014/5/16 (金) 00:29:53 もか  
INCM1.23a
[2183] Re5:不具合:「開きません」のキャンセルが存在しません
MessageBoxやDialogBox*(ついでにSHBrowseForFolder、GetOpenFileName等)は内部でGetMessage等を呼び出してメッセージ処理をするから、
BlockingHookと同じように他のウィンドウのメッセージが処理されることを意識する必要があるってことですね
(サクラのコードはBlockingHookもほとんど他の処理が走ることを考慮していませんけど)

VMessageBoxFを表示中にさらにVMessageBoxFが表示されることがあるようです。
何かのダイアログが表示された状態で、親ウィンドウにWM_CLOSEが送られてきたとか。
ためしに、編集中ドキュメントを[X]で閉じようとして「保存しますか?」ときかれてきて、
その状態でタスクバー(Win7)から「このウィンドウを閉じる」を選んだら、
もう一つ「保存しますか?」が表示されました。
1つめが他のダイアログだった場合は、VMessageBoxFのszBufはstaticなので、
2つめをキャンセルして1つめに戻ってきた場合に、よろしくないんじゃないでしょうか。
LR4さんの代替案ならWarpでコピーされて問題なさそうです。

考慮したほうがいいことで思いつくことは
1.バッファのリサイクル(LS/LSW/to_*char)
2.staticになってる変数等の再入問題
3.API呼び出し前にチェックしたファイル・ウィンドウ・共有変数等の内容が変更になっている可能性
4.プロセス(親ウィンドウ)の終了
とかいろいろありますが現状は結構手抜きのはず。

2014/5/16 (金) 09:50:12 LR4  
Mozilla/5.0 (Windows NT 6.1; rv:29.0) Gecko/20100101 Firefox/29.0
[2186] Re6:不具合:「開きません」のキャンセルが存在しません
残念なことですが、複数のメッセージボックスを表示している場合ですが、*各メッセージボックスの文字列バッファが独立したものになっていても*、どのメッセージボックスに対するCtrl+Cも、常に最後に出したメッセージボックスのテキストがクリップボードに入ります。
最後のメッセージボックスを閉じるとひとつ前のメッセージボックスのテキストになります。
(MessageBox APIの側で常に末尾スタックに積まれたバッファポインタを参照しているのかな?という挙動です)

サクラとは別に、Visual Studioが生成する最も単純なWin32 Appに少し手を加えただけのプログラムで検証しても同様でした。

サクラでは検索ボックスと置換ボックスを同時に出して、
検索ボックス:検索条件を指定してください
置換ボックス:前方(↓) に文字列 'x' が1つも見つかりません
のメッセージを同時に出すことができます。
上記に加えて、「閉じる前に保存しますか?」も簡単に出せますね。

メッセージフックでもして自コード内にクリップボード処理を回せば矯正できるとは思いますが、さすがにそれはアレなので、複数表示についてはあきらめて期待通りには動かないのが「仕様」ということにしておくほうが賢明と思います。
1個だけ表示しているときは期待通り動く、というところまでの対策で妥協しましょう(汗)

2014/5/16 (金) 10:30:39 LR4  
Mozilla/5.0 (Windows NT 6.1; rv:29.0) Gecko/20100101 Firefox/29.0
[2187] Re7:不具合:「開きません」のキャンセルが存在しません
> 最後のメッセージボックスを閉じるとひとつ前のメッセージボックスのテキストになります。

すみません、必ずしもこのルール通りではないようです。時折、違う挙動が起きるような?…
ちなみに、メモ帳でも検索ダイアログの「"x"が見つかりません」と「無題 への変更内容を保存しますか?」を同時に出したりできますが、やはり変な挙動になります。

2014/5/16 (金) 18:21:43 LR4  
Mozilla/5.0 (Windows NT 6.1; rv:29.0) Gecko/20100101 Firefox/29.0
[2188] Re7:不具合:「開きません」のキャンセルが存在しません
>どのメッセージボックスに対するCtrl+Cも、常に最後に出したメッセージボックスのテキストがクリップボードに入ります。

Spy++で見たら、どのウィンドウがアクティブかに関わらずメッセージループを回しているメッセージボックス(最後に表示したメッセージボックス)に WM_COPY が送られていました。
エディタウィンドウをアクティブにしている時でも。

2015/7/9 (木) 22:30:13 syat  
Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.132 Safari/537.36
[2265] Re8:不具合:「開きません」のキャンセルが存在しません
LR4さんのパッチをトラッカーに登録しました。(patchunicode/816)
問題なさそうなのでこちらを採用したいと思います。

[▼次のスレッド]
INCM/CMT
Cyclamen v3.81
[ut:0.010][st:0.000]