Recent

Author Topic: TSearchRec Time on Windows / Linux problem  (Read 669 times)

cris75

  • Jr. Member
  • **
  • Posts: 65
TSearchRec Time on Windows / Linux problem
« on: June 13, 2024, 05:16:31 pm »
HI,
suppose we access the attributes of a TSearchRec, "Time" would be the time (and date) of the last modification, a longint that can be converted back to a human readable format via DateTimeToStr(FileDateTodateTime( TSearchRec.Time )), correct me if I'm wrong;
I wrote a small program that scans a directory (via FindFirst) and returns the "last modified time" of all files in it, what I noticed is that the values ​​stored in TSearchRec.Time are completely different when I run the program in Windows compared to when I run it on Linux.
From what I found searching online I'm pretty sure this is due to an "internal" time conversion mechanism in both operating systems, but this also means that if I run the program in Linux, I can't use the value contained in TSearchRec.Time and convert it again via the "FileDateTodateTime" function, this time in a Windows test program written specifically to check it (in fact I get conversion errors);
If I copy an existing (old) file from my Debian machine to my Windows 10 VM and then go and check the "last modified" property of that file in both operating systems (via Dophin/Explorer), as I expected they are identical, (same date and time reported), so I assume that the operating systems automatically manage these conversions;
Is there a function that can handle this "conversion"?
(I mean, in my case "get" the value of the TSearchRec.Time attribute in Linux and then somehow correctly convert it back to a human readable date and time in Windows - and vice versa)
Lazarus: 3.2 / FPC: 3.2.2 [x86_64-win64-win32/win64]
Win10 x64
Debian 12 gtk2/qt5

Thaddy

  • Hero Member
  • *****
  • Posts: 15556
  • Censorship about opinions does not belong here.
Re: TSearchRec Time on Windows / Linux problem
« Reply #1 on: June 13, 2024, 05:55:49 pm »
Windows and linux have a different time pivot:
unix counts from /1/1/1970
windows counts from /12/31/1899 i

There are conversion functions, though, like datetimetounix
See the manual:
https://www.freepascal.org/docs-html/rtl/dateutils/datetimetounix.html.
« Last Edit: June 13, 2024, 06:48:19 pm by Thaddy »
If I smell bad code it usually is bad code and that includes my own code.

PascalDragon

  • Hero Member
  • *****
  • Posts: 5654
  • Compiler Developer
Re: TSearchRec Time on Windows / Linux problem
« Reply #2 on: June 13, 2024, 10:12:17 pm »
HI,
suppose we access the attributes of a TSearchRec, "Time" would be the time (and date) of the last modification, a longint that can be converted back to a human readable format via DateTimeToStr(FileDateTodateTime( TSearchRec.Time )), correct me if I'm wrong;
I wrote a small program that scans a directory (via FindFirst) and returns the "last modified time" of all files in it, what I noticed is that the values ​​stored in TSearchRec.Time are completely different when I run the program in Windows compared to when I run it on Linux.
From what I found searching online I'm pretty sure this is due to an "internal" time conversion mechanism in both operating systems, but this also means that if I run the program in Linux, I can't use the value contained in TSearchRec.Time and convert it again via the "FileDateTodateTime" function, this time in a Windows test program written specifically to check it (in fact I get conversion errors);
If I copy an existing (old) file from my Debian machine to my Windows 10 VM and then go and check the "last modified" property of that file in both operating systems (via Dophin/Explorer), as I expected they are identical, (same date and time reported), so I assume that the operating systems automatically manage these conversions;
Is there a function that can handle this "conversion"?
(I mean, in my case "get" the value of the TSearchRec.Time attribute in Linux and then somehow correctly convert it back to a human readable date and time in Windows - and vice versa)

Please provide concrete examples of what kind of differences you see.

Windows and linux have a different time pivot:
unix counts from /1/1/1970
windows counts from /12/31/1899 i

FileDateToDateTime is supposed to take care of that already.

marcov

  • Administrator
  • Hero Member
  • *
  • Posts: 11732
  • FPC developer.
Re: TSearchRec Time on Windows / Linux problem
« Reply #3 on: June 13, 2024, 10:43:53 pm »
There is also local time vs UTC, so a deviation of a few hours could be caused by that .

Btw FPC 3.2.4 will have

Code: Pascal  [Select][+][-]
  1.     property TimeStamp: TDateTime read GetTimeStamp;
  2.     property TimeStampUTC: TDateTime read GetTimeStampUTC;

in sysutils.searchrec.

 

TinyPortal © 2005-2018