summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorhut <hut@lavabit.com>2012-11-09 21:57:52 +0100
committerhut <hut@lavabit.com>2012-11-09 23:31:24 +0100
commitb34807bd428bbe7bb40e8798af17f0f4cf5ecf1f (patch)
tree933e2433f2a8f876e2d6b2c5ebd7a21b951a240b
parentc3cc82296bfa78b37def79533e82e0e85b4069c0 (diff)
downloadranger-b34807bd428bbe7bb40e8798af17f0f4cf5ecf1f.tar.gz
gui.ui: more portable terminal title support
-rw-r--r--ranger/gui/ui.py11
1 files changed, 5 insertions, 6 deletions
diff --git a/ranger/gui/ui.py b/ranger/gui/ui.py
index 6f021b68..b8a4ab7f 100644
--- a/ranger/gui/ui.py
+++ b/ranger/gui/ui.py
@@ -10,10 +10,6 @@ from .displayable import DisplayableContainer
 from .mouse_event import MouseEvent
 from ranger.ext.keybinding_parser import KeyBuffer, KeyMaps, ALT_KEY
 
-TERMINALS_WITH_TITLE = ("xterm", "xterm-256color", "rxvt",
-		"rxvt-256color", "rxvt-unicode", "rxvt-unicode-256color",
-		"aterm", "Eterm", "screen", "screen-256color")
-
 MOUSEMASK = curses.ALL_MOUSE_EVENTS | curses.REPORT_MOUSE_POSITION
 
 _ASCII = ''.join(chr(c) for c in range(32, 127))
@@ -44,7 +40,6 @@ class UI(DisplayableContainer):
 	termsize = None
 
 	def __init__(self, env=None, fm=None):
-		self._draw_title = os.environ["TERM"] in TERMINALS_WITH_TITLE
 		self.keybuffer = KeyBuffer()
 		self.keymaps = KeyMaps(self.keybuffer)
 
@@ -86,6 +81,8 @@ class UI(DisplayableContainer):
 			self.setup()
 			self.win.addstr("loading...")
 			self.win.refresh()
+			curses.setupterm()
+			self._draw_title = curses.tigetflag('hs') # has_status_line
 		self.update_size()
 		self.is_on = True
 
@@ -286,7 +283,9 @@ class UI(DisplayableContainer):
 			try:
 				fixed_cwd = cwd.encode('utf-8', 'surrogateescape'). \
 						decode('utf-8', 'replace')
-				sys.stdout.write("\033]2;ranger:" + fixed_cwd + "\007")
+				sys.stdout.write("%sranger:%s%s" %
+						(curses.tigetstr('tsl').decode('latin-1'), fixed_cwd,
+						 curses.tigetstr('fsl').decode('latin-1')))
 				sys.stdout.flush()
 			except:
 				pass