summaryrefslogtreecommitdiff
path: root/tools/source
diff options
context:
space:
mode:
authorEike Rathke <erack@redhat.com>2017-05-06 00:12:49 +0200
committerEike Rathke <erack@redhat.com>2017-05-06 00:13:15 +0200
commit3208f0cb805de6b2ac5f2e1c5d067cd3b845d924 (patch)
treef9f96c5f7bc77bfa14c0a9c67f6e2ad0aacdb091 /tools/source
parenta940826162dc93f5543f81fc8fe5d8618c4a6efb (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/source')
-rw-r--r--tools/source/datetime/datetime.cxx23
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 ) );