Alexandre Julliard : server: Use the new set_fd_user function in create_serial().

Alexandre Julliard julliard at wine.codeweavers.com
Tue Jan 24 06:45:40 CST 2006


Module: wine
Branch: refs/heads/master
Commit: ab5ca5c04829642fbf1cff1a6c530e6fe1afd313
URL:    http://source.winehq.org/git/?p=wine.git;a=commit;h=ab5ca5c04829642fbf1cff1a6c530e6fe1afd313

Author: Alexandre Julliard <julliard at winehq.org>
Date:   Tue Jan 24 13:31:48 2006 +0100

server: Use the new set_fd_user function in create_serial().

---

 server/serial.c |   18 +++++-------------
 1 files changed, 5 insertions(+), 13 deletions(-)

diff --git a/server/serial.c b/server/serial.c
index 08a64a0..42d274f 100644
--- a/server/serial.c
+++ b/server/serial.c
@@ -131,19 +131,14 @@ int is_serial_fd( struct fd *fd )
 struct object *create_serial( struct fd *fd, unsigned int options )
 {
     struct serial *serial;
-    int unix_fd;
-
-    if ((unix_fd = dup( get_unix_fd(fd) )) == -1) return NULL;
+    int unix_fd = get_unix_fd( fd );
 
     /* set the fd back to blocking if necessary */
     if (options & (FILE_SYNCHRONOUS_IO_ALERT | FILE_SYNCHRONOUS_IO_NONALERT))
         fcntl( unix_fd, F_SETFL, 0 );
 
-    if (!(serial = alloc_object( &serial_ops )))
-    {
-        close( unix_fd );
-        return NULL;
-    }
+    if (!(serial = alloc_object( &serial_ops ))) return NULL;
+
     serial->options      = options;
     serial->readinterval = 0;
     serial->readmult     = 0;
@@ -155,11 +150,8 @@ struct object *create_serial( struct fd 
     list_init( &serial->read_q );
     list_init( &serial->write_q );
     list_init( &serial->wait_q );
-    if (!(serial->fd = create_anonymous_fd( &serial_fd_ops, unix_fd, &serial->obj )))
-    {
-        release_object( serial );
-        return NULL;
-    }
+    serial->fd = (struct fd *)grab_object( fd );
+    set_fd_user( fd, &serial_fd_ops, &serial->obj );
     return &serial->obj;
 }
 




More information about the wine-cvs mailing list