blob: d96c741b963ca171e140bf1e2765e4044d3b781e [file] [log] [blame]
Fred Drakec7b5b3c1999-10-29 17:23:15 +00001\section{\module{filecmp} ---
Fred Drake353aaad2000-07-03 08:24:49 +00002 File and Directory Comparisons}
Fred Drakec7b5b3c1999-10-29 17:23:15 +00003
4\declaremodule{standard}{filecmp}
5\sectionauthor{Moshe Zadka}{mzadka@geocities.com}
6\modulesynopsis{Compare files efficiently.}
7
Fred Drake353aaad2000-07-03 08:24:49 +00008
9The \module{filecmp} module defines functions to compare files and directories,
10with various optional time/correctness trade-offs.
Fred Drakec7b5b3c1999-10-29 17:23:15 +000011
12The \module{filecmp} module defines the following function:
13
14\begin{funcdesc}{cmp}{f1, f2\optional{, shallow\optional{, use_statcache}}}
Fred Drake353aaad2000-07-03 08:24:49 +000015Compare the files named \var{f1} and \var{f2}, returning \code{1} if
16they seem equal, \code{0} otherwise.
Fred Drakec7b5b3c1999-10-29 17:23:15 +000017
18Unless \var{shallow} is given and is false, files with identical
Fred Drake353aaad2000-07-03 08:24:49 +000019\function{os.stat()} signatures are taken to be equal. If
Fred Drakec7b5b3c1999-10-29 17:23:15 +000020\var{use_statcache} is given and is true,
Fred Drake353aaad2000-07-03 08:24:49 +000021\function{statcache.stat()} will be called rather then
22\function{os.stat()}; the default is to use \function{os.stat()}.
Fred Drakec7b5b3c1999-10-29 17:23:15 +000023
24Files that were compared using this function will not be compared again
25unless their \function{os.stat()} signature changes. Note that using
26\var{use_statcache} true will cause the cache invalidation mechanism to
27fail --- the stale stat value will be used from \refmodule{statcache}'s
28cache.
29
Fred Drake353aaad2000-07-03 08:24:49 +000030Note that no external programs are called from this function, giving it
Fred Drakec7b5b3c1999-10-29 17:23:15 +000031portability and efficiency.
32\end{funcdesc}
33
Fred Drake353aaad2000-07-03 08:24:49 +000034\begin{funcdesc}{cmpfiles}{dir1, dir2, common\optional{,
35 shallow\optional{, use_statcache}}}
36Returns three lists of file names: \var{match}, \var{mismatch},
37\var{errors}. \var{match} contains the list of files match in both
38directories, \var{mismatch} includes the names of those that don't,
39and \var{errros} lists the names of files which could not be
40compared. Files may be listed in \var{errors} because the user may
41lack permission to read them or many other reasons, but always that
42the comparison could not be done for some reason.
43
44The \var{shallow} and \var{use_statcache} parameters have the same
45meanings and default values as for \function{filecmp.cmp()}.
46\end{funcdesc}
47
Fred Drakec7b5b3c1999-10-29 17:23:15 +000048Example:
49
50\begin{verbatim}
51>>> import filecmp
52>>> filecmp.cmp('libundoc.tex', 'libundoc.tex')
531
54>>> filecmp.cmp('libundoc.tex', 'lib.tex')
550
56\end{verbatim}
Fred Drake353aaad2000-07-03 08:24:49 +000057
58
59\subsection{The \protect\class{dircmp} class \label{dircmp-objects}}
60
61\begin{classdesc}{dircmp}{a, b\optional{, ignore\optional{, hide}}}
62Construct a new directory comparison object, to compare the
63directories \var{a} and \var{b}. \var{ignore} is a list of names to
64ignore, and defaults to \code{['RCS', 'CVS', 'tags']}. \var{hide} is a
65list of names to hid, and defaults to \code{[os.curdir, os.pardir]}.
66\end{classdesc}
67
68\begin{methoddesc}[dircmp]{report}{}
69Print (to \code{sys.stdout}) a comparison between \var{a} and \var{b}.
70\end{methoddesc}
71
72\begin{methoddesc}[dircmp]{report_partial_closure}{}
73Print a comparison between \var{a} and \var{b} and common immediate
74subdirctories.
75\end{methoddesc}
76
77\begin{methoddesc}[dircmp]{report_full_closure}{}
78Print a comparison between \var{a} and \var{b} and common
79subdirctories (recursively).
80\end{methoddesc}
81
82\begin{memberdesc}[dircmp]{left_list}
83Files and subdirectories in \var{a}, filtered by \var{hide} and
84\var{ignore}.
85\end{memberdesc}
86
87\begin{memberdesc}[dircmp]{right_list}
88Files and subdirectories in \var{b}, filtered by \var{hide} and
89\var{ignore}.
90\end{memberdesc}
91
92\begin{memberdesc}[dircmp]{common}
93Files and subdirectories in both \var{a} and \var{b}.
94\end{memberdesc}
95
96\begin{memberdesc}[dircmp]{left_only}
97Files and subdirectories only in \var{a}.
98\end{memberdesc}
99
100\begin{memberdesc}[dircmp]{right_only}
101Files and subdirectories only in \var{b}.
102\end{memberdesc}
103
104\begin{memberdesc}[dircmp]{common_dirs}
105Subdirectories in both \var{a} and \var{b}.
106\end{memberdesc}
107
108\begin{memberdesc}[dircmp]{common_files}
109Files in both \var{a} and \var{b}
110\end{memberdesc}
111
112\begin{memberdesc}[dircmp]{common_funny}
113Names in both \var{a} and \var{b}, such that the type differs between
114the directories, or names for which \function{os.stat()} reports an
115error.
116\end{memberdesc}
117
118\begin{memberdesc}[dircmp]{same_files}
119Files which are identical in both \var{a} and \var{b}.
120\end{memberdesc}
121
122\begin{memberdesc}[dircmp]{diff_files}
123Files which are in both \var{a} and \var{b}, whose contents differ.
124\end{memberdesc}
125
126\begin{memberdesc}[dircmp]{funny_files}
127Files which are in both \var{a} and \var{b}, but could not be
128compared.
129\end{memberdesc}
130
131\begin{memberdesc}[dircmp]{subdirs}
132A dictionary mapping names in \member{common_dirs} to
133\class{dircmp} objects.
134\end{memberdesc}
135
136Note that via \method{__getattr__()} hooks, all attributes are
137computed lazilly, so there is no speed penalty if only those
138attributes which are lightweight to compute are used.