X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/246c704fca3a07ee5ba89da3a4cc87370f6c8cc9..eb749c3e37cada3f22255c8fe6ac080f72e04814:/src/common/filename.cpp diff --git a/src/common/filename.cpp b/src/common/filename.cpp index d3f34e5aa2..ec00ae7bed 100644 --- a/src/common/filename.cpp +++ b/src/common/filename.cpp @@ -53,6 +53,8 @@ #ifdef __UNIX_LIKE__ #include #include + #include + #include #endif // ---------------------------------------------------------------------------- @@ -118,14 +120,32 @@ private: // convert between wxDateTime and FILETIME which is a 64-bit value representing // the number of 100-nanosecond intervals since January 1, 1601. -static void ConvertWxToFileTime(FILETIME *ft, const wxDateTime& dt) +// the number of milliseconds between the Unix Epoch (January 1, 1970) and the +// FILETIME reference point (January 1, 1601) +static const wxLongLong FILETIME_EPOCH_OFFSET = wxLongLong(0xa97, 0x30b66800); + +static void ConvertFileTimeToWx(wxDateTime *dt, const FILETIME &ft) { - // TODO + wxLongLong ll(ft.dwHighDateTime, ft.dwLowDateTime); + + // convert 100ns to ms + ll /= 10000; + + // move it to our Epoch + ll -= FILETIME_EPOCH_OFFSET; + + *dt = wxDateTime(ll); } -static void ConvertFileTimeToWx(wxDateTime *dt, const FILETIME &ft) +static void ConvertWxToFileTime(FILETIME *ft, const wxDateTime& dt) { - // TODO + // do the reverse of ConvertFileTimeToWx() + wxLongLong ll = dt.GetValue(); + ll *= 10000; + ll += FILETIME_EPOCH_OFFSET; + + ft->dwHighDateTime = ll.GetHi(); + ft->dwLowDateTime = ll.GetLo(); } #endif // __WIN32__