From 8087e701ccddc5ea8835292605007cced674a43b Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Fri, 12 Apr 2013 11:06:45 +0200 Subject: [PATCH] lib: Add synthetic_smb_fname_split Signed-off-by: Volker Lendecke Reviewed-by: Jeremy Allison --- source3/include/proto.h | 3 +++ source3/lib/filename_util.c | 29 +++++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/source3/include/proto.h b/source3/include/proto.h index 5b9decdc1ca..f481e9977de 100644 --- a/source3/include/proto.h +++ b/source3/include/proto.h @@ -1609,6 +1609,9 @@ struct smb_filename *synthetic_smb_fname(TALLOC_CTX *mem_ctx, const char *base_name, const char *stream_name, const SMB_STRUCT_STAT *psbuf); +struct smb_filename *synthetic_smb_fname_split(TALLOC_CTX *ctx, + const char *fname, + const SMB_STRUCT_STAT *psbuf); const char *smb_fname_str_dbg(const struct smb_filename *smb_fname); const char *fsp_str_dbg(const struct files_struct *fsp); const char *fsp_fnum_dbg(const struct files_struct *fsp); diff --git a/source3/lib/filename_util.c b/source3/lib/filename_util.c index a92c11e304e..2fe611c6d4b 100644 --- a/source3/lib/filename_util.c +++ b/source3/lib/filename_util.c @@ -117,6 +117,35 @@ NTSTATUS create_synthetic_smb_fname_split(TALLOC_CTX *ctx, return status; } +struct smb_filename *synthetic_smb_fname_split(TALLOC_CTX *ctx, + const char *fname, + const SMB_STRUCT_STAT *psbuf) +{ + const char *stream_name = NULL; + char *base_name = NULL; + struct smb_filename *ret; + + if (!lp_posix_pathnames()) { + stream_name = strchr_m(fname, ':'); + } + + /* Setup the base_name/stream_name. */ + if (stream_name) { + base_name = talloc_strndup(ctx, fname, + PTR_DIFF(stream_name, fname)); + } else { + base_name = talloc_strdup(ctx, fname); + } + + if (!base_name) { + return NULL; + } + + ret = synthetic_smb_fname(ctx, base_name, stream_name, psbuf); + TALLOC_FREE(base_name); + return ret; +} + /** * Return a string using the talloc_tos() */