Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Unbelievable strange file creation time problem

I have a very strange problem indeed! I wonder if the problem is in the framework, OS or maybe it's just me, misunderstanding things...

I have a file, which might be created a long time ago, I use the file, and then I want to archive it, by changing it's name. Then I want to create a new file, with the same name as the old file had, before it was renamed. Easy enough!

The problem that really puzzles me, is that the newly created file gets wrong "created"-timestamp! That's a problem since it's that timestamp that I want to use for determing when to archive and create a new file.

I've created a very small sample that shows the problem. For the sample to work, there must be a file 1.txt in the Files folder. Also, the file attribute must also be set back in time (with one of the tools available, I use Nomad.NET).

    static void Main(string[] args)     {         // Create a directory, if doesnt exist.         string path = Path.GetDirectoryName(Application.ExecutablePath) + "\\Files";         Directory.CreateDirectory(path);          // Create/attach to the 1.txt file         string filename = path + "\\1.txt";         StreamWriter sw = File.AppendText(filename);         sw.WriteLine("testing");         sw.Flush();         sw.Close();         // Rename it...         File.Move(filename, path + "\\2.txt");          // Create a new 1.txt         sw = File.AppendText(filename);         FileInfo fi = new FileInfo(filename);         // Observe, the old files creation date!!         Console.WriteLine(String.Format("Date: {0}", fi.CreationTime.Date));          Console.ReadKey();     } 
like image 779
kaze Avatar asked Jan 21 '10 12:01

kaze


2 Answers

This is the result of an arcane "feature" going way back to the old days of Windows. The core details are here:

Windows NT Contains File System Tunneling Capabilities (Archive)

Basically, this is on purpose. But it's configurable, and an anachronism in most of today's software.

I think you can create a new filename first, then rename old->old.1, then new->old, and it'll "work". I don't remember honestly what we did when we ran into this last a few years back.

like image 111
Joe Avatar answered Oct 08 '22 20:10

Joe


I recently ran into the same problem described in the question. In our case, if our log file is older than a week, we delete it and start a new one. However, it's been keeping the same date created since 2008.

One answer here describes renaming the old file and then creating a new one, hopefully picking up the proper Creation Date. However, that was unsuccessful for us, it kept the old date still.

What we used was the File.SetCreationTime method, and as its name suggests, it easily let us control the creation date of the file, allowing us to set it to DateTime.Now. The rest of our logic worked correctly afterwards.

like image 26
Aaron Avatar answered Oct 08 '22 20:10

Aaron