From 766f04cebd08d5b7056171945a79b7a8cb4de198 Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Thu, 11 Apr 2013 17:01:22 +0200 Subject: lib: Add synthetic_smb_fname The interface of create_synthetic_smb_fname is just silly Signed-off-by: Volker Lendecke Reviewed-by: Jeremy Allison --- source3/lib/filename_util.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'source3/lib/filename_util.c') diff --git a/source3/lib/filename_util.c b/source3/lib/filename_util.c index 99cc114c18..2503e77764 100644 --- a/source3/lib/filename_util.c +++ b/source3/lib/filename_util.c @@ -75,6 +75,25 @@ NTSTATUS create_synthetic_smb_fname(TALLOC_CTX *ctx, const char *base_name, return copy_smb_filename(ctx, &smb_fname_loc, smb_fname_out); } +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 smb_fname_loc = { 0, }; + + /* Setup the base_name/stream_name. */ + smb_fname_loc.base_name = discard_const_p(char, base_name); + smb_fname_loc.stream_name = discard_const_p(char, stream_name); + + /* Copy the psbuf if one was given. */ + if (psbuf) + smb_fname_loc.st = *psbuf; + + /* Let copy_smb_filename() do the heavy lifting. */ + return cp_smb_filename(mem_ctx, &smb_fname_loc); +} + /** * XXX: This is temporary and there should be no callers of this once * smb_filename is plumbed through all path based operations. -- cgit