summaryrefslogtreecommitdiffstats
path: root/Doc/lib/libdircache.tex
blob: 58845493b48c6d923a01fbf3133c0200344dd1d7 (plain)
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
48
49
\section{\module{dircache} ---
         Cached directory listings}

\declaremodule{standard}{dircache}
\sectionauthor{Moshe Zadka}{moshez@zadka.site.co.il}
\modulesynopsis{Return directory listing, with cache mechanism.}

The \module{dircache} module defines a function for reading directory listing
using a cache, and cache invalidation using the \var{mtime} of the directory.
Additionally, it defines a function to annotate directories by appending
a slash.

The \module{dircache} module defines the following functions:

\begin{funcdesc}{reset}{}
Resets the directory cache.
\end{funcdesc}

\begin{funcdesc}{listdir}{path}
Return a directory listing of \var{path}, as gotten from
\function{os.listdir()}. Note that unless \var{path} changes, further call
to \function{listdir()} will not re-read the directory structure.

Note that the list returned should be regarded as read-only. (Perhaps
a future version should change it to return a tuple?)
\end{funcdesc}

\begin{funcdesc}{opendir}{path}
Same as \function{listdir()}. Defined for backwards compatibility.
\end{funcdesc}

\begin{funcdesc}{annotate}{head, list}
Assume \var{list} is a list of paths relative to \var{head}, and append,
in place, a \character{/} to each path which points to a directory.
\end{funcdesc}

\begin{verbatim}
>>> import dircache
>>> a = dircache.listdir('/')
>>> a = a[:] # Copy the return value so we can change 'a'
>>> a
['bin', 'boot', 'cdrom', 'dev', 'etc', 'floppy', 'home', 'initrd', 'lib', 'lost+
found', 'mnt', 'proc', 'root', 'sbin', 'tmp', 'usr', 'var', 'vmlinuz']
>>> dircache.annotate('/', a)
>>> a
['bin/', 'boot/', 'cdrom/', 'dev/', 'etc/', 'floppy/', 'home/', 'initrd/', 'lib/
', 'lost+found/', 'mnt/', 'proc/', 'root/', 'sbin/', 'tmp/', 'usr/', 'var/', 'vm
linuz']
\end{verbatim}