diff options
author | Eike Rathke <erack@redhat.com> | 2017-05-06 00:12:49 +0200 |
---|---|---|
committer | Eike Rathke <erack@redhat.com> | 2017-05-06 00:13:15 +0200 |
commit | 3208f0cb805de6b2ac5f2e1c5d067cd3b845d924 (patch) | |
tree | f9f96c5f7bc77bfa14c0a9c67f6e2ad0aacdb091 /tools | |
parent | a940826162dc93f5543f81fc8fe5d8618c4a6efb (diff) |
DateTime::GetWin32FileDateTime: FILETIME is uint64
Truncate to 0 at 1601-01-01
See source code comment for pointers and reasoning.
Change-Id: Iea961e0c0302f4f48a0ddbdd23036cbbbf53c00f
Diffstat (limited to 'tools')
-rw-r--r-- | tools/source/datetime/datetime.cxx | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/tools/source/datetime/datetime.cxx b/tools/source/datetime/datetime.cxx index eedbdea51abb..84e4c5436220 100644 --- a/tools/source/datetime/datetime.cxx +++ b/tools/source/datetime/datetime.cxx @@ -228,15 +228,22 @@ void DateTime::GetWin32FileDateTime( sal_uInt32 & rLower, sal_uInt32 & rUpper ) const sal_Int64 a100nPerSecond = SAL_CONST_INT64( 10000000 ); const sal_Int64 a100nPerDay = a100nPerSecond * sal_Int64( 60 * 60 * 24 ); - sal_Int64 nYears = GetYear() - 1601; - sal_Int64 nDays = - nYears * 365 + - nYears / 4 - nYears / 100 + nYears / 400 + - GetDayOfYear() - 1; + // FILETIME is indirectly documented as uint64, see + // https://msdn.microsoft.com/en-us/library/windows/desktop/ms724284.aspx + // mentioning the ULARGE_INTEGER structure. + // https://msdn.microsoft.com/en-us/library/windows/desktop/ms724280.aspx + // mentions that if FILETIME is not less than 0x8000000000000000 then the + // FileTimeToSystemTime function fails, which is another indicator. + // Unless there's evidence that FILETIME can represent a signed offset from + // 1601-01-01 truncate at 0. (reading part below in + // CreateFromWin32FileDateTime() would had to be adapted to signed as + // well). + sal_Int16 nYear = GetYear(); + SAL_WARN_IF( nYear < 1601, "tools.datetime", "DateTime::GetWin32FileDateTime - year < 1601: " << nYear); - sal_Int64 aTime = - a100nPerDay * nDays + - GetNSFromTime()/100; + sal_Int64 aTime = (nYear < 1601 ? 0 : ( + a100nPerDay * static_cast<sal_Int64>(*this - Date(1,1,1601)) + + GetNSFromTime()/100)); rLower = sal_uInt32( aTime % SAL_CONST_UINT64( 0x100000000 ) ); rUpper = sal_uInt32( aTime / SAL_CONST_UINT64( 0x100000000 ) ); |