When copying files in Finder, you might have noticed that the newly created, still-being-written-to files are ‘grayed out’, conveniently informing the user that the file is not ready yet.
data:image/s3,"s3://crabby-images/b1cd3/b1cd344a56ebd884cbc560c145f3de7418786f8f" alt="Screenshot of Finder (11-04-2018, 10-13-09).jpg Greyed out files in Finder"
I wanted to replicate that for an upcoming upgrade of Transloader (along with a progress indicator, as you can see in the screenshot above, but that’s another topic), and after trying a couple of things, I found out how to do it.
I tested this on macOS High Sierra only, since it’s the OS version I’m targeting right now, but I don’t see a reason why it wouldn’t work on earlier versions of macOS.
It’s All in the Date
After digging around on the internet, I found that all that needs to be done is to change the file’s creation- and modification dates to one specific date, namely:
January 24th, 1984, 09:00:00 AM
data:image/s3,"s3://crabby-images/d9287/d92872e4f38a100390c0d90045b398997c343ea9" alt="Screenshot of Xcode (11-04-2018, 10-50-57).jpg Setting the creation and modification dates of the file to be greyed out"
And it works great – the created file appears ‘grayed out’ in Finder.
There’s a downside, however:
When copying a file in Finder, and trying to move that still-being-written-to file, Finder will display a convenient message that tells the user the file is in use and moving it might cause problems.
This doesn’t happen when using this date-setting approach.
So I kept digging.
The Solution
What I did, then, was use Terminal and the ‘mdls’ command to list the meta data of the still-being-written-to file:
data:image/s3,"s3://crabby-images/1d6a4/1d6a41432de0f15f171f53c260c14c5eb730b2ec" alt="Screenshot of Terminal (11-04-2018, 10-21-20).jpg mdls in Terminal on a copying file"
At first, coming from the date-approach, I noticed the kMDItemFSCreationDate item, stating
1904-01-01 00:00:00 +0000
However, setting that as the creation date does nothing at all.
Then, I noticed the kMDItemFSCreatorCode and kMDItemFSTypeCode fields (red arrows in the screenshot of Terminal above).
Setting those like this…
data:image/s3,"s3://crabby-images/73006/730065271898d6d5b65b17a1a4f523e0fd4c69a4" alt="Screenshot of Xcode (11-04-2018, 10-51-44).jpg Setting creator and type codes in Objective-C"
…does exactly what I wanted – it ‘grays out’ the file in Finder, and displays the convenient Finder error message when trying to move it:
data:image/s3,"s3://crabby-images/d24ad/d24ad486e8d7bb5d72b1bbbbc65f0a1d8b8548b7" alt="Screenshot of Finder (11-04-2018, 10-45-37).jpg Finder error message when trying to move a still being written to file"
Mission accomplished – we’re done!
Please keep in mind, though, that the user may still choose “Continue” to move the file, so you should definitely use an NSFileCoordinator to take care of that.