■ このスレッドは過去ログ倉庫に格納されています
Win32API質問箱 Build126
- 1 :デフォルトの名無しさん:2020/05/01(金) 22:16:51.96 ID:ZJ42fMZB.net
- Win32APIについての質問はこちらへどうぞ。
■注意
・質問する前にMSDNライブラリやPlatformSDK、Google等で検索しましょう。
・日本語版MSDN Online Libraryは不完全です。
英語版( http://msdn.microsoft.com/en-us/library/ )の利用推奨。
・APIフックなど高度な事をしたい場合はできるだけAdvenced Windowsを読みましょう。
・言語特有の問題やIDE、MFCやVCLなどの質問はそれぞれの言語や開発環境スレで
■過去スレ
Win32API質問箱 Build125
https://mevius.5ch.net/test/read.cgi/tech/1551247748/
Win32API質問箱 Build124
https://mevius.5ch.net/test/read.cgi/tech/1510395780/
■関連スレ
Visual Studio 2019 Part4 https://mevius.5ch.net/test/read.cgi/tech/1585715794/
Visual Studio 2017 Part7 https://mevius.5ch.net/test/read.cgi/tech/1558179898/
【C++】 DirectX初心者質問スレ Part41 【C】 https://mevius.5ch.net/test/read.cgi/tech/1521786252/
- 952 :デフォルトの名無しさん:2021/10/27(水) 21:34:16.61 ID:rXHlGl3r.net
- win7以前かな
- 953 :デフォルトの名無しさん:2021/10/27(水) 22:39:54.26 ID:FvdEROp3.net
- サービスのAPIってWindows NTの時代からたいして変わってないだろw
- 954 :デフォルトの名無しさん:2021/10/27(水) 23:35:14.09 ID:joAdtZnc.net
- NT4 から2000でSCMの動的ロードが出来るようになったな
- 955 :デフォルトの名無しさん:2021/10/27(水) 23:50:16.32 ID:ou7Wlnm/.net
- >>951
WinMain(またはmain)内でStartServiceCtrlDispatcherを呼ぶ以外の方法あるの?
- 956 :デフォルトの名無しさん:2021/10/28(木) 09:41:55.77 ID:XVuwIiyB.net
- おまいの眼は節穴か
- 957 :デフォルトの名無しさん:2021/10/28(木) 21:15:42.35 ID:WySuLNFg.net
- yes.It's the power of Christ that compels you!
- 958 :デフォルトの名無しさん:2021/11/02(火) 16:25:02.03 ID:yLMj4W62.net
- IOCTL_DISK_GET_DRIVE_LAYOUT_EXで得られるパーティションの情報と
FindFirstVolume, FindNextVolumeで得られるボリュームとの
対応付けはどうやるんです?
- 959 :デフォルトの名無しさん:2021/11/03(水) 12:54:39.69 ID:VhVmtrn9.net
- >>958
何をやりたいのかわからないけど、IOCTL_DISK_GET_DRIVE_LAYOUT_EXの情報からドライブ名にしたいのなら、
"\\?\Volume" + PartitionId(GUID) にすれば、ボリューム名になるのでそれを変換すればいいはず
- 960 :デフォルトの名無しさん:2021/11/03(水) 16:28:52.42 ID:XJPYAEvm.net
- >>959
おー
ありがとうございます。
- 961 :デフォルトの名無しさん:2021/11/05(金) 13:35:11.77 ID:aDspL8GE.net
- WS_EX_TOPMOSTなウインドウが時々、
通常ウインドウごときに前に出しゃばられるんだけど
防ぐか、出しゃばられたのを自動検知してZオーダーを
奪い返すにはどうすればいい?
- 962 :デフォルトの名無しさん:2021/11/05(金) 13:42:11.04 ID:AxgqQTGR.net
- 他所の窓が WS_EX_TOPMOST で奪っていって前に出しゃばられてるのであれば
WM_STYLECHANGED 捕まえて奪い返す?
- 963 :デフォルトの名無しさん:2021/11/05(金) 14:22:05.51 ID:x8tAGQOE.net
- >>961
もしかして
そうなった時って一度アクティブにしたらなおるやつ?
- 964 :デフォルトの名無しさん:2021/11/06(土) 14:43:09.91 ID:b1XdA94q.net
- ランサムウェアでも造ってんのか
- 965 :デフォルトの名無しさん:2021/11/06(土) 15:06:28.83 ID:Iy8k0Kf7.net
- yes!
- 966 :961:2021/11/06(土) 21:24:14.45 ID:7Goy9i30.net
- CreateWindow直後は理屈のとおりなんだけど
長時間稼働させて忘れた頃にAdobe Readerだの一太郎だのに
前に出しゃばられてるんだ
- 967 :デフォルトの名無しさん:2021/11/06(土) 21:29:06.09 ID:n6Z+kNBR.net
- >>963はどうなんだよって
- 968 :デフォルトの名無しさん:2021/11/06(土) 22:27:59.28 ID:Iy8k0Kf7.net
- >>961
WM _ windowposchanging
- 969 :デフォルトの名無しさん:2021/11/07(日) 15:26:34.47 ID:eUZdhF5f.net
- >>966
忖度だ
- 970 :デフォルトの名無しさん:2021/11/08(月) 18:39:57.62 ID:GDZdggMg.net
- 継ぎスレよろ
- 971 :sage:2021/11/11(木) 21:36:46.70 ID:sXUxuuhm.net
- 質問します
自作ソフトからのドラッグアンドドロップで
デカいファイルのコピーなどで DoDragDrop から長時間制御がかえって来ないことを嫌って
DoDragDrop に渡すデータオブジェクトに IDataObjectAsyncCapability を実装しています
これで、D&Dが非同期になり、データのコピーなどが始まると、StartOperation が呼ばれ、
終わると、EndOperation が呼ばれると思っていたのですが・・・
で、何がしたいかといいますと、自作ソフトからエクスプローラにファイルなどをD&Dをしたとき、
エクスプローラが自作ソフトのプロセス中の IDataObject を
使用している間は自作アプリの終了を出来ないようにしたいわけです(なぜならエクスプローラが使用中だから)
それで、StartOperation でカウンタを一つ上げて、EndOperation でカウンタを一つ下げれば
現在なんらかの IDataObject が使用中かどうかわかるので、その間は終了できないようにしたいわけです
ところが、実際には、StartOperation は呼ばれますが EndOperation は呼ばれません!(なぜ?)
Win10 と Win11 の両方で試しましたが、両方ともそうでしたのでそういう実装なのでしょう
そこで、IDataObject のデストラクタ をもってして EndOperation の代わりにしようと考えました
IDataObject の参照カウンタが0になって解放されたなら、だれも使ってないことは確実なので、、、
で、エクスプローラは IDataObject を使い終わったら素直に Release してくれるのでいいですが
そうでないソフトもあります、具体的には Visual Studio 2022 がそうでした
勝手な想像ですが、おそらく IDataObject の解放が GC 任せになっているのでしょうか、いつ解放してくれるか分かりません
問題は、Visual Studio 2022 に直接ドロップしなくても
D&D 中に少しでもマウスカーソルが Visual Studio 2022 のウィンドウの上を通過するだけで
Visual Studio が IDataObject を握ったままになることです
探せば Visual Studio 以外にも、特に .Net 系のアプリなんかで IDataObject の解放を
GC任せにしているアプリはあるんじゃないですかね
そういった経緯がありまして、どのタイミングでファイルのコピーなどが終了して
アプリを終了してもい状態になったかどうか、判断する手立てがなくて困ってます
何かいい方法ないですかね
- 972 :デフォルトの名無しさん:2021/11/12(金) 00:10:15.19 ID:4fWazNbK.net
- 迷惑な香具師だな
- 973 :デフォルトの名無しさん:2021/11/12(金) 00:15:39.07 ID:sPOmWbjM.net
- 961もそうだが只の釣りだろ
- 974 :デフォルトの名無しさん:2021/11/12(金) 02:05:20.32 ID:M7lyd7nj.net
- Ruby なら、まずデスクトップに、Rubyスクリプト・a.rb を起動するショートカットを作る
ショートカットのリンク先
C:\Ruby25-x64\bin\ruby.exe C:/Users/Owner/Documents/a.rb
a.rbの内容は、以下のように、
DryRun を使っているので、実際にはコピーされない
普通は、以下のように同期処理で作るけど、非同期にしたいのなら、
別プロセス・worker process でも起動すれば?
require 'fileutils'
dest_dir = "C:/Users/Owner/Documents/tmp/"
# ARGV は、ドロップした複数のファイルパスの配列
ARGV.select { |full_path| File.file?( full_path ) } # ファイルのみ処理する
.each do |full_path|
file_name = File.basename( full_path ) # ファイル名のみ
FileUtils::DryRun.move( full_path, dest_dir + file_name)
end
sleep # 出力したコマンドプロンプト画面を閉じないようにする
出力
mv C:\Users\Owner\Documents\x.txt C:/Users/Owner/Documents/tmp/x.txt
- 975 :デフォルトの名無しさん:2021/11/12(金) 02:18:11.02 ID:+s5Ye2oF.net
- 読んでないぞガイジ
- 976 :デフォルトの名無しさん:2021/11/12(金) 02:47:31.80 ID:0Z8rlyMb.net
- 上のキチガイも書いてるがそういう場合は別プロセスにして放置だな
単一プロセスでうまくいかない事なんて沢山ある
- 977 :971:2021/11/12(金) 14:34:55.49 ID:+qQdSUS6.net
- そうですね、確かにただのファイルのコピーなら別プロセスで実行してもいいのですが
ドラッグアンドドロップと絡んでくると難しいんじゃないですかね
なにせ実際にファイルのコピーを行うのは自アプリじゃなくて
エクスプローラ側のなのでですね
別プロセスで DoDragDrop を呼び出せってことなんでしょうけど
ドラッグアンドドロップの起点となるのはメインアプリのマウスメッセージからなので
これはかなり難しいと思います
なにせ DoDragDrop は別スレッドから呼び出しただけで動かなくなる変なAPIなので
http://bbs.wankuma.com/index.cgi?mode=al2&namber=94173&KLOG=163
別プロセスとなるとさらにハードルが高いと思われます
なぜ別スレッドで DoDragDrop が呼び出せないかは謎なんですが
多分 Windows 内部で WM_LBUTTONDOWN 系の何か「今」マウスが押されてる
ウィンドウかスレッドを覚えていて、それとは別スレッドで DoDragDrop が実行されると
失敗する処理が入っているんだと思います
ドラッグアンドドロップはかなり、なんというか、まぁ、特別というか
他のアプリにも影響が出る処理なので、OS全体を巻き込んでフリーズしないように
何かしてあるんでしょうね、これ、ちょっとよく分かりませんが、、、
ともかく別スレッドで実行できないです、なんででしょうね
それを回避するのが IDataObjectAsyncCapability なんですが
https://docs.microsoft.com/en-us/windows/win32/api/shldisp/nn-shldisp-idataobjectasynccapability
MSDN にも StartOperation が呼ばれたら、データ維持しろ、みたいなことが書いてあるけど
それをいつまで維持すればよいのかという話で、最後に EndOperation が呼ばれるって書いてあるけど
実際には呼ばれないんですよねー、まぁ呼ばれることもあるんですけど、この辺がまた一貫してない
- 978 :デフォルトの名無しさん:2021/11/12(金) 15:45:20.47 ID:rNKaN3pL.net
- おい片山、これの対応と次スレ建てやっとけ
- 979 :デフォルトの名無しさん:2021/12/02(木) 12:18:05.69 ID:Q5DdwN4N.net
- DialogBoxでメインウインドウを作るとタイトルバーのHeightが若干短くなるものと認識していたのですが、色々とスタイルを試しても一般的なウインドウと同じものしか出来上がりません
世に出てるダイアログベースのフリーソフトは短いものが多いと思いますが何が違うのでしょうか?
- 980 :デフォルトの名無しさん:2021/12/02(木) 12:31:16.49 ID:aNBqwDTQ.net
- 自分で描いてるんじゃね?
spy++で属性見るべし
- 981 :デフォルトの名無しさん:2021/12/02(木) 12:36:49.79 ID:vBr1OiF/.net
- 比較画像とかある?
- 982 :デフォルトの名無しさん:2021/12/02(木) 12:43:31.97 ID:zC7DodB0.net
- >>979
> DialogBoxでメインウインドウを作るとタイトルバーのHeightが若干短くなるものと認識していたのですが、
そのようなことはありません
> 色々とスタイルを試しても一般的なウインドウと同じものしか出来上がりません
それが通常です
> 世に出てるダイアログベースのフリーソフトは短いものが多いと思いますが何が違うのでしょうか?
思い違いです
WS_EX_TOOLWINDOW を付与したウィンドウを求めてるだけじゃないのですか?
- 983 :デフォルトの名無しさん:2021/12/02(木) 13:03:17.36 ID:Q5DdwN4N.net
- >>980->>982
返答ありがとうございます
spy++で全く同じスタイルを付与してもタイトルバーの長さは変わらず太いままでした
短い方のフリーソフトにはWS_EX_TOOLWINDOWは立ってないようです
そして色々とググってみた所stackoverflowの質問によると、manifestにて最小サポートOSをWindowsXPにすると短くなるみたいな仕組みっぽいです
https://stackoverflow.com/questions/32426055/windows-10-dialog-box-titlebar-behavior
- 984 :デフォルトの名無しさん:2021/12/02(木) 19:14:11.18 ID:8y/JBuUj.net
- この値ってファイル重複は調べられないのね
ハードリンク、シンボリックリンクだと同一の値だったが
(unsigned __int64) nFileIndexLow + ( (unsigned __int64) nFileIndexHigh<<32)
- 985 :デフォルトの名無しさん:2021/12/02(木) 21:02:13.06 ID:8y/JBuUj.net
- 上のファイルIDって、ボリュームごとにナンバーがつけ変わるんですか?
そもそもどのようにファイルIDが生成されてるのか不明なんですが
コピーだと別のIDになりましたが
ボリューム番号を付けないでファイルIDが一致した場合、全く別のファイルってことがあるんですか?
ファイルの同一性判定
Windows
ボリュームシリアル番号とファイルIDを用いて同一性判定を行う。
https://yohhoy.hatenadiary.jp/entry/20130311/p1
- 986 :デフォルトの名無しさん:2021/12/02(木) 21:07:25.22 ID:NUCi8UEu.net
- うめ
- 987 :デフォルトの名無しさん:2021/12/02(木) 21:09:25.23 ID:8y/JBuUj.net
- ファイルIDが変更されるルールが不明なんですが
その昔の nFileIndexHigh/Low の日本語説明はこうなっている。
この識別子とボリューム シリアル番号により、 ファイルが一意に識別されます。
この番号は、 システムの再起動時やファイルのオープン時に変更される場合がありますが、
プロセスがファイルをオープンした後は、 識別子はファイルがクローズするまで一定の値になります。
アプリケーションはこの識別子とボリューム シリアル番号を使って、 2つのハンドルが同じファイルを参照しているかどうかを判断することができます。
成る程、比較にはボリューム シリアル番号も含めねばならぬ。
当時の「ファイルオープン時に変更されるかも」の文言の真意は判らないが、nFileIndexHigh/Low を長期間保存しておくのは問題有るかも知れない。
usskim.blog37.fc2.com/blog-entry-555.html
- 988 :デフォルトの名無しさん:2021/12/02(木) 21:39:46.13 ID:z73dHP14.net
- https://docs.microsoft.com/en-us/windows/win32/api/fileapi/ns-fileapi-by_handle_file_information
英語読めよ..
- 989 :デフォルトの名無しさん:2021/12/02(木) 23:17:05.29 ID:8y/JBuUj.net
- サンクス
でもよくわからないです
- 990 :デフォルトの名無しさん:2021/12/03(金) 19:56:31.26 ID:SutKwY48.net
- NTFSの内部情報がないとどうにもならん
終了
- 991 :デフォルトの名無しさん:2021/12/07(火) 10:03:39.54 ID:m4TDhLeb.net
- dbgviewの後継ツールってないの?
特定のプロセスだけ監視するとか
大量のゴミ撒き散らしてるプロセスだけ除外するとかしたい
- 992 :デフォルトの名無しさん:2021/12/07(火) 13:11:46.58 ID:VYmmPtZe.net
- >>991
dbgviewのFilter機能じゃダメなの?
>特定のプロセスだけ監視とか
>大量のゴミ撒き散らしてるプロセスだけ除外するとかしたい
自分が作ってるアプリなら、Traceの頭に固有文字列付けとけばよいし、
そうで無いなら[プロセス番号]でフィルターすれば事足りると思うが?
- 993 :デフォルトの名無しさん:2021/12/07(火) 13:35:15.66 ID:KkhoCDsy.net
- >>987
FATならディレクトリの最初のクラスタと、ファイルのバイトオフセットから生成
デフラグによってそのクラスタ位置やバイトオフセットが変われば識別子も変わる
削除して別のファイルを生成した場合に、同じファイルIDが生成される可能性がある
NTFSなら削除されるかReplaceFileによって置き換えられるまでは一意
またFAT、NTFSともにファイルIDはファイルシステムごとだから、同一コンピュータ上でも論理ドライブが違えば被ることもあるので、
同じ論理ドライブか異なる論理ドライブかを判断するもの(ボリューム シリアル番号など)が必要
- 994 :デフォルトの名無しさん:2021/12/07(火) 21:50:48.67 ID:kG93TMWa.net
- デフラグやファイル操作で変わるなら何の意味もないように見える
活用したい場面なんてないのでは
- 995 :デフォルトの名無しさん:2021/12/09(木) 20:57:10.24 ID:aTCz13pR.net
- うめる
- 996 :デフォルトの名無しさん:2021/12/09(木) 20:57:15.04 ID:aTCz13pR.net
- 落とせ
- 997 :デフォルトの名無しさん:2021/12/09(木) 20:57:20.79 ID:aTCz13pR.net
- 捕手
- 998 :デフォルトの名無しさん:2021/12/09(木) 20:57:34.68 ID:aTCz13pR.net
- 外野手
- 999 :デフォルトの名無しさん:2021/12/09(木) 20:57:48.44 ID:aTCz13pR.net
- これでこのpartスレは終わりだ
- 1000 :デフォルトの名無しさん:2021/12/09(木) 20:58:48.50 ID:rdeWvBW2.net
- 1000ならこのpartスレはこのスレで終了
未来永劫立てるなボケガイジ低学歴低年収底辺ども
しねしね
- 1001 :2ch.net投稿限界:Over 1000 Thread
- 2ch.netからのレス数が1000に到達しました。
総レス数 1001
263 KB
掲示板に戻る
全部
前100
次100
最新50
read.cgi ver 2014.07.20.01.SC 2014/07/20 D ★