From 45ebc2ebb137febfea19d23e468f776155122f19 Mon Sep 17 00:00:00 2001
From: Alessio Igor Bogani <alessioigorbogani@gmail.com>
Date: Wed, 7 Feb 2024 12:34:17 +0100
Subject: [PATCH] Add a sleep if write() fails immediately

---
 src/Socket2.cpp | 20 ++++++++++++++------
 1 file changed, 14 insertions(+), 6 deletions(-)

diff --git a/src/Socket2.cpp b/src/Socket2.cpp
index 6c535ba..7cb26fb 100644
--- a/src/Socket2.cpp
+++ b/src/Socket2.cpp
@@ -532,14 +532,19 @@ void Socket2::write(const Tango::DevVarCharArray *argin)
 			{
 				delete argin_data;
 
-				string error_mesg = "Connection refused";
-
 				close();
 				open();
+
+				string error_mesg = "Connection refused";
 				DEBUG_STREAM << error_mesg << endl;
+
 				set_state( Tango::FAULT );
 				set_status( error_mesg );
 
+				sleep( tout.tv_sec );
+				usleep( tout.tv_usec );
+				timerclear( &tout );
+
 				Tango::Except::throw_exception( "",
 						error_mesg,
 						"Socket2::write()");
@@ -586,11 +591,12 @@ void Socket2::write(const Tango::DevVarCharArray *argin)
 
 	if( (bytes_total - output_queue_length()) != bytes_to_write )
 	{
-		string error_mesg = "Unable to send request to device";
-
 		close();
 		open();
+
+		string error_mesg = "Unable to send request to device";
 		DEBUG_STREAM << error_mesg << endl;
+
 		set_state( Tango::FAULT );
 		set_status( error_mesg );
 
@@ -997,9 +1003,11 @@ bool Socket2::read(timeval *tv)
 			close();
 			open();
 
-			DEBUG_STREAM << "Server shutting down" << endl;
+			string error_mesg = "Server shutting down";
+			DEBUG_STREAM << error_mesg << endl;
+
 			set_state(Tango::FAULT);
-			set_status("Server shutting down");
+			set_status(error_mesg);
 
 			sleep( tv->tv_sec );
 			usleep( tv->tv_usec );
-- 
GitLab