[SCM] Samba Shared Repository - branch master updated

Jeremy Allison jra at samba.org
Tue Oct 18 16:06:03 MDT 2011


The branch, master has been updated
       via  8d54bdb vfs_netatalk should be using strstr_m, not strstr to find .AppleDouble paths.
       via  f5ae41d The last argument to atalk_build_paths() is always false, remove it.
      from  47aa9ed lib/util: skip single hex digit at the end of the input sting - fix potential segfault

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit 8d54bdb5e199b2198990ee8d572662a128506337
Author: Jeremy Allison <jra at samba.org>
Date:   Tue Oct 18 11:54:53 2011 -0700

    vfs_netatalk should be using strstr_m, not strstr to find .AppleDouble paths.
    
    Autobuild-User: Jeremy Allison <jra at samba.org>
    Autobuild-Date: Wed Oct 19 00:05:45 CEST 2011 on sn-devel-104

commit f5ae41d8235fe54ca04542877059aaa2e287b0c2
Author: Jeremy Allison <jra at samba.org>
Date:   Tue Oct 18 11:24:35 2011 -0700

    The last argument to atalk_build_paths() is always false, remove it.

-----------------------------------------------------------------------

Summary of changes:
 source3/modules/vfs_netatalk.c |   31 ++++++++++++++-----------------
 1 files changed, 14 insertions(+), 17 deletions(-)


Changeset truncated at 500 lines:

diff --git a/source3/modules/vfs_netatalk.c b/source3/modules/vfs_netatalk.c
index 8d2c9b7..3e5606b 100644
--- a/source3/modules/vfs_netatalk.c
+++ b/source3/modules/vfs_netatalk.c
@@ -34,8 +34,7 @@ static int atalk_build_paths(TALLOC_CTX *ctx, const char *path,
 			     const char *fname,
 			     char **adbl_path, char **orig_path,
 			     SMB_STRUCT_STAT *adbl_info,
-			     SMB_STRUCT_STAT *orig_info,
-			     bool fake_dir_create_times);
+			     SMB_STRUCT_STAT *orig_info);
 
 static int atalk_unlink_file(const char *path);
 
