-
Notifications
You must be signed in to change notification settings - Fork 525
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
Optimize write_to_file
in windows-bindgen
to avoid unnecessary file writes
#3079
Conversation
Unfortunately, I think there's a compelling reason not to do this unconditionally. Many build systems expect that the timestamps on the output files of a task will be newer than the timestamps of the inputs of a task, after running a task. If we don't update the output timestamps, then build systems will re-run bindgen every time. So this breaks incremental builds in environments that use timestamps. Maybe this could be a configuration option? |
Interesting, the github workflow doesn't seem to like it either. |
Maybe it could be a boolean parameter to bindgen: Always update output? If the output reads the same, then maybe we just "touch" the output to update its last-modified time. I don't see a way to do that directly in And just to clarify -- I don't mean it has to be a single |
|
Ah, good. I wasn't aware of Still, I would like this behavior to be controllable. The caller should be able to choose between "do a single unconditional write" vs. this diffing behavior. I say this because my team manages build systems (the Windows build lab), and our buidl systems do a lot of introspection into the file access patterns of tools that they execute. This "read and verify" pattern will be flagged as a very problematic behavior by several major build systems because it looks like a false dependency on a previous state, when it's really not. The default behavior for riddle.exe should be to unconditionally write its output. The "read and verify" pattern should be an opt-in optimization. My rationale is that this have the least risk of causing problems for build systems. |
For what it's worth, cppwinrt has done this for years without any trouble. https://github.com/microsoft/cppwinrt/blob/master/cppwinrt/text_writer.h#L178 Anyway if this is not desirable, I'd rather just leave the current behavior alone. If developers have problems with rust-analyzer they can temporarily disable it while working on the windows-rs repo. I never use it for this reason. We can also separately reduce the overhead and optimize things, like using |
Alternative to #3072 to avoid unnecessary file writes that trigger side effects in build systems and IDEs.
I ended up doing the same thing for cppwinrt years ago as msbuild and razzle had a real problem for similar reasons.