X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=src%2Fwildcard.c;h=febe8ee039def9e92f435664756ff53ce2801837;hb=7c1dad65663cb7f2068539367e226f3901489f30;hp=742b564782d3219156ec5f669d2f6432d0bf1e8b;hpb=eeb96703721a2ba6c64ec63f2c330515e8992b4f;p=wimlib diff --git a/src/wildcard.c b/src/wildcard.c index 742b5647..febe8ee0 100644 --- a/src/wildcard.c +++ b/src/wildcard.c @@ -7,20 +7,18 @@ /* * Copyright (C) 2013 Eric Biggers * - * This file is part of wimlib, a library for working with WIM files. + * This file is free software; you can redistribute it and/or modify it under + * the terms of the GNU Lesser General Public License as published by the Free + * Software Foundation; either version 3 of the License, or (at your option) any + * later version. * - * wimlib is free software; you can redistribute it and/or modify it under the - * terms of the GNU General Public License as published by the Free - * Software Foundation; either version 3 of the License, or (at your option) - * any later version. - * - * wimlib is distributed in the hope that it will be useful, but WITHOUT ANY - * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR - * A PARTICULAR PURPOSE. See the GNU General Public License for more + * This file is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more * details. * - * You should have received a copy of the GNU General Public License - * along with wimlib; if not, see http://www.gnu.org/licenses/. + * You should have received a copy of the GNU Lesser General Public License + * along with this file; if not, see http://www.gnu.org/licenses/. */ #ifdef HAVE_CONFIG_H @@ -28,6 +26,7 @@ #endif #include + #include "wimlib/dentry.h" #include "wimlib/encoding.h" #include "wimlib/error.h" @@ -106,16 +105,17 @@ match_wildcard(const tchar *string, const tchar *wildcard, * path separators in the pattern must be @path_sep, and there cannot be * consecutive path separators, and there cannot be a trailing path * separator. If there is a leading path separator, the match is attempted - * with the filename only; otherwise, the matchis attempted with the whole + * with the filename only; otherwise, the match is attempted with the whole * path. * * @path_sep - * Path separator character in @path and @wildcard. + * Path separator character used in @path and @wildcard. * * @prefix_ok * If %true, allow a prefix of @path, terminated by a path separator, to - * match, in addition to @path itself. a.k.a. also return true if the - * wildcard actually matches one of the ancestor directories of @path. + * match the pattern, in addition to @path itself. In other words, return + * %true if the pattern actually matches one of the ancestor directories of + * @path. * * Returns %true if there was a match; %false if there was not. */ @@ -187,29 +187,25 @@ wildcard_status(const tchar *wildcard) static int match_dentry(struct wim_dentry *cur_dentry, struct match_dentry_ctx *ctx) { - tchar *name; - size_t name_len; + const tchar *name; + size_t name_nchars; int ret; if (cur_dentry->file_name_nbytes == 0) return 0; -#if TCHAR_IS_UTF16LE - name = cur_dentry->file_name; - name_len = cur_dentry->file_name_nbytes; -#else - ret = utf16le_to_tstr(cur_dentry->file_name, - cur_dentry->file_name_nbytes, - &name, &name_len); + ret = utf16le_get_tstr(cur_dentry->file_name, + cur_dentry->file_name_nbytes, + &name, &name_nchars); if (ret) return ret; -#endif - name_len /= sizeof(tchar); + name_nchars /= sizeof(tchar); - if (match_wildcard(name, - &ctx->wildcard_path[ctx->cur_component_offset], - ctx->cur_component_len, - ctx->case_insensitive)) + if (do_match_wildcard(name, + name_nchars, + &ctx->wildcard_path[ctx->cur_component_offset], + ctx->cur_component_len, + ctx->case_insensitive)) { switch (wildcard_status(&ctx->wildcard_path[ ctx->cur_component_offset + @@ -234,9 +230,8 @@ match_dentry(struct wim_dentry *cur_dentry, struct match_dentry_ctx *ctx) ret = 0; } -#if !TCHAR_IS_UTF16LE - FREE(name); -#endif + utf16le_put_tstr(name); + return ret; } @@ -331,7 +326,7 @@ expand_wildcard(WIMStruct *wim, struct wim_dentry *root; int ret; - root = wim_root_dentry(wim); + root = wim_get_current_root_dentry(wim); if (root == NULL) goto no_match;