From: Jeremy Allison Date: Wed, 7 Oct 2009 22:39:38 +0000 (-0700) Subject: Make the logic a lot clearer and fix the comment to match. X-Git-Tag: talloc-2.0.1~59 X-Git-Url: http://git.samba.org/samba.git/?p=ira%2Fwip.git;a=commitdiff_plain;h=94ce06f01d9c84e79df1029ec3e2c6defc7fa800;hp=91456b8dc5c4237eb76ac82afa0c5f4a35bdca65 Make the logic a lot clearer and fix the comment to match. Jeremy --- diff --git a/source3/smbd/files.c b/source3/smbd/files.c index bf216050b8c..f7509d75fde 100644 --- a/source3/smbd/files.c +++ b/source3/smbd/files.c @@ -429,24 +429,19 @@ bool file_find_subpath(files_struct *dir_fsp) fsp->conn->connectpath, fsp->fsp_name->base_name); - if (strnequal(d_fullname, d1_fullname, dlen)) { - /* - * If the open file is a second file handle to the - * same name or is a stream on the original file, then - * don't return true. - */ - if (d1_fullname[dlen] != '/') { - TALLOC_FREE(d1_fullname); - continue; - } - + /* + * If the open file has a path that is a longer + * component, then it's a subpath. + */ + if (strnequal(d_fullname, d1_fullname, dlen) && + (d1_fullname[dlen] == '/')) { TALLOC_FREE(d1_fullname); - ret = true; - goto out; + TALLOC_FREE(d_fullname); + return true; } TALLOC_FREE(d1_fullname); - } - out: + } + TALLOC_FREE(d_fullname); return ret; }