MacOS – OS X Finder hangs on tagging

finderfinder-taghangicloudmacos

I'm having a problem with the new tagging feature in Mavericks and I have a feeling it might go deeper than just the tagging.

The problem is this:
When tagging anything on Mavericks the Finder becomes unresponsive for anything up to 15 seconds and beach-balls. I am using a Mac Pro Mid 2010 with 16GB RAM so power is not the issue.

At first I thought the problem might have been due to having done an upgrade install of Mavericks, but after seeing tagging working fine on an upgraded Air and iMac I decided to try a clean install. Alas, the problem persisted.

Since I was installing on a DIY Fusion Drive I had created back in the early days of Mountain Lion, that became my next suspect. To "quickly" test my theory I installed Mavericks on an external slow & tiny USB drive. Zero problems. Tagging was instantaneous and no beach balls in sight.

So, it seemed likely to be one of the drives. First I tried installing Mavericks on a newly created Fusion Drive (using the same component drives; an OCR Vertex 3 and a regular WD HDD) from the Mavericks recovery partition terminal in the hope that a newer CoreStorage would fix things. Same problem.

Next I tried the drives individually, but after having installed a fresh Mavericks on both (I know, tedious) and still having the problem I feel I am running out of options. Is it my SATA controller? And why just on the tagging?

I have made a few Activity Monitor Spindumps which I'm hoping anyone with the knowledge & inclination could glean some information from.

Any help is greatly appreciated.
:/
Teo

Spindumps:
https://www.dropbox.com/s/d86hdy2xcq8jryy/Mavs%20Finder%20Tagging%20Spindump.txt

https://www.dropbox.com/s/ilmaceo8szhp9s8/Spindump2.txt

UPDATE 17 May 2014

I have now identified the source of the bug (on my system at least).

I noticed that on a completely fresh user account everything works as it should, new tags are added without hangs or even delays.

The moment I enable the "iCloud->Documents & Data" option the problem manifests: hangs occur on adding any new tags. Even more unfortunately, disabling it again does not make the issue disappear. Once enabled the system isn't working properly anymore.

My guess is that there's something buggy in the way the system is trying to check for tags across iCloud but strange that the problem remains after removing it.

Any new info/suggestions are welcome.

UPDATE 1 October 2014
This problem persists in Yosemite 10.10 GM

Best Answer

This problem has been bugging me for months. I've kept a weather eye on the Google results, poked around trying to find my own solution, upgraded to Yosemite to see if the issue was resolved there, but nothing turned up. So, during the Thanksgiving break I decided to sit down and fix this once and for all.

Looooong story short, every time you add a new tag (and possibly when you add a tag to a file) it gets popped into the Finder sidebar for easy access. Handy. Thing is, if you get crazy and add a metric ton of tags, none of them are ever removed from the Finder sidebar. They roll off the edge where you can't see them, and are flagged as "visible if newer items are removed" but they are all retained in the sidebar items plist. This plist gets massive, and takes a long time to parse any time it must be modified.

To make things worse, when you have "documents and data" turned on under System Preferences > iCloud the tag list is synced. This means the hang follows you to every machine where you are signed into iCloud, even on a fresh reload of OS X. Funfunfun.

Thankfully, there is an easy fix. I'll keep the explanation simple for Joe Internet who may be having this problem stumble across this post.

When the Finder is running properly (not beach-balled), right-click on the icon in the Dock and select "Go to Folder". In the dialog that appears type "~/Library/Preferences/". That funny little squiggle at the front is just a nice little shortcut that tells the dialog to start in your home folder for the path, rather than the root of the internal drive.

You will be presented with a cornucopia of scary looking plists. The one we are after is titled "com.apple.sidebarlists.plist". Copy that plist somewhere you can find it later (just in case something goes awry and you have to put it back.) Now, delete the the original plist in the Library folder and reboot your machine. After the reboot Finder will have an empty tag sidebar and you can create, delete, and rearrange tags to your hearts content. No hangs. As long as you have iCloud "Documents and Data" enabled, this new clean sidebar will also be uploaded to iCloud and clear out the old gigantic one on all your machines.

It should be noted that this DOES NOT delete the tags from your files. That information is actually appended to an extended attribute (xattr) of the file itself, rather than being stored in a single plist or database somewhere. Thankfully the tags on the files themselves aren't what's causing the hang issue, so we can leave them untouched.

Of course, what you will lose are the list of tags and custom folders you want in the Finder sidebar. Add the folders back the normal way (drag them into the sidebar) and you can select which tags you want by going to the Finder menu > Preferences > Tags and checking the boxes. I've got about a dozen and things are snappy.

One other unfortunate loss are the tags' assigned colors. That's strictly stored in the Finder's plist. The tags may appear to retain their color until you add them back to the sidebar, or try to apply a tag to an item, at which point the color vanishes.

After you've added a tag or two back to the sidebar the "all tags" item will reappear at the bottom of the list. Click on that and scroll through the list of tags to re-assign their colors. Make sure to re-apply color even to the tags that appear to have retained it, because when that tag is next added to a file or otherwise modified there's a good chance the color will disappear.

Something to note if you have a lot of colors applied: adding them all back may cause the hang issue to re-manifest. All those color assignments are stored in the plist, and too many may drag things down. I've only got a few color assignments so I haven't been able to verify this theory.

That's it! Congratulations! Tags are now usable on your machine(s) again. Just remember to go into Finder > Preferences > Tags every now and again and clear the checkbox or minus sign from the tags you don't want displayed in the sidebar and things should remain snappy.