diff options
author | Aris Adamantiadis <aris@0xbadc0de.be> | 2011-03-22 11:49:57 +0100 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2011-03-23 08:49:26 +0100 |
commit | b7f6794e03f4e1f20f78967656c7a7d6d6b1940a (patch) | |
tree | 1ce9d5df4d1b0342203056b00803eef1067fc25c /src | |
parent | cd9fc88151fb66225297ec3a278a2d9756544b38 (diff) | |
download | libssh-b7f6794e03f4e1f20f78967656c7a7d6d6b1940a.tar.gz libssh-b7f6794e03f4e1f20f78967656c7a7d6d6b1940a.tar.xz libssh-b7f6794e03f4e1f20f78967656c7a7d6d6b1940a.zip |
Implement ssh_blocking_flush()
Based on code from Jan Willamowius
(cherry picked from commit dff4e4e6d3a56123b00df48fdcd7a6de0a275aef)
Diffstat (limited to 'src')
-rw-r--r-- | src/session.c | 25 | ||||
-rw-r--r-- | src/socket.c | 12 |
2 files changed, 37 insertions, 0 deletions
diff --git a/src/session.c b/src/session.c index ab7cdff9..be428889 100644 --- a/src/session.c +++ b/src/session.c @@ -298,6 +298,31 @@ int ssh_is_blocking(ssh_session session){ } /** + * @brief Blocking flush of the outgoing buffer + * @param[in] session The SSH session + * @param[in] timeout Set an upper limit on the time for which this function + * will block, in milliseconds. Specifying a negative value + * means an infinite timeout. This parameter is passed to + * the poll() function. + * @returns SSH_OK on success, SSH_ERROR otherwise. + */ + +int ssh_blocking_flush(ssh_session session, int timeout){ + ssh_socket s; + if(session==NULL) + return SSH_ERROR; + + enter_function(); + s=session->socket; + while (ssh_socket_buffered_write_bytes(s) > 0 && session->alive) { + ssh_handle_packets(session, timeout); + } + + leave_function(); + return SSH_OK; +} + +/** * @brief Check if we are connected. * * @param[in] session The session to check if it is connected. diff --git a/src/socket.c b/src/socket.c index 0f8fc23c..24616255 100644 --- a/src/socket.c +++ b/src/socket.c @@ -644,6 +644,18 @@ int ssh_socket_data_writable(ssh_socket s) { return s->write_wontblock; } +/** @internal + * @brief returns the number of outgoing bytes currently buffered + * @param s the socket + * @returns numbers of bytes buffered, or 0 if the socket isn't connected + */ +int ssh_socket_buffered_write_bytes(ssh_socket s){ + if(s==NULL || s->out_buffer == NULL) + return 0; + return buffer_get_rest_len(s->out_buffer); +} + + int ssh_socket_get_status(ssh_socket s) { int r = 0; |