summaryrefslogtreecommitdiff
path: root/source3/lib/ms_fnmatch.c
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2004-12-02 00:55:47 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 10:53:30 -0500
commitd7a1c4f79c7c9d7038096a34626ba7236e856929 (patch)
treefbc89abd715f680349da1d709f70120d22959419 /source3/lib/ms_fnmatch.c
parent8fe6d35761a6928b606cce8b7c5d5cee95eb2d40 (diff)
downloadsamba-d7a1c4f79c7c9d7038096a34626ba7236e856929.tar.gz
r4032: Fix bug #2110 - ensure we convert to ucs2 correctly.
Jeremy. (This used to be commit a1e5a2a6ab1abc9add7a606e2e3f2d6c88dcf96c)
Diffstat (limited to 'source3/lib/ms_fnmatch.c')
-rw-r--r--source3/lib/ms_fnmatch.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/source3/lib/ms_fnmatch.c b/source3/lib/ms_fnmatch.c
index 3040dc7f9d3..71f3959c241 100644
--- a/source3/lib/ms_fnmatch.c
+++ b/source3/lib/ms_fnmatch.c
@@ -167,8 +167,17 @@ int ms_fnmatch(const char *pattern, const char *string, enum protocol_types prot
}
}
- pstrcpy_wa(p, pattern);
- pstrcpy_wa(s, string);
+ if (push_ucs2(NULL, p, pattern, sizeof(p), STR_TERMINATE) == (size_t)-1) {
+ /* Not quite the right answer, but finding the right one
+ under this failure case is expensive, and it's pretty close */
+ return -1;
+ }
+
+ if (push_ucs2(NULL, s, string, sizeof(s), STR_TERMINATE) == (size_t)-1) {
+ /* Not quite the right answer, but finding the right one
+ under this failure case is expensive, and it's pretty close */
+ return -1;
+ }
if (protocol <= PROTOCOL_LANMAN2) {
/*