|  | """Read and cache directory listings. | 
|  |  | 
|  | The listdir() routine returns a sorted list of the files in a directory, | 
|  | using a cache to avoid reading the directory more often than necessary. | 
|  | The annotate() routine appends slashes to directories.""" | 
|  | from warnings import warnpy3k | 
|  | warnpy3k("the dircache module has been removed in Python 3.0", stacklevel=2) | 
|  | del warnpy3k | 
|  |  | 
|  | import os | 
|  |  | 
|  | __all__ = ["listdir", "opendir", "annotate", "reset"] | 
|  |  | 
|  | cache = {} | 
|  |  | 
|  | def reset(): | 
|  | """Reset the cache completely.""" | 
|  | global cache | 
|  | cache = {} | 
|  |  | 
|  | def listdir(path): | 
|  | """List directory contents, using cache.""" | 
|  | try: | 
|  | cached_mtime, list = cache[path] | 
|  | del cache[path] | 
|  | except KeyError: | 
|  | cached_mtime, list = -1, [] | 
|  | mtime = os.stat(path).st_mtime | 
|  | if mtime != cached_mtime: | 
|  | list = os.listdir(path) | 
|  | list.sort() | 
|  | cache[path] = mtime, list | 
|  | return list | 
|  |  | 
|  | opendir = listdir # XXX backward compatibility | 
|  |  | 
|  | def annotate(head, list): | 
|  | """Add '/' suffixes to directories.""" | 
|  | for i in range(len(list)): | 
|  | if os.path.isdir(os.path.join(head, list[i])): | 
|  | list[i] = list[i] + '/' |