summaryrefslogtreecommitdiff
path: root/source3/msdfs
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2004-03-09 23:26:56 +0000
committerJeremy Allison <jra@samba.org>2004-03-09 23:26:56 +0000
commit0060085a837cbeb049d51a254fbe83b8eea685bb (patch)
tree82b5ffcde6b5ce976e49a39f4b92a7822a1c7584 /source3/msdfs
parent104e6c43ed1f9732242db74792704beaf5fc302c (diff)
downloadsamba-0060085a837cbeb049d51a254fbe83b8eea685bb.tar.gz
samba-0060085a837cbeb049d51a254fbe83b8eea685bb.tar.bz2
samba-0060085a837cbeb049d51a254fbe83b8eea685bb.zip
Fix dfs referrals - don't use check_path_syntax. Also use mb char calls in
dfs code. Jeremy. (This used to be commit 70670841028aaeb72267ac41ca30af8dba412998)
Diffstat (limited to 'source3/msdfs')
-rw-r--r--source3/msdfs/msdfs.c19
1 files changed, 9 insertions, 10 deletions
diff --git a/source3/msdfs/msdfs.c b/source3/msdfs/msdfs.c
index cd83756056..081ce809cf 100644
--- a/source3/msdfs/msdfs.c
+++ b/source3/msdfs/msdfs.c
@@ -45,7 +45,7 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp)
/* now tokenize */
/* parse out hostname */
- p = strchr(temp,'\\');
+ p = strchr_m(temp,'\\');
if(p == NULL)
return False;
*p = '\0';
@@ -54,7 +54,7 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp)
/* parse out servicename */
temp = p+1;
- p = strchr(temp,'\\');
+ p = strchr_m(temp,'\\');
if(p == NULL) {
pstrcpy(pdp->servicename,temp);
pdp->reqpath[0] = '\0';
@@ -67,9 +67,8 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp)
/* rest is reqpath */
pstrcpy(pdp->reqpath, p+1);
p = pdp->reqpath;
- while (*p) {
- if (*p == '\\') *p = '/';
- p++;
+ while ((p = strchr_m(p, '\\'))!=NULL) {
+ *p++ = '/';
}
DEBUG(10,("rest of the path: %s\n",pdp->reqpath));
@@ -148,7 +147,7 @@ static BOOL parse_symlink(char* buf,struct referral** preflist,
for(i=0;i<count;i++) {
/* replace / in the alternate path by a \ */
- char* p = strchr(alt_path[i],'/');
+ char* p = strchr_m(alt_path[i],'/');
if(p)
*p = '\\';
@@ -270,7 +269,7 @@ static BOOL resolve_dfs_path(pstring dfspath, struct dfs_path* dp,
/* redirect if any component in the path is a link */
pstrcpy(reqpath, dp->reqpath);
- p = strrchr(reqpath, '/');
+ p = strrchr_m(reqpath, '/');
while (p) {
*p = '\0';
pstrcpy(localpath, reqpath);
@@ -288,7 +287,7 @@ static BOOL resolve_dfs_path(pstring dfspath, struct dfs_path* dp,
pstrcpy(buf, dfspath);
trim_char(buf, '\0', '\\');
for (; consumed_level; consumed_level--) {
- q = strrchr(buf, '\\');
+ q = strrchr_m(buf, '\\');
if (q)
*q = 0;
}
@@ -298,7 +297,7 @@ static BOOL resolve_dfs_path(pstring dfspath, struct dfs_path* dp,
return True;
}
- p = strrchr(reqpath, '/');
+ p = strrchr_m(reqpath, '/');
consumed_level++;
}
@@ -526,7 +525,7 @@ static int setup_ver2_dfs_referral(char* pathname, char** ppdata,
offset = 8;
/* add the referral elements */
for(i=0;i<junction->referral_count;i++) {
- struct referral* ref = &(junction->referral_list[i]);
+ struct referral* ref = &junction->referral_list[i];
int unilen;
SSVAL(pdata,offset,2); /* version 2 */