1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
/*
Copyright 2024 Northern.tech AS
This file is part of CFEngine 3 - written and maintained by Northern.tech AS.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
To the extent this program is licensed as part of the Enterprise
versions of CFEngine, the applicable Commercial Open Source License
(COSL) may apply to this file if you as a licensee so wish it. See
included file COSL.txt.
*/
#ifndef GLOB_LIB_H
#define GLOB_LIB_H
#include <sequence.h>
#include <set.h>
/* Set by ./configure allowing us to avoid #include <config.h> here. */
@WITH_PCRE2_DEFINE@
#ifdef WITH_PCRE2
/**
* @brief Find files/directories matching shell pattern (glob).
*
* Patterns are UNIX shell style:
*
* '*' matches everything,
* '?' matches any single character,
* '[seq]' matches any character in seq,
* '[!seq]' matches any character not in seq,
* '{foo,bar}' matches foo or bar.
*
* Pattern is normalized if the operating system requires it. The double
* asterisk symbol does not match any subdirectories. The result is sorted in
* lexical order.
*
* @param pattern Glob pattern.
* @return Sorted sequence of matches.
*/
Seq *GlobFind(const char *pattern);
/**
* @brief Test whether string (filename) matches shell pattern (glob).
*
* Patterns are UNIX shell style:
*
* '*' matches everything,
* '?' matches any single character,
* '[seq]' matches any character in seq,
* '[!seq]' matches any character not in seq,
* '{foo,bar}' matches foo or bar.
*
* Pattern is normalized if the operating system requires it.
*
* We don't check if filename is valid, or if it is a file or if it exists.
* It's treated as just a string.
*
* Modeled after the python fnmatch module (see
* https://github.com/python/cpython/blob/3.8/Lib/fnmatch.py)
*
* @param pattern Glob pattern.
* @return True if filename matches shell pattern.
*/
bool GlobMatch(const char *pattern, const char *filename);
#endif // WITH_PCRE2
/**
* @brief Find files/directories matching shell pattern (glob).
*
* Patterns are UNIX shell style:
*
* '*' matches everything,
* '?' matches any single character,
* '[seq]' matches any character in seq,
* '[!seq]' matches any character not in seq,
* '{foo,bar}' matches foo or bar,
* '**' matches any subdirectory from zero up to six levels deep. A
* limit set by previous CFEngineers. TODO: remove limit in
* ticket CFE-4317.
*
* Pattern is normalized if the operating system requires it.
*
* @param pattern Glob pattern.
* @return Set of matches.
*/
StringSet *GlobFileList(const char *pattern);
#endif // GLOB_LIB_H
|