| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | \section{\module{stat} --- | 
					
						
							| 
									
										
										
										
											1999-03-02 16:37:17 +00:00
										 |  |  |          Interpreting \function{stat()} results} | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-03-02 16:37:17 +00:00
										 |  |  | \declaremodule{standard}{stat} | 
					
						
							| 
									
										
										
										
											1999-04-13 21:38:02 +00:00
										 |  |  |   \platform{Unix, Windows} | 
					
						
							| 
									
										
										
										
											1998-08-06 21:30:32 +00:00
										 |  |  | \modulesynopsis{Utilities for interpreting the results of | 
					
						
							| 
									
										
										
										
											1999-03-02 16:37:17 +00:00
										 |  |  |   \function{os.stat()}, \function{os.lstat()} and \function{os.fstat()}.} | 
					
						
							|  |  |  | \sectionauthor{Skip Montanaro}{skip@automatrix.com} | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | The \module{stat} module defines constants and functions for | 
					
						
							|  |  |  | interpreting the results of \function{os.stat()} and | 
					
						
							|  |  |  | \function{os.lstat()} (if they exist).  For complete details about the | 
					
						
							|  |  |  | \cfunction{stat()} and \cfunction{lstat()} system calls, consult your | 
					
						
							|  |  |  | local man pages. | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | The \module{stat} module defines the following functions: | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{S_ISDIR}{mode} | 
					
						
							| 
									
										
										
										
											1998-01-29 22:03:41 +00:00
										 |  |  | Return non-zero if the mode was gotten from a directory. | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{S_ISCHR}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a character special device. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-29 22:03:41 +00:00
										 |  |  | \begin{funcdesc}{S_ISBLK}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a block special device. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | \begin{funcdesc}{S_ISREG}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a regular file. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{S_ISFIFO}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a FIFO. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{S_ISLNK}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a symbolic link. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{S_ISSOCK}{mode} | 
					
						
							|  |  |  | Return non-zero if the mode was gotten from a socket. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All the data items below are simply symbolic indexes into the 10-tuple | 
					
						
							| 
									
										
										
										
											1999-03-02 16:37:17 +00:00
										 |  |  | returned by \function{os.stat()} or \function{os.lstat()}.   | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_MODE} | 
					
						
							|  |  |  | Inode protection mode. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_INO} | 
					
						
							|  |  |  | Inode number. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_DEV} | 
					
						
							|  |  |  | Device inode resides on. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_NLINK} | 
					
						
							|  |  |  | Number of links to the inode. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_UID} | 
					
						
							|  |  |  | User id of the owner. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_GID} | 
					
						
							|  |  |  | Group id of the owner. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_SIZE} | 
					
						
							|  |  |  | File size in bytes. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_ATIME} | 
					
						
							|  |  |  | Time of last access. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_MTIME} | 
					
						
							|  |  |  | Time of last modification. | 
					
						
							|  |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{datadesc}{ST_CTIME} | 
					
						
							| 
									
										
										
										
											1998-04-08 22:44:25 +00:00
										 |  |  | Time of last status change (see manual pages for details). | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | \end{datadesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Example: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1996-12-19 22:39:22 +00:00
										 |  |  | import os, sys | 
					
						
							|  |  |  | from stat import * | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def process(dir, func): | 
					
						
							|  |  |  |     '''recursively descend the directory rooted at dir, calling func for | 
					
						
							|  |  |  |        each regular file''' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for f in os.listdir(dir): | 
					
						
							|  |  |  |         mode = os.stat('%s/%s' % (dir, f))[ST_MODE]
 | 
					
						
							|  |  |  |         if S_ISDIR(mode): | 
					
						
							|  |  |  |             # recurse into directory | 
					
						
							|  |  |  |             process('%s/%s' % (dir, f), func)
 | 
					
						
							|  |  |  |         elif S_ISREG(mode): | 
					
						
							|  |  |  |             func('%s/%s' % (dir, f))
 | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             print 'Skipping %s/%s' % (dir, f)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def f(file): | 
					
						
							|  |  |  |     print 'frobbed', file | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-04-05 19:26:16 +00:00
										 |  |  | if __name__ == '__main__': | 
					
						
							|  |  |  |     process(sys.argv[1], f) | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} |