⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 servconn.h

📁 Linux下的多协议即时通讯程序源代码
💻 H
字号:
/** * @file servconn.h Server connection functions * * purple * * Purple is the legal property of its developers, whose names are too numerous * to list here.  Please refer to the COPYRIGHT file distributed with this * source distribution. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */#ifndef _MSN_SERVCONN_H_#define _MSN_SERVCONN_H_typedef struct _MsnServConn MsnServConn;#include "session.h"#include "cmdproc.h"#include "proxy.h"#include "httpconn.h"/** * Connection error types. */typedef enum{	MSN_SERVCONN_ERROR_NONE,	MSN_SERVCONN_ERROR_CONNECT,	MSN_SERVCONN_ERROR_WRITE,	MSN_SERVCONN_ERROR_READ,} MsnServConnError;/** * Connection types. */typedef enum{	MSN_SERVCONN_NS,	MSN_SERVCONN_SB} MsnServConnType;/** * A Connection. */struct _MsnServConn{	MsnServConnType type; /**< The type of this connection. */	MsnSession *session;  /**< The MSN session of this connection. */	MsnCmdProc *cmdproc;  /**< The command processor of this connection. */	PurpleProxyConnectData *connect_data;	gboolean connected;   /**< A flag that states if it's connected. */	gboolean processing;  /**< A flag that states if something is working							with this connection. */	gboolean wasted;      /**< A flag that states if it should be destroyed. */	char *host; /**< The host this connection is connected or should be				  connected to. */	int num; /**< A number id of this connection. */	MsnHttpConn *httpconn; /**< The HTTP connection this connection should use. */	int fd; /**< The connection's file descriptor. */	int inpa; /**< The connection's input handler. */	char *rx_buf; /**< The receive buffer. */	int rx_len; /**< The receive buffer lenght. */	size_t payload_len; /**< The length of the payload.						  It's only set when we've received a command that						  has a payload. */	PurpleCircBuffer *tx_buf;	guint tx_handler;	void (*connect_cb)(MsnServConn *); /**< The callback to call when connecting. */	void (*disconnect_cb)(MsnServConn *); /**< The callback to call when disconnecting. */	void (*destroy_cb)(MsnServConn *); /**< The callback to call when destroying. */};/** * Creates a new connection object. * * @param session The session. * @param type The type of the connection. */MsnServConn *msn_servconn_new(MsnSession *session, MsnServConnType type);/** * Destroys a connection object. * * @param servconn The connection. */void msn_servconn_destroy(MsnServConn *servconn);/** * Connects to a host. * * @param servconn The connection. * @param host The host. * @param port The port. */gboolean msn_servconn_connect(MsnServConn *servconn, const char *host, int port);/** * Disconnects. * * @param servconn The connection. */void msn_servconn_disconnect(MsnServConn *servconn);/** * Sets the connect callback. * * @param servconn The servconn. * @param connect_cb The connect callback. */void msn_servconn_set_connect_cb(MsnServConn *servconn,								 void (*connect_cb)(MsnServConn *));/** * Sets the disconnect callback. * * @param servconn The servconn. * @param disconnect_cb The disconnect callback. */void msn_servconn_set_disconnect_cb(MsnServConn *servconn,									void (*disconnect_cb)(MsnServConn *));/** * Sets the destroy callback. * * @param servconn The servconn that's being destroyed. * @param destroy_cb The destroy callback. */void msn_servconn_set_destroy_cb(MsnServConn *servconn,								 void (*destroy_cb)(MsnServConn *));/** * Writes a chunck of data to the servconn. * * @param servconn The servconn. * @param buf The data to write. * @param size The size of the data. */ssize_t msn_servconn_write(MsnServConn *servconn, const char *buf,						  size_t size);/** * Function to call whenever an error related to a switchboard occurs. * * @param servconn The servconn. * @param error The error that happened. */void msn_servconn_got_error(MsnServConn *servconn, MsnServConnError error);#endif /* _MSN_SERVCONN_H_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -