Added pathtools
This commit is contained in:
parent
5611ff2f93
commit
695a901627
4 changed files with 524 additions and 0 deletions
21
Sublime/fl0w/pathtools/__init__.py
Normal file
21
Sublime/fl0w/pathtools/__init__.py
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# pathtools: File system path tools.
|
||||||
|
# Copyright (C) 2010 Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
# in the Software without restriction, including without limitation the rights
|
||||||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
# copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
# THE SOFTWARE.
|
207
Sublime/fl0w/pathtools/path.py
Normal file
207
Sublime/fl0w/pathtools/path.py
Normal file
|
@ -0,0 +1,207 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# path.py: Path functions.
|
||||||
|
#
|
||||||
|
# Copyright (C) 2010 Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
# in the Software without restriction, including without limitation the rights
|
||||||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
# copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
# THE SOFTWARE.
|
||||||
|
|
||||||
|
"""
|
||||||
|
:module: pathtools.path
|
||||||
|
:synopsis: Directory walking, listing, and path sanitizing functions.
|
||||||
|
:author: Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
|
||||||
|
Functions
|
||||||
|
---------
|
||||||
|
.. autofunction:: get_dir_walker
|
||||||
|
.. autofunction:: walk
|
||||||
|
.. autofunction:: listdir
|
||||||
|
.. autofunction:: list_directories
|
||||||
|
.. autofunction:: list_files
|
||||||
|
.. autofunction:: absolute_path
|
||||||
|
.. autofunction:: real_absolute_path
|
||||||
|
.. autofunction:: parent_dir_path
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os.path
|
||||||
|
import os.path
|
||||||
|
from functools import partial
|
||||||
|
|
||||||
|
|
||||||
|
__all__ = [
|
||||||
|
'get_dir_walker',
|
||||||
|
'walk',
|
||||||
|
'listdir',
|
||||||
|
'list_directories',
|
||||||
|
'list_files',
|
||||||
|
'absolute_path',
|
||||||
|
'real_absolute_path',
|
||||||
|
'parent_dir_path',
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
def get_dir_walker(recursive, topdown=True, followlinks=False):
|
||||||
|
"""
|
||||||
|
Returns a recursive or a non-recursive directory walker.
|
||||||
|
|
||||||
|
:param recursive:
|
||||||
|
``True`` produces a recursive walker; ``False`` produces a non-recursive
|
||||||
|
walker.
|
||||||
|
:returns:
|
||||||
|
A walker function.
|
||||||
|
"""
|
||||||
|
if recursive:
|
||||||
|
walk = partial(os.walk, topdown=topdown, followlinks=followlinks)
|
||||||
|
else:
|
||||||
|
def walk(path, topdown=topdown, followlinks=followlinks):
|
||||||
|
try:
|
||||||
|
yield next(os.walk(path, topdown=topdown, followlinks=followlinks))
|
||||||
|
except NameError:
|
||||||
|
yield os.walk(path, topdown=topdown, followlinks=followlinks).next() #IGNORE:E1101
|
||||||
|
return walk
|
||||||
|
|
||||||
|
|
||||||
|
def walk(dir_pathname, recursive=True, topdown=True, followlinks=False):
|
||||||
|
"""
|
||||||
|
Walks a directory tree optionally recursively. Works exactly like
|
||||||
|
:func:`os.walk` only adding the `recursive` argument.
|
||||||
|
|
||||||
|
:param dir_pathname:
|
||||||
|
The directory to traverse.
|
||||||
|
:param recursive:
|
||||||
|
``True`` for walking recursively through the directory tree;
|
||||||
|
``False`` otherwise.
|
||||||
|
:param topdown:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
:param followlinks:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
"""
|
||||||
|
walk_func = get_dir_walker(recursive, topdown, followlinks)
|
||||||
|
for root, dirnames, filenames in walk_func(dir_pathname):
|
||||||
|
yield (root, dirnames, filenames)
|
||||||
|
|
||||||
|
|
||||||
|
def listdir(dir_pathname,
|
||||||
|
recursive=True,
|
||||||
|
topdown=True,
|
||||||
|
followlinks=False):
|
||||||
|
"""
|
||||||
|
Enlists all items using their absolute paths in a directory, optionally
|
||||||
|
recursively.
|
||||||
|
|
||||||
|
:param dir_pathname:
|
||||||
|
The directory to traverse.
|
||||||
|
:param recursive:
|
||||||
|
``True`` for walking recursively through the directory tree;
|
||||||
|
``False`` otherwise.
|
||||||
|
:param topdown:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
:param followlinks:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
"""
|
||||||
|
for root, dirnames, filenames\
|
||||||
|
in walk(dir_pathname, recursive, topdown, followlinks):
|
||||||
|
for dirname in dirnames:
|
||||||
|
yield absolute_path(os.path.join(root, dirname))
|
||||||
|
for filename in filenames:
|
||||||
|
yield absolute_path(os.path.join(root, filename))
|
||||||
|
|
||||||
|
|
||||||
|
def list_directories(dir_pathname,
|
||||||
|
recursive=True,
|
||||||
|
topdown=True,
|
||||||
|
followlinks=False):
|
||||||
|
"""
|
||||||
|
Enlists all the directories using their absolute paths within the specified
|
||||||
|
directory, optionally recursively.
|
||||||
|
|
||||||
|
:param dir_pathname:
|
||||||
|
The directory to traverse.
|
||||||
|
:param recursive:
|
||||||
|
``True`` for walking recursively through the directory tree;
|
||||||
|
``False`` otherwise.
|
||||||
|
:param topdown:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
:param followlinks:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
"""
|
||||||
|
for root, dirnames, filenames\
|
||||||
|
in walk(dir_pathname, recursive, topdown, followlinks):
|
||||||
|
for dirname in dirnames:
|
||||||
|
yield absolute_path(os.path.join(root, dirname))
|
||||||
|
|
||||||
|
|
||||||
|
def list_files(dir_pathname,
|
||||||
|
recursive=True,
|
||||||
|
topdown=True,
|
||||||
|
followlinks=False):
|
||||||
|
"""
|
||||||
|
Enlists all the files using their absolute paths within the specified
|
||||||
|
directory, optionally recursively.
|
||||||
|
|
||||||
|
:param dir_pathname:
|
||||||
|
The directory to traverse.
|
||||||
|
:param recursive:
|
||||||
|
``True`` for walking recursively through the directory tree;
|
||||||
|
``False`` otherwise.
|
||||||
|
:param topdown:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
:param followlinks:
|
||||||
|
Please see the documentation for :func:`os.walk`
|
||||||
|
"""
|
||||||
|
for root, dirnames, filenames\
|
||||||
|
in walk(dir_pathname, recursive, topdown, followlinks):
|
||||||
|
for filename in filenames:
|
||||||
|
yield absolute_path(os.path.join(root, filename))
|
||||||
|
|
||||||
|
|
||||||
|
def absolute_path(path):
|
||||||
|
"""
|
||||||
|
Returns the absolute path for the given path and normalizes the path.
|
||||||
|
|
||||||
|
:param path:
|
||||||
|
Path for which the absolute normalized path will be found.
|
||||||
|
:returns:
|
||||||
|
Absolute normalized path.
|
||||||
|
"""
|
||||||
|
return os.path.abspath(os.path.normpath(path))
|
||||||
|
|
||||||
|
|
||||||
|
def real_absolute_path(path):
|
||||||
|
"""
|
||||||
|
Returns the real absolute normalized path for the given path.
|
||||||
|
|
||||||
|
:param path:
|
||||||
|
Path for which the real absolute normalized path will be found.
|
||||||
|
:returns:
|
||||||
|
Real absolute normalized path.
|
||||||
|
"""
|
||||||
|
return os.path.realpath(absolute_path(path))
|
||||||
|
|
||||||
|
|
||||||
|
def parent_dir_path(path):
|
||||||
|
"""
|
||||||
|
Returns the parent directory path.
|
||||||
|
|
||||||
|
:param path:
|
||||||
|
Path for which the parent directory will be obtained.
|
||||||
|
:returns:
|
||||||
|
Parent directory path.
|
||||||
|
"""
|
||||||
|
return absolute_path(os.path.dirname(path))
|
265
Sublime/fl0w/pathtools/patterns.py
Normal file
265
Sublime/fl0w/pathtools/patterns.py
Normal file
|
@ -0,0 +1,265 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# patterns.py: Common wildcard searching/filtering functionality for files.
|
||||||
|
#
|
||||||
|
# Copyright (C) 2010 Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
# in the Software without restriction, including without limitation the rights
|
||||||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
# copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
# THE SOFTWARE.
|
||||||
|
|
||||||
|
"""
|
||||||
|
:module: pathtools.patterns
|
||||||
|
:synopsis: Wildcard pattern matching and filtering functions for paths.
|
||||||
|
:author: Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
|
||||||
|
Functions
|
||||||
|
---------
|
||||||
|
.. autofunction:: match_path
|
||||||
|
.. autofunction:: match_path_against
|
||||||
|
.. autofunction:: filter_paths
|
||||||
|
"""
|
||||||
|
|
||||||
|
from fnmatch import fnmatch, fnmatchcase
|
||||||
|
|
||||||
|
__all__ = ['match_path',
|
||||||
|
'match_path_against',
|
||||||
|
'match_any_paths',
|
||||||
|
'filter_paths']
|
||||||
|
|
||||||
|
|
||||||
|
def _string_lower(s):
|
||||||
|
"""
|
||||||
|
Convenience function to lowercase a string (the :mod:`string` module is
|
||||||
|
deprecated/removed in Python 3.0).
|
||||||
|
|
||||||
|
:param s:
|
||||||
|
The string which will be lowercased.
|
||||||
|
:returns:
|
||||||
|
Lowercased copy of string s.
|
||||||
|
"""
|
||||||
|
return s.lower()
|
||||||
|
|
||||||
|
|
||||||
|
def match_path_against(pathname, patterns, case_sensitive=True):
|
||||||
|
"""
|
||||||
|
Determines whether the pathname matches any of the given wildcard patterns,
|
||||||
|
optionally ignoring the case of the pathname and patterns.
|
||||||
|
|
||||||
|
:param pathname:
|
||||||
|
A path name that will be matched against a wildcard pattern.
|
||||||
|
:param patterns:
|
||||||
|
A list of wildcard patterns to match_path the filename against.
|
||||||
|
:param case_sensitive:
|
||||||
|
``True`` if the matching should be case-sensitive; ``False`` otherwise.
|
||||||
|
:returns:
|
||||||
|
``True`` if the pattern matches; ``False`` otherwise.
|
||||||
|
|
||||||
|
Doctests::
|
||||||
|
>>> match_path_against("/home/username/foobar/blah.py", ["*.py", "*.txt"], False)
|
||||||
|
True
|
||||||
|
>>> match_path_against("/home/username/foobar/blah.py", ["*.PY", "*.txt"], True)
|
||||||
|
False
|
||||||
|
>>> match_path_against("/home/username/foobar/blah.py", ["*.PY", "*.txt"], False)
|
||||||
|
True
|
||||||
|
>>> match_path_against("C:\\windows\\blah\\BLAH.PY", ["*.py", "*.txt"], True)
|
||||||
|
False
|
||||||
|
>>> match_path_against("C:\\windows\\blah\\BLAH.PY", ["*.py", "*.txt"], False)
|
||||||
|
True
|
||||||
|
"""
|
||||||
|
if case_sensitive:
|
||||||
|
match_func = fnmatchcase
|
||||||
|
pattern_transform_func = (lambda w: w)
|
||||||
|
else:
|
||||||
|
match_func = fnmatch
|
||||||
|
pathname = pathname.lower()
|
||||||
|
pattern_transform_func = _string_lower
|
||||||
|
for pattern in set(patterns):
|
||||||
|
pattern = pattern_transform_func(pattern)
|
||||||
|
if match_func(pathname, pattern):
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def _match_path(pathname,
|
||||||
|
included_patterns,
|
||||||
|
excluded_patterns,
|
||||||
|
case_sensitive=True):
|
||||||
|
"""Internal function same as :func:`match_path` but does not check arguments.
|
||||||
|
|
||||||
|
Doctests::
|
||||||
|
>>> _match_path("/users/gorakhargosh/foobar.py", ["*.py"], ["*.PY"], True)
|
||||||
|
True
|
||||||
|
>>> _match_path("/users/gorakhargosh/FOOBAR.PY", ["*.py"], ["*.PY"], True)
|
||||||
|
False
|
||||||
|
>>> _match_path("/users/gorakhargosh/foobar/", ["*.py"], ["*.txt"], False)
|
||||||
|
False
|
||||||
|
>>> _match_path("/users/gorakhargosh/FOOBAR.PY", ["*.py"], ["*.PY"], False)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
...
|
||||||
|
ValueError: conflicting patterns `set(['*.py'])` included and excluded
|
||||||
|
"""
|
||||||
|
if not case_sensitive:
|
||||||
|
included_patterns = set(map(_string_lower, included_patterns))
|
||||||
|
excluded_patterns = set(map(_string_lower, excluded_patterns))
|
||||||
|
else:
|
||||||
|
included_patterns = set(included_patterns)
|
||||||
|
excluded_patterns = set(excluded_patterns)
|
||||||
|
common_patterns = included_patterns & excluded_patterns
|
||||||
|
if common_patterns:
|
||||||
|
raise ValueError('conflicting patterns `%s` included and excluded'\
|
||||||
|
% common_patterns)
|
||||||
|
return (match_path_against(pathname, included_patterns, case_sensitive)\
|
||||||
|
and not match_path_against(pathname, excluded_patterns,
|
||||||
|
case_sensitive))
|
||||||
|
|
||||||
|
|
||||||
|
def match_path(pathname,
|
||||||
|
included_patterns=None,
|
||||||
|
excluded_patterns=None,
|
||||||
|
case_sensitive=True):
|
||||||
|
"""
|
||||||
|
Matches a pathname against a set of acceptable and ignored patterns.
|
||||||
|
|
||||||
|
:param pathname:
|
||||||
|
A pathname which will be matched against a pattern.
|
||||||
|
:param included_patterns:
|
||||||
|
Allow filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern is specified, the function treats the pathname as
|
||||||
|
a match_path.
|
||||||
|
:param excluded_patterns:
|
||||||
|
Ignores filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern is specified, the function treats the pathname as
|
||||||
|
a match_path.
|
||||||
|
:param case_sensitive:
|
||||||
|
``True`` if matching should be case-sensitive; ``False`` otherwise.
|
||||||
|
:returns:
|
||||||
|
``True`` if the pathname matches; ``False`` otherwise.
|
||||||
|
:raises:
|
||||||
|
ValueError if included patterns and excluded patterns contain the
|
||||||
|
same pattern.
|
||||||
|
|
||||||
|
Doctests::
|
||||||
|
>>> match_path("/Users/gorakhargosh/foobar.py")
|
||||||
|
True
|
||||||
|
>>> match_path("/Users/gorakhargosh/foobar.py", case_sensitive=False)
|
||||||
|
True
|
||||||
|
>>> match_path("/users/gorakhargosh/foobar.py", ["*.py"], ["*.PY"], True)
|
||||||
|
True
|
||||||
|
>>> match_path("/users/gorakhargosh/FOOBAR.PY", ["*.py"], ["*.PY"], True)
|
||||||
|
False
|
||||||
|
>>> match_path("/users/gorakhargosh/foobar/", ["*.py"], ["*.txt"], False)
|
||||||
|
False
|
||||||
|
>>> match_path("/users/gorakhargosh/FOOBAR.PY", ["*.py"], ["*.PY"], False)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
...
|
||||||
|
ValueError: conflicting patterns `set(['*.py'])` included and excluded
|
||||||
|
"""
|
||||||
|
included = ["*"] if included_patterns is None else included_patterns
|
||||||
|
excluded = [] if excluded_patterns is None else excluded_patterns
|
||||||
|
return _match_path(pathname, included, excluded, case_sensitive)
|
||||||
|
|
||||||
|
|
||||||
|
def filter_paths(pathnames,
|
||||||
|
included_patterns=None,
|
||||||
|
excluded_patterns=None,
|
||||||
|
case_sensitive=True):
|
||||||
|
"""
|
||||||
|
Filters from a set of paths based on acceptable patterns and
|
||||||
|
ignorable patterns.
|
||||||
|
|
||||||
|
:param pathnames:
|
||||||
|
A list of path names that will be filtered based on matching and
|
||||||
|
ignored patterns.
|
||||||
|
:param included_patterns:
|
||||||
|
Allow filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern list is specified, ["*"] is used as the default pattern,
|
||||||
|
which matches all files.
|
||||||
|
:param excluded_patterns:
|
||||||
|
Ignores filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern list is specified, no files are ignored.
|
||||||
|
:param case_sensitive:
|
||||||
|
``True`` if matching should be case-sensitive; ``False`` otherwise.
|
||||||
|
:returns:
|
||||||
|
A list of pathnames that matched the allowable patterns and passed
|
||||||
|
through the ignored patterns.
|
||||||
|
|
||||||
|
Doctests::
|
||||||
|
>>> pathnames = set(["/users/gorakhargosh/foobar.py", "/var/cache/pdnsd.status", "/etc/pdnsd.conf", "/usr/local/bin/python"])
|
||||||
|
>>> set(filter_paths(pathnames)) == pathnames
|
||||||
|
True
|
||||||
|
>>> set(filter_paths(pathnames, case_sensitive=False)) == pathnames
|
||||||
|
True
|
||||||
|
>>> set(filter_paths(pathnames, ["*.py", "*.conf"], ["*.status"], case_sensitive=True)) == set(["/users/gorakhargosh/foobar.py", "/etc/pdnsd.conf"])
|
||||||
|
True
|
||||||
|
"""
|
||||||
|
included = ["*"] if included_patterns is None else included_patterns
|
||||||
|
excluded = [] if excluded_patterns is None else excluded_patterns
|
||||||
|
|
||||||
|
for pathname in pathnames:
|
||||||
|
# We don't call the public match_path because it checks arguments
|
||||||
|
# and sets default values if none are found. We're already doing that
|
||||||
|
# above.
|
||||||
|
if _match_path(pathname, included, excluded, case_sensitive):
|
||||||
|
yield pathname
|
||||||
|
|
||||||
|
def match_any_paths(pathnames,
|
||||||
|
included_patterns=None,
|
||||||
|
excluded_patterns=None,
|
||||||
|
case_sensitive=True):
|
||||||
|
"""
|
||||||
|
Matches from a set of paths based on acceptable patterns and
|
||||||
|
ignorable patterns.
|
||||||
|
|
||||||
|
:param pathnames:
|
||||||
|
A list of path names that will be filtered based on matching and
|
||||||
|
ignored patterns.
|
||||||
|
:param included_patterns:
|
||||||
|
Allow filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern list is specified, ["*"] is used as the default pattern,
|
||||||
|
which matches all files.
|
||||||
|
:param excluded_patterns:
|
||||||
|
Ignores filenames matching wildcard patterns specified in this list.
|
||||||
|
If no pattern list is specified, no files are ignored.
|
||||||
|
:param case_sensitive:
|
||||||
|
``True`` if matching should be case-sensitive; ``False`` otherwise.
|
||||||
|
:returns:
|
||||||
|
``True`` if any of the paths matches; ``False`` otherwise.
|
||||||
|
|
||||||
|
Doctests::
|
||||||
|
>>> pathnames = set(["/users/gorakhargosh/foobar.py", "/var/cache/pdnsd.status", "/etc/pdnsd.conf", "/usr/local/bin/python"])
|
||||||
|
>>> match_any_paths(pathnames)
|
||||||
|
True
|
||||||
|
>>> match_any_paths(pathnames, case_sensitive=False)
|
||||||
|
True
|
||||||
|
>>> match_any_paths(pathnames, ["*.py", "*.conf"], ["*.status"], case_sensitive=True)
|
||||||
|
True
|
||||||
|
>>> match_any_paths(pathnames, ["*.txt"], case_sensitive=False)
|
||||||
|
False
|
||||||
|
>>> match_any_paths(pathnames, ["*.txt"], case_sensitive=True)
|
||||||
|
False
|
||||||
|
"""
|
||||||
|
included = ["*"] if included_patterns is None else included_patterns
|
||||||
|
excluded = [] if excluded_patterns is None else excluded_patterns
|
||||||
|
|
||||||
|
for pathname in pathnames:
|
||||||
|
# We don't call the public match_path because it checks arguments
|
||||||
|
# and sets default values if none are found. We're already doing that
|
||||||
|
# above.
|
||||||
|
if _match_path(pathname, included, excluded, case_sensitive):
|
||||||
|
return True
|
||||||
|
return False
|
31
Sublime/fl0w/pathtools/version.py
Normal file
31
Sublime/fl0w/pathtools/version.py
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# version.py: Version information.
|
||||||
|
# Copyright (C) 2010 Yesudeep Mangalapilly <yesudeep@gmail.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
# in the Software without restriction, including without limitation the rights
|
||||||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
# copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
# THE SOFTWARE.
|
||||||
|
|
||||||
|
# When updating this version number, please update the
|
||||||
|
# ``docs/source/global.rst.inc`` file as well.
|
||||||
|
VERSION_MAJOR = 0
|
||||||
|
VERSION_MINOR = 1
|
||||||
|
VERSION_BUILD = 2
|
||||||
|
VERSION_INFO = (VERSION_MAJOR, VERSION_MINOR, VERSION_BUILD)
|
||||||
|
VERSION_STRING = "%d.%d.%d" % VERSION_INFO
|
||||||
|
|
||||||
|
__version__ = VERSION_INFO
|
Reference in a new issue