summaryrefslogtreecommitdiff
path: root/vio
diff options
context:
space:
mode:
authorunknown <cmiller@zippy.cornsilk.net>2006-09-13 09:40:07 -0400
committerunknown <cmiller@zippy.cornsilk.net>2006-09-13 09:40:07 -0400
commitf70015d1bb34ca244c5a1cc9f340712372447534 (patch)
tree35f0f9755402434d46f4ae30ced2b75f7ffb6cec /vio
parentb430d54aa72c73ad5fdb5af8e3591cc9f565cc78 (diff)
parente44a92325437caafc8034d6a90527e25285ba73f (diff)
downloadmariadb-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.c29
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__ */