-
Notifications
You must be signed in to change notification settings - Fork 13k
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
feat: add tier-1 platform support for change_time #128256
base: master
Are you sure you want to change the base?
Conversation
fix: remove `en-us` from doc links to support globalization
@tgross35 unfortunately there are still cases where None would be returned, but I updated the documentation to clarify when that is the case |
Note: Currently the doc-url I link to that explains ChangeTime is dev blog. I have a PR out to update the official docs so that it reflects the information from there MicrosoftDocs/sdk-api#1863 |
/// This will return `None` if the `Metadata` instance was not created using the `FILE_BASIC_INFO` type. | ||
/// Returns the value of the `ChangeTime{Low,High}` field from the | ||
/// [`FILE_BASIC_INFO`] struct associated with the current file handle. | ||
/// [`ChangeTime`], is the last time file metadata was changed, such as |
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.
/// [`ChangeTime`], is the last time file metadata was changed, such as | |
/// [`ChangeTime`] is the last time file metadata was changed, such as |
Spurious comma
/// [`WIN32_FIND_DATA`]: https://learn.microsoft.com/windows/win32/api/minwinbase/ns-minwinbase-win32_find_dataw | ||
/// [`FindFirstFile`]: https://learn.microsoft.com/windows/win32/api/fileapi/nf-fileapi-findfirstfilea | ||
/// [`FindNextFile`]: https://learn.microsoft.com/windows/win32/api/fileapi/nf-fileapi-findnextfilea | ||
/// [`ChangeTime`]: https://devblogs.microsoft.com/oldnewthing/20100709-00/?p=13463#:~:text=I%E2%80%99m%20told%20that%20the%20difference%20is%20metadata.%20The,attributes%20%28hidden%2C%20read-only%2C%20etc.%29%20or%20renaming%20the%20file. |
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.
Looks like this has some highlighting, https://devblogs.microsoft.com/oldnewthing/20100709-00/?p=13463 seems to work
@@ -373,12 +373,19 @@ impl File { | |||
reparse_tag = attr_tag.ReparseTag; | |||
} | |||
} | |||
|
|||
// FILE_BASIC_INFO contains additional fields not returned by GetFileInformationByHandle | |||
let basic_info = self.basic_info()?; |
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.
I don't know what the failure conditions are here, is accessing FILE_BASIC_INFO
expected to never fail? Looks like uwp already does this.
If failures are possible, you can just do self.basic_info().ok().map(|info| c::FILETIME { ... })
.
Cool, thanks! The above looks reasonable to me with the possible failure concern addressed. Since this works on all platforms, is a test possible now? |
Hm, this adds an extra sys call for every use of |
Per usual with Windows r? @ChrisDenton |
Yeah, I thought about that over the weekend, going to do a bit more tinkering to see if I can find a way to avoid an extra call. Alternatively, how do you feel about an |
Okay wow this was a trip to research. So apparently https://learn.microsoft.com/windows/win32/api/winbase/nf-winbase-getfileinformationbyname This API can return an information class type that returns a struct called Here's the real cool part. According to documentation, this api doesn't open the file in order to return metadata, which means that it should actually improve performance along this code path since
Also, the struct includes the reparse tag if set, meaning the current additional syscall can be avoided when the reparse attribute is set. For now, I'll try it out and see if I can get it working and I'll update the PR accordingly. |
So slightly blocked by this PR getting merged microsoft/win32metadata#1934 in order for bindings.txt/windows-bindgen to pick up the new API. (/~https://github.com/microsoft/win32metadata/blob/3b275fdb05e7dbab989c00b8a86e985853c6b65e/generation/WinSDK/RecompiledIdlHeaders/um/WinBase.h#L9394) However, I confirmed that the API already exists in winbase.h, by just running my own bindgen, which means I could at least test the functionality w/ this Draft PR. |
Additional prior art -- libuv/libuv#4327 |
We can also look at getting this API in earlier than microsoft/win32metadata#1934, will file a separate issue to track that. |
I've been looking into it using this. One concern is how new the API is. The vast majority of users will not have it and the API docs are still displaying a stability warning (though given Python's unusually early use of the API, I'm not sure how seriously to take that). We could fallback to Another issue is that not all filesystem drivers support it. Notably fat32 but also third party drivers or (worse) things that hook the filesystem APIs. Maybe using a To be clear, I'm not against it at all. Just that there's enough question that I'd rather think/ask/test a bit more. |
In any case, there's no reason to block fixing the links. Could you either update this PR to just do the link changes or open a new PR for that? And separately open an issue for using |
Right, |
@ChrisDenton - Created a new PR for the links, #130168, I'll start a new issue for this particular thing |
☔ The latest upstream changes (presumably #130253) made this pull request unmergeable. Please resolve the merge conflicts. |
@juliusl what's the status of this? thanks |
@Dylan-DPC hey there, was waiting on the windows build that includes this API to get to retail, I'll need to circle back to see what the status is but I think it's either released or is close to releasing. |
fix: remove
en-us
from doc links to support globalizationRelated: #121478
r? tgross35