Added server_call_noerr function that avoids touching the last error.
diff --git a/include/server.h b/include/server.h
index d492b88..c00cab8 100644
--- a/include/server.h
+++ b/include/server.h
@@ -922,6 +922,10 @@
/* client communication functions */
+extern unsigned int server_call_noerr( enum request req );
+extern unsigned int server_call_fd( enum request req, int fd_out, int *fd_in );
+extern void server_protocol_error( const char *err, ... );
+
/* get a pointer to the request buffer */
static inline void * WINE_UNUSED get_req_buffer(void)
{
@@ -934,9 +938,13 @@
return (char *)NtCurrentTeb()->buffer + NtCurrentTeb()->buffer_size - (char *)ptr;
}
-extern unsigned int server_call( enum request req );
-extern unsigned int server_call_fd( enum request req, int fd_out, int *fd_in );
-extern void server_protocol_error( const char *err, ... );
+/* do a server call and set the last error code */
+static inline int server_call( enum request req )
+{
+ unsigned int res = server_call_noerr( req );
+ if (res) SetLastError( res );
+ return res;
+}
extern int CLIENT_InitServer(void);
extern int CLIENT_SetDebug( int level );