88 lines
2.8 KiB
Diff
88 lines
2.8 KiB
Diff
diff -uprN gaim-1.5.0-clean/libpurple/protocols/novell/nmconn.c gaim-1.5.0-new-files/libpurple/protocols/novell/nmconn.c
|
|
--- gaim-1.5.0-clean/libpurple/protocols/novell/nmconn.c 2005-03-06 17:10:36.000000000 -0500
|
|
+++ gaim-1.5.0-new-files/libpurple/protocols/novell/nmconn.c 2005-10-05 14:57:03.000000000 -0400
|
|
@@ -191,6 +191,12 @@ void nm_release_conn(NMConn *conn)
|
|
g_free(conn->ssl_conn);
|
|
conn->ssl_conn = NULL;
|
|
}
|
|
+
|
|
+ if (conn->io) {
|
|
+ purple_io_destroy (conn->io);
|
|
+ conn->io = NULL;
|
|
+ }
|
|
+
|
|
g_free(conn->addr);
|
|
conn->addr = NULL;
|
|
g_free(conn);
|
|
@@ -203,11 +209,23 @@ nm_tcp_write(NMConn * conn, const void *
|
|
if (conn == NULL || buff == NULL)
|
|
return -1;
|
|
|
|
- if (!conn->use_ssl)
|
|
- return (write(conn->fd, buff, len));
|
|
- else if (conn->ssl_conn && conn->ssl_conn->write)
|
|
- return (conn->ssl_conn->write(conn->ssl_conn->data, buff, len));
|
|
- else
|
|
+ if (!conn->use_ssl) {
|
|
+ if (!conn->io || purple_io_get_fd (conn->io) != conn->fd) {
|
|
+ if (conn->io)
|
|
+ purple_io_destroy (conn->io);
|
|
+ conn->io = purple_io_new (conn->fd);
|
|
+ }
|
|
+
|
|
+ return purple_io_write_bytes (conn->io, buff, len);
|
|
+ } else if (conn->ssl_conn && conn->ssl_conn->data && conn->ssl_conn->write) {
|
|
+ if (!conn->io || purple_io_get_ssl_connection (conn->io) != conn->ssl_conn->data) {
|
|
+ if (conn->io)
|
|
+ purple_io_destroy (conn->io);
|
|
+ conn->io = purple_io_new_ssl (conn->ssl_conn->data);
|
|
+ }
|
|
+
|
|
+ return purple_io_write_bytes (conn->io, buff, len);
|
|
+ } else
|
|
return -1;
|
|
}
|
|
|
|
diff -uprN gaim-1.5.0-clean/libpurple/protocols/novell/nmconn.h gaim-1.5.0-new-files/libpurple/protocols/novell/nmconn.h
|
|
--- gaim-1.5.0-clean/libpurple/protocols/novell/nmconn.h 2004-06-23 13:27:56.000000000 -0400
|
|
+++ gaim-1.5.0-new-files/libpurple/protocols/novell/nmconn.h 2005-10-05 12:53:52.000000000 -0400
|
|
@@ -24,6 +24,7 @@
|
|
typedef struct _NMConn NMConn;
|
|
typedef struct _NMSSLConn NMSSLConn;
|
|
|
|
+#include "purple-io.h"
|
|
#include "nmfield.h"
|
|
#include "nmuser.h"
|
|
|
|
@@ -42,6 +43,9 @@ struct _NMConn
|
|
/* The file descriptor of the socket for the connection. */
|
|
int fd;
|
|
|
|
+ /* The buffering I/O wrapper. */
|
|
+ PurpleIO *io;
|
|
+
|
|
/* The transaction counter. */
|
|
int trans_id;
|
|
|
|
diff -uprN gaim-1.5.0-clean/libpurple/protocols/novell/novell.c gaim-1.5.0-new-files/libpurple/protocols/novell/novell.c
|
|
--- gaim-1.5.0-clean/libpurple/protocols/novell/novell.c 2005-07-24 15:27:36.000000000 -0400
|
|
+++ gaim-1.5.0-new-files/libpurple/protocols/novell/novell.c 2005-10-05 14:57:03.000000000 -0400
|
|
@@ -2166,17 +2166,12 @@ static void
|
|
novell_close(PurpleConnection * gc)
|
|
{
|
|
NMUser *user;
|
|
- NMConn *conn;
|
|
|
|
if (gc == NULL)
|
|
return;
|
|
|
|
user = gc->proto_data;
|
|
if (user) {
|
|
- conn = user->conn;
|
|
- if (conn && conn->ssl_conn) {
|
|
- purple_ssl_close(user->conn->ssl_conn->data);
|
|
- }
|
|
nm_deinitialize_user(user);
|
|
}
|
|
gc->proto_data = NULL;
|