@@ -61,8 +60,7 @@ static int atalk_build_paths(TALLOC_CTX *ctx, const char *path,
 			     const char *fname,
 			     char **adbl_path, char **orig_path,
 			     SMB_STRUCT_STAT *adbl_info,
-			     SMB_STRUCT_STAT *orig_info,
-			     bool fake_dir_create_times)
+			     SMB_STRUCT_STAT *orig_info)
 {
 	int ptr0 = 0;
 	int ptr1 = 0;
@@ -75,7 +73,7 @@ static int atalk_build_paths(TALLOC_CTX *ctx, const char *path,
 #if 0
 	DEBUG(3, ("ATALK: PATH: %s[%s]\n", path, fname));
 #endif
-	if (strstr(path, APPLEDOUBLE) || strstr(fname, APPLEDOUBLE)) {
+	if (strstr_m(path, APPLEDOUBLE) || strstr_m(fname, APPLEDOUBLE)) {
 		DEBUG(3, ("ATALK: path %s[%s] already contains %s\n", path, fname, APPLEDOUBLE));
 		return -1;
 	}
@@ -88,7 +86,7 @@ static int atalk_build_paths(TALLOC_CTX *ctx, const char *path,
 	/* get pointer to last '/' */
 	ptr1 = atalk_get_path_ptr(*orig_path);
 
-	sys_lstat(*orig_path, orig_info, fake_dir_create_times);
+	sys_lstat(*orig_path, orig_info, false);
 
 	if (S_ISDIR(orig_info->st_ex_mode)) {
 		*adbl_path = talloc_asprintf(ctx, "%s/%s/%s/", 
@@ -103,7 +101,7 @@ static int atalk_build_paths(TALLOC_CTX *ctx, const char *path,
 #if 0
 	DEBUG(3, ("ATALK: DEBUG:\n%s\n%s\n", *orig_path, *adbl_path)); 
 #endif
-	sys_lstat(*adbl_path, adbl_info, fake_dir_create_times);
+	sys_lstat(*adbl_path, adbl_info, false);
 	return 0;
 }
 
@@ -128,7 +126,7 @@ static void atalk_add_to_list(name_compare_entry **list)
 
 	if (cur_list) {
 		for (i = 0, count = 0; cur_list[i].name; i ++, count ++) {
-			if (strstr(cur_list[i].name, APPLEDOUBLE))
+			if (strstr_m(cur_list[i].name, APPLEDOUBLE))
 				return;
 		}
 	}
@@ -237,7 +235,7 @@ static int atalk_rmdir(struct vfs_handle_struct *handle, const char *path)
 	 * from this module, gotta use talloc stuff..
 	 */
 
-	strstr(path, APPLEDOUBLE) ? (add = False) : (add = True);
+	strstr_m(path, APPLEDOUBLE) ? (add = False) : (add = True);
 
 	if (!(ctx = talloc_init("remove_directory")))
 		goto exit_rmdir;
@@ -276,7 +274,7 @@ static int atalk_rename(struct vfs_handle_struct *handle,
 
 	if (atalk_build_paths(talloc_tos(), handle->conn->origpath, oldname,
 			      &adbl_path, &orig_path, &adbl_info,
-			      &orig_info, false) != 0)
+			      &orig_info) != 0)
 		goto exit_rename;
 
 	if (S_ISDIR(orig_info.st_ex_mode) || S_ISREG(orig_info.st_ex_mode)) {
@@ -319,13 +317,13 @@ static int atalk_unlink(struct vfs_handle_struct *handle,
 	if (!handle->conn->hide_list) return ret;
 
 	for (i = 0; handle->conn->veto_list[i].name; i ++) {
-		if (strstr(handle->conn->veto_list[i].name, APPLEDOUBLE))
+		if (strstr_m(handle->conn->veto_list[i].name, APPLEDOUBLE))
 			break;
 	}
 
 	if (!handle->conn->veto_list[i].name) {
 		for (i = 0; handle->conn->hide_list[i].name; i ++) {
-			if (strstr(handle->conn->hide_list[i].name, APPLEDOUBLE))
+			if (strstr_m(handle->conn->hide_list[i].name, APPLEDOUBLE))
 				break;
 			else {
 				DEBUG(3, ("ATALK: %s is not hidden, skipped..\n",
@@ -337,7 +335,7 @@ static int atalk_unlink(struct vfs_handle_struct *handle,
 
 	if (atalk_build_paths(talloc_tos(), handle->conn->origpath, path,
 			      &adbl_path, &orig_path,
-			      &adbl_info, &orig_info, false) != 0)
+			      &adbl_info, &orig_info) != 0)
 		goto exit_unlink;
 
 	if (S_ISDIR(orig_info.st_ex_mode) || S_ISREG(orig_info.st_ex_mode)) {
@@ -371,8 +369,7 @@ static int atalk_chmod(struct vfs_handle_struct *handle, const char *path, mode_
 		return ret;
 
 	if (atalk_build_paths(ctx, handle->conn->origpath, path, &adbl_path,
-			      &orig_path, &adbl_info, &orig_info,
-			      false) != 0)
+			      &orig_path, &adbl_info, &orig_info) != 0)
 		goto exit_chmod;
 
 	if (!S_ISDIR(orig_info.st_ex_mode) && !S_ISREG(orig_info.st_ex_mode)) {
@@ -405,7 +402,7 @@ static int atalk_chown(struct vfs_handle_struct *handle, const char *path, uid_t
 
 	if (atalk_build_paths(ctx, handle->conn->origpath, path,
 			      &adbl_path, &orig_path,
-			      &adbl_info, &orig_info, false) != 0)
+			      &adbl_info, &orig_info) != 0)
 		goto exit_chown;
 
 	if (!S_ISDIR(orig_info.st_ex_mode) && !S_ISREG(orig_info.st_ex_mode)) {
@@ -440,7 +437,7 @@ static int atalk_lchown(struct vfs_handle_struct *handle, const char *path, uid_
 
 	if (atalk_build_paths(ctx, handle->conn->origpath, path,
 			      &adbl_path, &orig_path,
-			      &adbl_info, &orig_info, false) != 0)
+			      &adbl_info, &orig_info) != 0)
 		goto exit_lchown;
 
 	if (!S_ISDIR(orig_info.st_ex_mode) && !S_ISREG(orig_info.st_ex_mode)) {


-- 
Samba Shared Repository


More information about the samba-cvs mailing list