diff options
author | unknown <cmiller@zippy.cornsilk.net> | 2006-09-13 09:40:07 -0400 |
---|---|---|
committer | unknown <cmiller@zippy.cornsilk.net> | 2006-09-13 09:40:07 -0400 |
commit | f70015d1bb34ca244c5a1cc9f340712372447534 (patch) | |
tree | 35f0f9755402434d46f4ae30ced2b75f7ffb6cec /vio | |
parent | b430d54aa72c73ad5fdb5af8e3591cc9f565cc78 (diff) | |
parent | e44a92325437caafc8034d6a90527e25285ba73f (diff) | |
download | mariadb-git-f70015d1bb34ca244c5a1cc9f340712372447534.tar.gz |
Merge zippy.cornsilk.net:/home/cmiller/work/mysql/mysql-5.0--windows-vio-uninit
into zippy.cornsilk.net:/home/cmiller/work/mysql/mysql-5.1-maint
vio/viosocket.c:
Auto merged
Diffstat (limited to 'vio')
-rw-r--r-- | vio/viosocket.c | 29 |
1 files changed, 27 insertions, 2 deletions
diff --git a/vio/viosocket.c b/vio/viosocket.c index 0d472be7901..da80c5b536f 100644 --- a/vio/viosocket.c +++ b/vio/viosocket.c @@ -562,9 +562,13 @@ int vio_write_shared_memory(Vio * vio, const gptr buf, int size) } +/** + Close shared memory and DBUG_PRINT any errors that happen on closing. + @return Zero if all closing functions succeed, and nonzero otherwise. +*/ int vio_close_shared_memory(Vio * vio) { - int r; + int error_count= 0; DBUG_ENTER("vio_close_shared_memory"); if (vio->type != VIO_CLOSED) { @@ -578,23 +582,44 @@ int vio_close_shared_memory(Vio * vio) result if they are success. */ if (UnmapViewOfFile(vio->handle_map) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("UnmapViewOfFile() failed")); + } if (CloseHandle(vio->event_server_wrote) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->esw) failed")); + } if (CloseHandle(vio->event_server_read) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->esr) failed")); + } if (CloseHandle(vio->event_client_wrote) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->ecw) failed")); + } if (CloseHandle(vio->event_client_read) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->ecr) failed")); + } if (CloseHandle(vio->handle_file_map) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->hfm) failed")); + } if (CloseHandle(vio->event_conn_closed) == 0) + { + error_count++; DBUG_PRINT("vio_error", ("CloseHandle(vio->ecc) failed")); + } } vio->type= VIO_CLOSED; vio->sd= -1; - DBUG_RETURN(!r); + DBUG_RETURN(error_count); } #endif /* HAVE_SMEM */ #endif /* __WIN__ */ |