1 \section{\module{dircache
} ---
2 Cached directory listings
}
4 \declaremodule{standard
}{dircache
}
5 \sectionauthor{Moshe Zadka
}{mzadka@geocities.com
}
6 \modulesynopsis{Return directory listing, with cache mechanism.
}
8 The
\module{dircache
} module defines a function for reading directory listing
9 using a cache, and cache invalidation using the
\var{mtime
} of the directory.
10 Additionally, it defines a function to annotate directories by appending
13 The
\module{dircache
} module defines the following functions:
15 \begin{funcdesc
}{listdir
}{path
}
16 Return a directory listing of
\var{path
}, as gotten from
17 \function{os.listdir()
}. Note that unless
\var{path
} changes, further call
18 to
\function{listdir()
} will not re-read the directory structure.
20 Note that the list returned should be regarded as read-only. (Perhaps
21 a future version should change it to return a tuple?)
24 \begin{funcdesc
}{opendir
}{path
}
25 Same as
\function{listdir()
}. Defined for backwards compatability.
28 \begin{funcdesc
}{annotate
}{head, list
}
29 Assume
\var{list
} is a list of paths relative to
\var{head
}, and append,
30 in place, a
\character{/
} to each path which points to a directory.
35 >>> a=dircache.listdir('/')
36 >>> a=a
[:
] # Copy the return value so we can change 'a'
38 ['bin', 'boot', 'cdrom', 'dev', 'etc', 'floppy', 'home', 'initrd', 'lib', 'lost+
39 found', 'mnt', 'proc', 'root', 'sbin', 'tmp', 'usr', 'var', 'vmlinuz'
]
40 >>> dircache.annotate('/', a)
42 ['bin/', 'boot/', 'cdrom/', 'dev/', 'etc/', 'floppy/', 'home/', 'initrd/', 'lib/
43 ', 'lost+found/', 'mnt/', 'proc/', 'root/', 'sbin/', 'tmp/', 'usr/', 'var/', 'vm