cpsit / glob
A PHP implementation of Ant's glob.
Requires
- php: ^7.0
- webmozart/path-util: ^2.2
Requires (Dev)
- phpunit/phpunit: ^6
- sebastian/version: *
- symfony/filesystem: ^2.5
This package is auto-updated.
Last update: 2024-08-26 23:43:48 UTC
README
A utility implementing Ant-like globbing.
Note: This is a fork of webmozart/glob. In contrast to the original version it supports PHP >= 7.0.
We had to change the vendor name from Webmozart
to CPSIT
Syntax:
?
matches any character*
matches zero or more characters, except/
/**/
matches zero or more directory names[abc]
matches a single charactera
,b
orc
[a-c]
matches a single charactera
,b
orc
[^abc]
matches any character buta
,b
orc
[^a-c]
matches any character buta
,b
orc
{ab,cd}
matchesab
orcd
Comparison with glob()
Compared to PHP's native glob()
function, this utility supports:
/**/
for matching zero or more directories- globbing custom stream wrappers, like
myscheme://path/**/*.css
- matching globs against path strings
- filtering arrays of path strings by a glob
- exceptions if the glob contains invalid syntax
Since PHP's native glob()
function is much more efficient, this utility uses
glob()
internally whenever possible (i.e. when no special feature is used).
Installation
Use Composer to install the package:
$ composer require webmozart/glob
Usage
The main class of the package is Glob
. Use Glob::glob()
to glob the
filesystem:
use CPSIT\Glob\Glob; $paths = Glob::glob('/path/to/dir/*.css');
You can also use GlobIterator
to search the filesystem iteratively. However,
the iterator is not guaranteed to return sorted results:
use CPSIT\Glob\Iterator\GlobIterator; $iterator = new GlobIterator('/path/to/dir/*.css'); foreach ($iterator as $path) { // ... }
Path Matching
The package also provides utility methods for comparing paths against globs.
Use Glob::match()
to match a path against a glob:
if (Glob::match($path, '/path/to/dir/*.css')) { // ... }
Glob::filter()
filters a list of paths by a glob:
$paths = Glob::filter($paths, '/path/to/dir/*.css');
The same can be achieved iteratively with GlobFilterIterator
:
use CPSIT\Glob\Iterator\GlobFilterIterator; $iterator = new GlobFilterIterator('/path/to/dir/*.css', new ArrayIterator($paths)); foreach ($iterator as $path) { // ... }
You can also filter the keys of the path list by passing the FILTER_KEY
constant of the respective class:
$paths = Glob::filter($paths, '/path/to/dir/*.css', Glob::FILTER_KEY); $iterator = new GlobFilterIterator( '/path/to/dir/*.css', new ArrayIterator($paths), GlobFilterIterator::FILTER_KEY );
Relative Globs
Relative globs such as *.css
are not supported. Usually, such globs refer to
paths relative to the current working directory. This utility, however, does not
want to make such assumptions. Hence you should always pass absolute globs.
If you want to allow users to pass relative globs, I recommend to turn the globs into absolute globs using the Webmozart Path Utility:
use CPSIT\Glob\Glob; use Webmozart\PathUtil\Path; // If $glob is absolute, that glob is used without modification. // If $glob is relative, it is turned into an absolute path based on the current // working directory. $paths = Glob::glob(Path::makeAbsolute($glob, getcwd());
Windows Compatibility
Globs need to be passed in canonical form with forward slashes only. Returned paths contain forward slashes only.
Escaping
The Glob
class supports escaping by typing a backslash character \
before
any special character:
$paths = Glob::glob('/backup\\*/*.css');
In this example, the glob matches all CSS files in the /backup*
directory
rather than in all directories starting with /backup
. Due to PHP's own
escaping in strings, the backslash character \
needs to be typed twice to
produce a single \
in the string.
The following escape sequences are available:
\\?
: match a?
in the path\\*
: match a*
in the path\\{
: match a{
in the path\\}
: match a}
in the path\\[
: match a[
in the path\\]
: match a]
in the path\\^
: match a^
in the path\\-
: match a-
in the path\\\\
: match a\
in the path
Stream Wrappers
The Glob
class supports stream wrappers:
$paths = Glob::glob('myscheme:///**/*.css');
Authors
Contribute
Contributions to the package are always welcome!
- Report any bugs or issues you find on the issue tracker.
- You can grab the source code at the package's Git repository.
Support
If you are having problems, send a mail to bschussek@gmail.com or shout out to @webmozart on Twitter.
License
All contents of this package are licensed under the MIT license.