if i am viewing a window in lion's full screen mode and then activate the visor window, the full screen app slides away as if i was switching to another application.
yeah, would be great to have totalterminal to cover the fullscreen-app. So your terminal is always with you, no matter what fullscreen app you're working on.
Might be hard to implement, i guess.
At least the flickering when a fullscreen app switches to totalterminal on the desktop (on hitting the hotkey it switches to desktop with total terminal window visible, then it hides, and comes backs again) should be removed.
this would be a must, specially when running Textmate with fullscreen plugin.
Issue #12 references this same problem!
I encourage someone to go further and implement it because personally I don't use fullscreen apps right now and I don't plan to fix this anytime soon.
This will probably involve some new 10.7 APIs to tell the system that activating windows of Terminal.app should not exit fullscreen mode of fullscreen apps.
I think someone needs to implement NSWindowCollectionBehaviorFullScreenAuxiliary
Windows with this collection behavior can be shown on the same space as the fullscreen window.
Available in Mac OS X v10.7 and later.
Declared in NSWindow.h.
I have just tried it without success. Also one guy has open question on Developer Forums at Apple since Jul 5 and without answer.
My understanding so far:
When window goes to fullscreen mode, system creates a new exclusive space for this fullscreen window. Exclusive space allows only app's windows to be shown there. The app can create multiple fullscreen windows and each of them takes new exclusive space (try Safari and multiple CMD+N). You may mark some of your windows to be NSWindowCollectionBehaviorFullScreenAuxiliary so they can be shown on top of fullscreen windows without creating a new space. AppKit auxiliary windows like NSPanel have this flag set by default.
Terminal.app is different app and there is probably no supported way how it could display its own windows in exclusive space of some other app (say Safari).
My guess is that this will be possible on window server level with some CGSPrivate hackery (after someone takes the time to reverse-engineer it).
I have noticed that Adium message windows are sometimes able to occupy the Fullscreen apps spaces, not sure how yet.
As an workaround you can set LSUIElement in Terminal's Info.plist
Apart from that, works like a charm!
Great job guys!
Hey darwin, do you think you can put an option on TotalTerminal preferences to inject or remove LSUIElement from Terminal preferences Plist? You can name it something like "Work with Fullscreen apps". Is it possible to do it in runtime ?
It is possible to add it to preferences, but Terminal.app reastart will be required (no big deal).
Not a priority for me right now.
Is this going to make it in to the software soon?
@EricWVGG: probably not, I'm pretty stuck, I'm going to do some traveling and spend rest of my time working on Asepsis and TotalFinder support
if you really think this is an important issue you may consider adding it in your fork, I would merge it
As an aside, I noticed some other odd behavior w.r.t. full screen apps and TT.
It's weird (and possibly related). Just FYI.
It would be awesome if we can get if LSUIElement is set to 1 in the window and if TotalTerminal was invoked from a Fullscreen application window, them reset the top margin to 0 instead the size of the top bar, so we will no longer have the gap between total terminal and screen top when invoking TotalTerminal from a Fullscreen app window.
A sure thing to think about when the time comes to implement LSUIElement as a preference :)
Xscope appears to have found a way around this, which involves removing their app from the Dock. Dunno if you can gleam any hints from it:
Great solution, thanks!
Any updates on this ticket? Would be nice to have the ability to run TT above full-screen apps, especially for development. I personally run Emacs full screen but prefer TT for running code in the shell over running a shell within Emacs, and all the flicking about is starting to get a tad annoying.
Any movement on this? TT on fullscreen apps would be sweet for people with small screen laptops always running vim.
LSUIElement should be a temporary solution for 10.8
OS X 10.9 might have a better support for this (a rumor)
Doesn't work in 10.9 and cannot found a solution for now =(
Info.plist cannot be changed under Mavericks due to more strict security rules
See #3 for solution how to set LSUIElement dynamically with TotalTerminal 1.4.2
Yep, It does the trick. Thanks a lot!
For further readers the solution is:
1. Make sure TT is not running
2. Start default OS X terminal
3. write: defaults write com.apple.Terminal TotalTerminalHideDockIcon -bool YES
Neither of these options worked for me, default terminal, TotalTerminal, or AppleScript. The window still reverts to the desktop when the visor opens and the dock icon is still there. You can still edit the Info.plist in Mavericks, but you still have to change ownership of the file and Contents folder. This worked fine for me on Mavericks even before the new updates. Even over fullscreen apps including Safari.
Edit. This worked before the new TT release. Since then it still doesn't work.
@PeacefulChaos No, with default Mavericks settings, changing Info.plist of Terminal.app will break the code signature and system will refuse to launch it.
Since 1.4.4, switching to LSUIElement will be available via TotalTerminal preferences option "Run Terminal.app as a background app"
I edited the plist file once I updated to Mavericks with TT v1.4.1 and it still worked. The only side effect was there was no animation to the visor, but other than that, it worked fine. I'll be looking forward to the release of 1.4.4.
Please try 1.4.4, it is already available on the beta channel:
1.4.4 does remove the Terminal Icon from the dock and App Switcher, however it's still not working over full screen apps. This time instead of switching to the default desktop, it doesn't do anything at all until I switch to the main screen myself and then input the keystroke to open the visor. Suggestions?
Edit: I reverted the Info.plist to the original code and reset permissions to root:wheel.
Another Edit: Looking at Safari's behavior, it seem that the window is activating but it seems that it's behind the fullscreen apps.
Scratch my last. I did a reboot and now it works perfectly. Thanks!