summaryrefslogtreecommitdiff
path: root/source3/smbd/reply.c
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2004-03-11 22:59:58 +0000
committerJeremy Allison <jra@samba.org>2004-03-11 22:59:58 +0000
commit39c731347045dc345862d527871ae5b9a4619e74 (patch)
tree1efcc9c3ea2080a20b4bc52bf0b08a69c161b847 /source3/smbd/reply.c
parent77b180d401b1f431dd550a8498b83bdb24cd7325 (diff)
downloadsamba-39c731347045dc345862d527871ae5b9a4619e74.tar.gz
samba-39c731347045dc345862d527871ae5b9a4619e74.tar.bz2
samba-39c731347045dc345862d527871ae5b9a4619e74.zip
Restore the contract on all convert_stringXX() interfaces. Add a "allow_bad_conv"
boolean parameter that allows broken iconv conversions to work. Gets rid of the nasty errno checks in mangle_hash2 and check_path_syntax and allows correct return code checking. Jeremy. (This used to be commit 3b4fca7b7f410cb0f11322e22c8f26a662eff941)
Diffstat (limited to 'source3/smbd/reply.c')
-rw-r--r--source3/smbd/reply.c28
1 files changed, 6 insertions, 22 deletions
diff --git a/source3/smbd/reply.c b/source3/smbd/reply.c
index dc9f0be401..4a0c06f442 100644
--- a/source3/smbd/reply.c
+++ b/source3/smbd/reply.c
@@ -117,35 +117,19 @@ NTSTATUS check_path_syntax(pstring destname, const pstring srcname)
* conversion to unicode. If the one byte char converts then
* it really is a directory separator following. Otherwise if
* the two byte character converts (and it should or our assumption
- * about character sets is broken and we panic) then copy both
+ * about character sets is broken and we return an error) then copy both
* bytes as it's a MB character, not a directory separator.
*/
uint16 ucs2_val;
- /*
- * We know the following will return 2 bytes. What
- * we need to know was if errno was set.
- * Note that if CH_UNIX is utf8 a string may be 3
- * bytes, but this is ok as mb utf8 characters don't
- * contain embedded directory separators. We are really checking
- * for mb UNIX asian characters like Japanese (SJIS) here.
- * JRA.
- */
-
- errno = 0;
- convert_string(CH_UNIX, CH_UCS2, s, 1, &ucs2_val, 2);
- if (errno == 0) {
+ if (convert_string(CH_UNIX, CH_UCS2, s, 1, &ucs2_val, 2, False) == 2) {
;
+ } else if (convert_string(CH_UNIX, CH_UCS2, s, 2, &ucs2_val, 2, False) == 2) {
+ *d++ = *s++;
} else {
- errno = 0;
- convert_string(CH_UNIX, CH_UCS2, s, 2, &ucs2_val, 2);
- if (errno == 0) {
- *d++ = *s++;
- } else {
- DEBUG(0,("check_path_syntax: directory separator assumptions invalid !\n"));
- return NT_STATUS_INVALID_PARAMETER;
- }
+ DEBUG(0,("check_path_syntax: directory separator assumptions invalid !\n"));
+ return NT_STATUS_INVALID_PARAMETER;
}
}
/* Just copy the char (or the second byte of the mb char). */