/* * Copyright (c) 1992, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * @(#)fnmatch.h 8.1 (Berkeley) 6/2/93 */ /* This file has been modified by the Apache Software Foundation. */ #ifndef _APR_FNMATCH_H_ #define _APR_FNMATCH_H_ /** * @file apr_fnmatch.h * @brief APR FNMatch Functions */ #include "apr_errno.h" #include "apr_tables.h" #ifdef __cplusplus extern "C" { #endif /** * @defgroup apr_fnmatch Filename Matching Functions * @ingroup APR * @{ */ #define APR_FNM_NOMATCH 1 /**< Match failed. */ #define APR_FNM_NOESCAPE 0x01 /**< Disable backslash escaping. */ #define APR_FNM_PATHNAME 0x02 /**< Slash must be matched by slash. */ #define APR_FNM_PERIOD 0x04 /**< Period must be matched by period. */ #define APR_FNM_CASE_BLIND 0x08 /**< Compare characters case-insensitively. */ /** * Try to match the string to the given pattern, return APR_SUCCESS if * match, else return APR_FNM_NOMATCH. Note that there is no such thing as * an illegal pattern. * * With all flags unset, a pattern is interpreted as such: * * PATTERN: Backslash followed by any character, including another * backslash.<br/> * MATCHES: That character exactly. * * <p> * PATTERN: ?<br/> * MATCHES: Any single character. * </p> * * <p> * PATTERN: *<br/> * MATCHES: Any sequence of zero or more characters. (Note that multiple * *s in a row are equivalent to one.) * * PATTERN: Any character other than \?*[ or a \ at the end of the pattern<br/> * MATCHES: That character exactly. (Case sensitive.) * * PATTERN: [ followed by a class description followed by ]<br/> * MATCHES: A single character described by the class description. * (Never matches, if the class description reaches until the * end of the string without a ].) If the first character of * the class description is ^ or !, the sense of the description * is reversed. The rest of the class description is a list of * single characters or pairs of characters separated by -. Any * of those characters can have a backslash in front of them, * which is ignored; this lets you use the characters ] and - * in the character class, as well as ^ and ! at the * beginning. The pattern matches a single character if it * is one of the listed characters or falls into one of the * listed ranges (inclusive, case sensitive). Ranges with * the first character larger than the second are legal but * never match. Edge cases: [] never matches, and [^] and [!] * always match without consuming a character. * * Note that these patterns attempt to match the entire string, not * just find a substring matching the pattern. * * @param pattern The pattern to match to * @param strings The string we are trying to match * @param flags flags to use in the match. Bitwise OR of: * <pre> * APR_FNM_NOESCAPE Disable backslash escaping * APR_FNM_PATHNAME Slash must be matched by slash * APR_FNM_PERIOD Period must be matched by period * APR_FNM_CASE_BLIND Compare characters case-insensitively. * </pre> */ APR_DECLARE(apr_status_t) apr_fnmatch(const char *pattern, const char *strings, int flags); /** * Determine if the given pattern is a regular expression. * @param pattern The pattern to search for glob characters. * @return non-zero if pattern has any glob characters in it */ APR_DECLARE(int) apr_fnmatch_test(const char *pattern); /** * Find all files that match a specified pattern in a directory. * @param dir_pattern The pattern to use for finding files, appended * to the search directory. The pattern is anything following the * final forward or backward slash in the parameter. If no slash * is found, the current directory is searched. * @param result Array to use when storing the results * @param p The pool to use. * @return APR_SUCCESS if no processing errors occurred, APR error * code otherwise * @remark The returned array may be empty even if APR_SUCCESS was * returned. */ APR_DECLARE(apr_status_t) apr_match_glob(const char *dir_pattern, apr_array_header_t **result, apr_pool_t *p); /** @} */ #ifdef __cplusplus } #endif #endif /* !_APR_FNMATCH_H_ */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
apr-x86_64.h | File | 17.89 KB | 0644 |
|
apr.h | File | 636 B | 0644 |
|
apr_allocator.h | File | 6.07 KB | 0644 |
|
apr_anylock.h | File | 4.93 KB | 0644 |
|
apr_atomic.h | File | 6.04 KB | 0644 |
|
apr_base64.h | File | 3.75 KB | 0644 |
|
apr_buckets.h | File | 63.15 KB | 0644 |
|
apr_crypto.h | File | 19.68 KB | 0644 |
|
apr_cstr.h | File | 11.13 KB | 0644 |
|
apr_date.h | File | 3.47 KB | 0644 |
|
apr_dbd.h | File | 23.35 KB | 0644 |
|
apr_dbm.h | File | 8.4 KB | 0644 |
|
apr_dso.h | File | 2.64 KB | 0644 |
|
apr_encode.h | File | 30.35 KB | 0644 |
|
apr_env.h | File | 2.06 KB | 0644 |
|
apr_errno.h | File | 53.77 KB | 0644 |
|
apr_escape.h | File | 17.23 KB | 0644 |
|
apr_file_info.h | File | 17.17 KB | 0644 |
|
apr_file_io.h | File | 42.88 KB | 0644 |
|
apr_fnmatch.h | File | 6.08 KB | 0644 |
|
apr_general.h | File | 7.34 KB | 0644 |
|
apr_getopt.h | File | 5.84 KB | 0644 |
|
apr_global_mutex.h | File | 7.19 KB | 0644 |
|
apr_hash.h | File | 10.08 KB | 0644 |
|
apr_hooks.h | File | 12.36 KB | 0644 |
|
apr_inherit.h | File | 2.09 KB | 0644 |
|
apr_ldap.h | File | 5.57 KB | 0644 |
|
apr_ldap_init.h | File | 5.64 KB | 0644 |
|
apr_ldap_option.h | File | 8.4 KB | 0644 |
|
apr_ldap_rebind.h | File | 3.09 KB | 0644 |
|
apr_ldap_url.h | File | 3.71 KB | 0644 |
|
apr_lib.h | File | 8.23 KB | 0644 |
|
apr_md4.h | File | 4.42 KB | 0644 |
|
apr_md5.h | File | 6.2 KB | 0644 |
|
apr_memcache.h | File | 16.82 KB | 0644 |
|
apr_mmap.h | File | 5.01 KB | 0644 |
|
apr_network_io.h | File | 36.02 KB | 0644 |
|
apr_optional.h | File | 2.71 KB | 0644 |
|
apr_optional_hooks.h | File | 3.78 KB | 0644 |
|
apr_perms_set.h | File | 1.86 KB | 0644 |
|
apr_poll.h | File | 20.6 KB | 0644 |
|
apr_pools.h | File | 30.94 KB | 0644 |
|
apr_portable.h | File | 20.02 KB | 0644 |
|
apr_proc_mutex.h | File | 6.85 KB | 0644 |
|
apr_queue.h | File | 3.98 KB | 0644 |
|
apr_random.h | File | 4.92 KB | 0644 |
|
apr_redis.h | File | 15.62 KB | 0644 |
|
apr_reslist.h | File | 7.01 KB | 0644 |
|
apr_ring.h | File | 18.78 KB | 0644 |
|
apr_rmm.h | File | 4.67 KB | 0644 |
|
apr_sdbm.h | File | 5.97 KB | 0644 |
|
apr_sha1.h | File | 3.79 KB | 0644 |
|
apr_shm.h | File | 9.26 KB | 0644 |
|
apr_signal.h | File | 2.7 KB | 0644 |
|
apr_siphash.h | File | 6.01 KB | 0644 |
|
apr_skiplist.h | File | 14.19 KB | 0644 |
|
apr_strings.h | File | 14.55 KB | 0644 |
|
apr_strmatch.h | File | 2.61 KB | 0644 |
|
apr_support.h | File | 1.6 KB | 0644 |
|
apr_tables.h | File | 18.9 KB | 0644 |
|
apr_thread_cond.h | File | 5.4 KB | 0644 |
|
apr_thread_mutex.h | File | 4.39 KB | 0644 |
|
apr_thread_pool.h | File | 10.84 KB | 0644 |
|
apr_thread_proc.h | File | 36.8 KB | 0644 |
|
apr_thread_rwlock.h | File | 4.65 KB | 0644 |
|
apr_time.h | File | 7.39 KB | 0644 |
|
apr_uri.h | File | 6.43 KB | 0644 |
|
apr_user.h | File | 5.19 KB | 0644 |
|
apr_uuid.h | File | 2.05 KB | 0644 |
|
apr_version.h | File | 5.22 KB | 0644 |
|
apr_want.h | File | 2.89 KB | 0644 |
|
apr_xlate.h | File | 6.26 KB | 0644 |
|
apr_xml.h | File | 12.19 KB | 0644 |
|
apu.h | File | 4.22 KB | 0644 |
|
apu_errno.h | File | 5.32 KB | 0644 |
|
apu_version.h | File | 4.2 KB | 0644 |
|
apu_want.h | File | 1.45 KB | 0644 |
|