For debugging, you may try replacing the error checking in the sockread from..

if ($sockerr) {
Message
}
Code

to the following:

if ($sockerr) {
Message
/echo -a $sock($sockname).wsmsg | ; This is the debug line, keep the else clause tho
}
else {
Code
}

If there is an error, it really shouldn't even be trying to send anything.