summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--ranger/fsobject/fsobject.py74
1 files changed, 44 insertions, 30 deletions
diff --git a/ranger/fsobject/fsobject.py b/ranger/fsobject/fsobject.py
index 5b64cd75..6b071fed 100644
--- a/ranger/fsobject/fsobject.py
+++ b/ranger/fsobject/fsobject.py
@@ -21,6 +21,8 @@ DOCUMENT_BASENAMES = ()
 
 import stat
 import os
+from stat import S_ISLNK, S_ISCHR, S_ISBLK, S_ISSOCK, S_ISFIFO, \
+		S_ISDIR, S_IXUSR
 from time import time
 from subprocess import Popen, PIPE
 from os.path import abspath, basename, dirname, realpath
@@ -175,11 +177,11 @@ class FileSystemObject(MimeTypeAware, FileManagerAware):
 				self.accessible = True
 				self.runnable = True
 		elif self.is_file:
-			try:
+			if self.stat:
 				self.size = self.stat.st_size
 				self.infostring = ' ' + human_readable(self.size)
-			except:
-				pass
+			else:
+				self.infostring = BAD_INFO
 		if self.is_link:
 			self.infostring = '->' + self.infostring
 
@@ -190,36 +192,48 @@ class FileSystemObject(MimeTypeAware, FileManagerAware):
 		"""
 
 		self.loaded = True
-		try:
-			self.stat = os.lstat(self.path)
-		except OSError:
-			self.stat = None
-			self.is_link = False
-			self.accessible = False
+
+		# Get the stat object, either from preload or from os.[l]stat
+		self.stat = None
+		if self.preload:
+			self.stat = self.preload[1]
+			self.is_link = S_ISLNK(self.stat.st_mode)
+			if self.is_link:
+				self.stat = self.preload[0]
+			self.preload = None
 		else:
-			self.is_link = stat.S_ISLNK(self.stat.st_mode)
+			try:
+				self.stat = os.lstat(self.path)
+			except:
+				pass
+			else:
+				self.is_link = S_ISLNK(self.stat.st_mode)
+				if self.is_link:
+					try:
+						self.stat = os.stat(self.path)
+					except:
+						pass
+
+		# Set some attributes
+		if self.stat:
 			if self.is_link:
-				try: # try to resolve the link
-					self.readlink = os.readlink(self.path)
-					self.realpath = realpath(self.path)
-					self.stat = os.stat(self.path)
-				except:  # it failed, so it must be a broken link
-					pass
+				self.realpath = realpath(self.path)
+				self.readlink = os.readlink(self.path)
 			mode = self.stat.st_mode
-			self.is_device = bool(stat.S_ISCHR(mode) or stat.S_ISBLK(mode))
-			self.is_socket = bool(stat.S_ISSOCK(mode))
-			self.is_fifo = bool(stat.S_ISFIFO(mode))
-			self.accessible = True
-
-		if self.accessible and os.access(self.path, os.F_OK):
-			self.exists = True
+			self.is_device = bool(S_ISCHR(mode) or S_ISBLK(mode))
+			self.is_socket = bool(S_ISSOCK(mode))
+			self.is_fifo = bool(S_ISFIFO(mode))
 			self.accessible = True
-			if os.path.isdir(self.path):
-				self.runnable = bool(mode & stat.S_IXUSR)
-
+			if os.access(self.path, os.F_OK):
+				self.exists = True
+				if S_ISDIR(mode):
+					self.runnable = bool(mode & S_IXUSR)
+			else:
+				self.exists = False
+				self.runnable = False
 		else:
-			self.exists = False
-			self.runnable = False
+			self.accessible = False
+
 		self.determine_infostring()
 
 	def get_permission_string(self):
@@ -231,9 +245,9 @@ class FileSystemObject(MimeTypeAware, FileManagerAware):
 		except:
 			return '----??----'
 
-		if stat.S_ISDIR(mode):
+		if S_ISDIR(mode):
 			perms = ['d']
-		elif stat.S_ISLNK(mode):
+		elif S_ISLNK(mode):
 			perms = ['l']
 		else:
 			perms = ['-']
' href='/danisanti/profani-tty/blame/themes/simple?id=22a14e1240ee3fcefd251f8acb08afc926043d58'>^
e58be44f ^
27adf031 ^

30b5f112 ^


446027b9 ^
f0f3a739 ^
93358d5e ^
fb7001cf ^
72c1c496 ^
bab75cae ^
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
    

           
           
         






                   




                      


                 
                    
                  

                     
                 

                     
                 



                       
                    
                         
                  
                       

                       


                
              
                   
              
                 
                  
                     
[ui]
beep=false
flash=false
splash=true
wrap=true
time.console=off
time.chat=off
time.muc=off
time.mucconfig=off
time.private=off
time.xmlconsole=off
time.statusbar=off
resource.title=false
resource.message=false
statuses.console=none
statuses.chat=none
statuses.muc=none
occupants=true
occupants.size=15
roster=true
roster.offline=false
roster.empty=false
roster.by=none
roster.order=presence
roster.unread=off
roster.priority=false
roster.size=25
roster.wrap=false
roster.contact.indent=0
roster.resource=false
roster.presence=false
roster.status=false
roster.contacts=true
roster.unsubscribed=false
roster.rooms=false
roster.rooms.unread=off
roster.count=off
roster.count.zero=false
privileges=false
presence=false
intype=false
enc.warn=false
wins.autotidy=false
tls.show=false
console.muc=first
console.chat=first
console.private=first