2016-12-06
2016-12-06 13:28:32 by Stephen R. van den Berg <srb@cuci.nl>
-
1cb5e7177d3096fea151ba1cf0bb000c9179a41a
(10 lines)
(+8/-2)
[
Show
| Annotate
]
Branch: 8.0
pgsql: Reconnect logic was broken, works reliably now.
371:
protected void destroy() {
PD("%d>Close conxion %d\n", socket ? socket->query_fd() : -1, !!nostash);
+ int|.pgsql_util.sql_result portal;
+ while (portal = qportals->try_read())
+ if (objectp(portal))
+ portal->_purgeportal();
if(nostash) {
catch {
while(sizeof(closecallbacks))
402: Inside #if constant(SSL.File)
socket=fcon;
break;
}
- default:PD("%d>Close socket\n",socket->query_fd());
+ default:
+ PD("%d>Close socket short\n", socket->query_fd());
socket->close();
pgsqlsess.nossl=1;
continue;
420:
#endif
break;
}
+ connectfail=pgsqlsess->_connectfail;
if(!socket->is_open())
error(strerror(socket->errno())+".\n");
- connectfail=pgsqlsess->_connectfail;
+
socket->set_backend(local_backend);
socket->set_buffer_mode(i,0);
socket->set_nonblocking(i->read_cb,write_cb,close);