Yesterday, Xcode 12 beta 3 was released and it includes a change to how tabs and navigation work. In beta 3, 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 beta 3 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 in beta 3, there is a concept of “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 “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!