Commit c4843d4a authored by Alexandre Julliard's avatar Alexandre Julliard

server: Add a helper function to skip the object attributes structure.

parent d9e6a31c
...@@ -711,8 +711,7 @@ DECL_HANDLER(create_file) ...@@ -711,8 +711,7 @@ DECL_HANDLER(create_file)
if (!root_fd) return; if (!root_fd) return;
} }
name = (const char *)get_req_data() + sizeof(*objattr) + objattr->sd_len; name = get_req_data_after_objattr( objattr, &name_len );
name_len = get_req_data_size() - sizeof(*objattr) - objattr->sd_len;
reply->handle = 0; reply->handle = 0;
if ((file = create_file( root_fd, name, name_len, req->access, req->sharing, if ((file = create_file( root_fd, name, name_len, req->access, req->sharing,
......
...@@ -198,6 +198,15 @@ const struct object_attributes *get_req_object_attributes( const struct security ...@@ -198,6 +198,15 @@ const struct object_attributes *get_req_object_attributes( const struct security
return attr; return attr;
} }
/* return a pointer to the request data following an object attributes structure */
const void *get_req_data_after_objattr( const struct object_attributes *attr, data_size_t *len )
{
const void *ptr = (const WCHAR *)((const struct object_attributes *)get_req_data() + 1) +
attr->sd_len / sizeof(WCHAR) + attr->name_len / sizeof(WCHAR);
*len = get_req_data_size() - ((const char *)ptr - (const char *)get_req_data());
return ptr;
}
/* write the remaining part of the reply */ /* write the remaining part of the reply */
void write_reply( struct thread *thread ) void write_reply( struct thread *thread )
{ {
......
...@@ -48,6 +48,7 @@ extern const char *get_config_dir(void); ...@@ -48,6 +48,7 @@ extern const char *get_config_dir(void);
extern void *set_reply_data_size( data_size_t size ); extern void *set_reply_data_size( data_size_t size );
extern const struct object_attributes *get_req_object_attributes( const struct security_descriptor **sd, extern const struct object_attributes *get_req_object_attributes( const struct security_descriptor **sd,
struct unicode_str *name ); struct unicode_str *name );
extern const void *get_req_data_after_objattr( const struct object_attributes *attr, data_size_t *len );
extern int receive_fd( struct process *process ); extern int receive_fd( struct process *process );
extern int send_client_fd( struct process *process, int fd, obj_handle_t handle ); extern int send_client_fd( struct process *process, int fd, obj_handle_t handle );
extern void read_request( struct thread *thread ); extern void read_request( struct thread *thread );
......
...@@ -174,9 +174,8 @@ DECL_HANDLER(create_symlink) ...@@ -174,9 +174,8 @@ DECL_HANDLER(create_symlink)
if (!objattr) return; if (!objattr) return;
target.str = (const WCHAR *)get_req_data() + sizeof(*objattr) / sizeof(WCHAR) + target.str = get_req_data_after_objattr( objattr, &target.len );
objattr->sd_len / sizeof(WCHAR) + name.len / sizeof(WCHAR); target.len = (target.len / sizeof(WCHAR)) * sizeof(WCHAR);
target.len = get_req_data_size() - ((const char *)target.str - (const char *)get_req_data());
if (objattr->rootdir && !(root = get_directory_obj( current->process, objattr->rootdir, 0 ))) return; if (objattr->rootdir && !(root = get_directory_obj( current->process, objattr->rootdir, 0 ))) return;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment