Update: This post was originally written during Xcode 12 beta 3, but has been updated to reflect the final release of Xcode 12.
Xcode 12 was released and it includes a change to how tabs and navigation work. In Xcode 12, the tabs have their own tabs. It makes no sense to me. I know we are supposed to be nice to each other about software, but this new UI/UX is beyond incomprehensible. What made it worse is that this new “tabs within tabs” was the default setting (overriding preferences I had previously set) and I could not figure out how to restore the previous (desired) behavior.
Even worse than that, the keyboard shortcuts I have memorized for navigating, opening, and closing tabs were not working. The shortcuts I have committed to muscle memory only seemed to control the inner tabs, not the outer tabs. It was an unintelligible mess.
After reaching peak frustration, I went to Twitter to ask what was going on. A lot of other folks were having the same problem. Luckily, I discovered how to disable the “tabs with tabs”. (Thank you @CaliCoding.)
You need to open Xcode’s Navigation preferences, and for “Navigation Style” select “Open In Place”. The new “inner tab bar” will disappear, and the previous tab behavior (and shortcuts!) will be restored.
So what happened?
Xcode 12 introduces new options for these bottom four navigation settings, which are all concerned with “what happens when you open a file”. Previously, the options were opening a new window or opening a new tab, and a few other options. Now, there is a concept of “tabs” (or “document tabs”) and “window tabs” — again, a completely incoherent and confusing design. In this model, “window tabs” are the normal tabs you are thinking of, consistent with Xcode 11 behavior and design. And the “document tabs” are the “inner tabs” that exist within a “window tab”. I also find these preferences indecipherable. How do any of these options accurately communicate how tabs will behave or which tabs (“inner” or “window”) will be shown?
If you are facing the same confusion, I hope this helps!