JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3RbrJFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr i f1@sdZddlZddlZddlZddlmZddlmZmZddl m Z GdddZ ej dd Z d d Zd ddd dZdS)zsdistutils.filelist Provides the FileList class, used for poking about the filesystem and building lists of files. N) convert_path)DistutilsTemplateErrorDistutilsInternalError)logc@seZdZdZddddZddZejddZd d Z d d Z d dZ ddZ ddZ ddZddZdddddZdddddZdS)FileListaA list of files built by on exploring the filesystem and filtered by applying various patterns to what we find there. Instance attributes: dir directory from which files will be taken -- only used if 'allfiles' not supplied to constructor files list of filenames currently being built/filtered/manipulated allfiles complete list of files under consideration (ie. without any filtering applied) NcCsd|_g|_dS)N)allfilesfiles)selfwarn debug_printr 7/opt/alt/python34/lib64/python3.4/distutils/filelist.py__init__s zFileList.__init__cCs ||_dS)N)r)r rr r r set_allfiles"szFileList.set_allfilescCst||_dS)N)findallr)r dirr r r r%szFileList.findallcCs'ddlm}|r#t|ndS)z~Print 'msg' to stdout if the global DEBUG (taken from the DISTUTILS_DEBUG environment variable) flag is true. r)DEBUGN)Zdistutils.debugrprint)r msgrr r r r (szFileList.debug_printcCs|jj|dS)N)rappend)r itemr r r r2szFileList.appendcCs|jj|dS)N)rextend)r itemsr r r r5szFileList.extendcCsXtttjj|j}g|_x*|D]"}|jjtjj|q.WdS)N)sortedmapospathsplitrrjoin)r Zsortable_filesZ sort_tupler r r sort8s  z FileList.sortcCsYxRtt|jdddD]1}|j||j|dkr |j|=q q WdS)Nr)rangelenr)r ir r r remove_duplicatesBs&zFileList.remove_duplicatescCs:|j}|d}d}}}|dkrut|dkrUtd|ndd |d dD}n|dkrt|d krtd|nt|d }dd |ddD}nT|dkrt|dkrtd|nt|d }ntd|||||fS)Nrincludeexcludeglobal-includeglobal-excludez&'%s' expects ...cSsg|]}t|qSr )r).0wr r r Vs z1FileList._parse_template_line..r recursive-includerecursive-excludez,'%s' expects ...cSsg|]}t|qSr )r)r+r,r r r r-\s graftprunez#'%s' expects a single zunknown action '%s')zincluder'r(r))r.r/)r1r2)rr#rr)r lineZwordsactionpatternsr dir_patternr r r _parse_template_lineKs,       zFileList._parse_template_linecCs|j|\}}}}|dkr}|jddj|x|D].}|j|ddsHtjd|qHqHWn|dkr|jddj|xs|D].}|j|ddstjd |qqWn:|d krA|jd dj|x|D].}|j|dd s tjd |q q Wn|dkr|jddj|x|D].}|j|dd sntjd|qnqnWnv|dkr|jd|dj|fxG|D]1}|j|d|stjd||qqWn |dkry|jd|dj|fx|D]1}|j|d|sAtjd||qAqAWn|dkr|jd||jdd|stjd|qnX|dkr |jd||jdd|stjd|qntd|dS)Nr&zinclude  anchorr z%warning: no files found matching '%s'r'zexclude z9warning: no previously-included files found matching '%s'zglobal-includezglobal-include rz>warning: no files found matching '%s' anywhere in distributionzglobal-excludezglobal-exclude zRwarning: no previously-included files matching '%s' found anywhere in distributionzrecursive-includezrecursive-include %s %sprefixz:warning: no files found matching '%s' under directory '%s'zrecursive-excludezrecursive-exclude %s %szNwarning: no previously-included files matching '%s' found under directory '%s'r1zgraft z+warning: no directories found matching '%s'r2zprune z6no previously-included directories found matching '%s'z'this cannot happen: invalid action '%s')r7r rinclude_patternrr exclude_patternr)r r3r4r5rr6patternr r r process_template_linegsf                          zFileList.process_template_liner rcCsd}t||||}|jd|j|jdkrK|jnxJ|jD]?}|j|rU|jd||jj|d}qUqUW|S)aSelect strings (presumably filenames) from 'self.files' that match 'pattern', a Unix-style wildcard (glob) pattern. Patterns are not quite the same as implemented by the 'fnmatch' module: '*' and '?' match non-special characters, where "special" is platform- dependent: slash on Unix; colon, slash, and backslash on DOS/Windows; and colon on Mac OS. If 'anchor' is true (the default), then the pattern match is more stringent: "*.py" will match "foo.py" but not "foo/bar.py". If 'anchor' is false, both of these will match. If 'prefix' is supplied, then only filenames starting with 'prefix' (itself a pattern) and ending with 'pattern', with anything in between them, will match. 'anchor' is ignored in this case. If 'is_regex' is true, 'anchor' and 'prefix' are ignored, and 'pattern' is assumed to be either a string containing a regex or a regex object -- no translation is done, the regex is just compiled and used as-is. Selected strings will be added to self.files. Return True if files are found, False otherwise. Fz%include_pattern: applying regex r'%s'Nz adding T)translate_patternr r=rrsearchrr)r r=r9r:is_regex files_found pattern_renamer r r r;s    zFileList.include_patterncCsd}t||||}|jd|jxhtt|jdddD]G}|j|j|rO|jd|j||j|=d}qOqOW|S)aRemove strings (presumably filenames) from 'files' that match 'pattern'. Other parameters are the same as for 'include_pattern()', above. The list 'self.files' is modified in place. Return True if files are found, False otherwise. Fz%exclude_pattern: applying regex r'%s'r z removing Tr!r!)r?r r=r"r#rr@)r r=r9r:rArBrCr$r r r r<s  &  zFileList.exclude_pattern)__name__ __module__ __qualname____doc__rrrcurdirrr rrrr%r7r>r;r<r r r r r s      L,rcCsddlm}m}m}m}g}|g}|j}|j}x|r|}tj|} x| D]} |tj krtj j || } n| } tj| } | |} || r|j| qk|| rk||  rk|| qkqkWqFW|S)z^Find all files under 'dir' and return the list of full filenames (relative to 'dir'). r)ST_MODES_ISREGS_ISDIRS_ISLNK) statrJrKrLrMpoprrlistdirrIrr)rrJrKrLrMliststackrOpushnamesrDfullnamerNmoder r r rs&"        rcCsStj|}tj}tjdkr0d}nd|}tjd||}|S)zTranslate a shell-like glob pattern to a regular expression; return a string containing the regex. Differs from 'fnmatch.translate()' in that '*' does not match "special characters" (which are platform-specific). \z\\\\z\1[^%s]z((?t|}nd}|dk rtd}t|dt| }tj}tjdkrd}nd|j|d|f}n|rd|}ntj|S)aTranslate a shell-like wildcard pattern to a compiled regular expression. Return the compiled regex. If 'is_regex' true, then 'pattern' is directly compiled to a regex (if it's a string) or just returned as-is (assumes it's a regex object). NrWz\\^z.*) isinstancestrr[compiler]r#rrZr)r=r9r:rArCZ empty_patternZ prefix_rerZr r r r?+s"       r?)rHrr[rXZdistutils.utilrZdistutils.errorsrrZ distutilsrrrIrr]r?r r r r s