亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? xtransmnx.c

?? 手寫識別Chinput源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* $XFree86: xc/lib/xtrans/Xtransmnx.c,v 3.3 1996/05/10 06:55:50 dawes Exp $ *//*Xtransmnx.cCreated:	11 April 1994 by Philip Homburg <philip@cs.vu.nl>*/#include <stdlib.h>#include <sys/ioctl.h>#include <sys/nbio.h>#include <net/hton.h>#include <net/netlib.h>#include <net/gen/in.h>#include <net/gen/netdb.h>#include <net/gen/tcp.h>#include <net/gen/tcp_io.h>struct private{	int nonblocking;	int read_inprogress;	char *read_buffer;	size_t read_bufsize;	size_t read_size;	size_t read_offset;	int write_inprogress;	char *write_buffer;	size_t write_bufsize;	size_t write_size;	size_t write_offset;	int write_errno;	int listen_completed;	u16_t listen_port;	XtransConnInfo listen_list;};#define RD_BUFSIZE	1024#define WR_BUFSIZE	1024static XtransConnInfo listen_list= NULL;static XtransConnInfo alloc_ConnInfo(Xtransport *thistrans);static void free_ConnInfo(XtransConnInfo ciptr);static struct private *alloc_private(size_t rd_size, size_t wr_size);static void free_private(struct private *priv);static void read_cb(nbio_ref_t ref, int res, int err);static void write_cb(nbio_ref_t ref, int res, int err);static void listen_cb(nbio_ref_t ref, int res, int err);static int restart_listen(XtransConnInfo ciptr);#ifdef TRANS_CLIENTstatic XtransConnInfoTRANS(MnxTcpOpenCOTSClient) (thistrans, protocol, host, port)Xtransport *thistrans;char 	   *protocol;char 	   *host;char       *port;{	XtransConnInfo	ciptr;	char *tcp_device;	int s_errno;	int fd;	nbio_ref_t ref;	PRMSG(2, "MnxTcpOpenCOTSClient(%s,%s,%s)\n",		protocol, host, port);	if ((ciptr= alloc_ConnInfo(thistrans)) == NULL)	{		PRMSG(1,			"MnxTcpOpenCOTSClient: alloc_ConnInfo failed\n",			0, 0, 0);		return NULL;	}	if ((ciptr->priv= (char *)alloc_private(RD_BUFSIZE, WR_BUFSIZE)) ==		NULL)	{		PRMSG(1,			"MnxTcpOpenCOTSClient: alloc_private() failed\n",			0, 0, 0);		s_errno= errno;		free_ConnInfo(ciptr);		errno= s_errno;		return NULL;	}	if ((tcp_device= getenv("TCP_DEVICE")) == NULL)		tcp_device= TCP_DEVICE;	PRMSG(4, "MnxTcpOpenCOTSClient: tcp_device= '%s'\n",		tcp_device, 0, 0);	if ((fd= open(tcp_device, O_RDWR)) == -1)	{		PRMSG(1,			"MnxTcpOpenCOTSClient: open '%s' failed: %s\n",			tcp_device, strerror(errno), 0);		s_errno= errno;		free_ConnInfo(ciptr);		errno= s_errno;		return NULL;	}	ciptr->fd= fd;	ref.ref_ptr= ciptr;	nbio_register(fd);	nbio_setcallback(fd, ASIO_READ, read_cb, ref);	nbio_setcallback(fd, ASIO_WRITE, write_cb, ref);	return ciptr;}#endif /* TRANS_CLIENT */#ifdef TRANS_SERVERstatic XtransConnInfoTRANS(MnxTcpOpenCOTSServer) (thistrans, protocol, host, port)Xtransport *thistrans;char 	   *protocol;char 	   *host;char 	   *port;{	XtransConnInfo	ciptr;	char *tcp_device;	int s_errno;	int fd;	nbio_ref_t ref;	PRMSG(2, "MnxTcpOpenCOTSServer(%s,%s,%s)\n",		protocol, host, port);	if ((ciptr= alloc_ConnInfo(thistrans)) == NULL)	{		PRMSG(1,			"MnxTcpOpenCOTSServer: alloc_ConnInfo failed\n",			0, 0, 0);		return NULL;	}	if ((ciptr->priv= (char *)alloc_private(RD_BUFSIZE, WR_BUFSIZE)) ==		NULL)	{		PRMSG(1,			"MnxTcpOpenCOTSServer: alloc_private() failed\n",			0, 0, 0);		s_errno= errno;		free_ConnInfo(ciptr);		errno= s_errno;		return NULL;	}	if ((tcp_device= getenv("TCP_DEVICE")) == NULL)		tcp_device= TCP_DEVICE;	PRMSG(4, "MnxTcpOpenCOTSServer: tcp_device= '%s'\n",		tcp_device, 0, 0);	if ((fd= open(tcp_device, O_RDWR)) == -1)	{		PRMSG(1,			"MnxTcpOpenCOTSServer: open '%s' failed: %s\n",			tcp_device, strerror(errno), 0);		s_errno= errno;		free_ConnInfo(ciptr);		errno= s_errno;		return NULL;	}	PRMSG(5, "MnxTcpOpenCOTSServer: fd= '%d'\n", fd, 0, 0);	ciptr->fd= fd;	ref.ref_ptr= ciptr;	nbio_register(fd);	nbio_setcallback(fd, ASIO_IOCTL, listen_cb, ref);	return ciptr;}#endif /* TRANS_SERVER */#ifdef TRANS_CLIENTstatic XtransConnInfoTRANS(MnxTcpOpenCLTSClient) (thistrans, protocol, host, port)Xtransport *thistrans;char 	   *protocol;char 	   *host;char 	   *port;{	abort();}#endif /* TRANS_CLIENT */#ifdef TRANS_SERVERstatic XtransConnInfoTRANS(MnxTcpOpenCLTSServer) (thistrans, protocol, host, port)Xtransport *thistrans;char 	   *protocol;char 	   *host;char 	   *port;{	abort();}#endif /* TRANS_SERVER */#ifdef TRANS_REOPENstatic XtransConnInfoTRANS(MnxTcpReopenCOTSServer) (thistrans, fd, port)Xtransport *thistrans;int	   fd;char	   *port;{    XtransConnInfo	ciptr;    int			i;    PRMSG (2,	"MnxTcpReopenCOTSServer(%d, %s)\n", fd, port, 0);    abort();}static XtransConnInfoTRANS(MnxTcpReopenCLTSServer) (thistrans, fd, port)Xtransport *thistrans;int	   fd;char	   *port;{    XtransConnInfo	ciptr;    int			i;    PRMSG (2,	"MnxTcpReopenCLTSServer(%d, %s)\n", fd, port, 0);    abort();}#endif /* TRANS_REOPEN */static intTRANS(MnxTcpSetOption) (ciptr, option, arg)XtransConnInfo 	ciptr;int 		option;int 		arg;{	int flags;	struct private *priv;	PRMSG(2, "MnxTcpSetOption(%d,%d,%d)\n",		ciptr->fd, option, arg);	priv= (struct private *)ciptr->priv;	switch(option)	{	case TRANS_NONBLOCKING:		flags= fcntl(ciptr->fd, F_GETFD);		if (flags == -1)		{			PRMSG(1,			"MnxTcpSetOption: fcntl F_GETFD failed: %s\n",				strerror(errno), 0, 0);			return -1;		}		if (arg == 0)			flags &= ~FD_ASYNCHIO;		else if (arg == 1)			flags |= FD_ASYNCHIO;		else		{			PRMSG(1,		"MnxTcpSetOption: bad arg for TRANS_NONBLOCKING: %d\n",				arg, 0, 0);			return -1;		}		if (fcntl(ciptr->fd, F_SETFD, flags) == -1)		{			PRMSG(1,			"MnxTcpSetOption: fcntl F_SETFD failed: %s\n",				strerror(errno), 0, 0);			return -1;		}		priv->nonblocking= arg;		return 0;	case TRANS_CLOSEONEXEC:		flags= fcntl(ciptr->fd, F_GETFD);		if (flags == -1)		{			PRMSG(1,			"MnxTcpSetOption: fcntl F_GETFD failed: %s\n",				strerror(errno), 0, 0);			return -1;		}		if (arg == 0)			flags &= ~FD_CLOEXEC;		else if (arg == 1)			flags |= FD_CLOEXEC;		else		{			PRMSG(1,		"MnxTcpSetOption: bad arg for TRANS_CLOSEONEXEC: %d\n",				arg, 0, 0);			return -1;		}		if (fcntl(ciptr->fd, F_SETFD, flags) == -1)		{			PRMSG(1,			"MnxTcpSetOption: fcntl F_SETFD failed: %s\n",				strerror(errno), 0, 0);			return -1;		}		return 0;	default:		PRMSG(1, "MnxTcpSetOption: unknown option '%d'\n",			option, 0, 0);		errno= EINVAL;		return -1;	}}#ifdef TRANS_SERVERstatic intTRANS(MnxTcpCreateListener) (ciptr, port)XtransConnInfo	ciptr;char		*port;{	struct servent *servp;	tcpport_t num_port;	char *check;	nwio_tcpconf_t tcpconf;	nwio_tcpcl_t tcpcl;	int r, s_errno, flags;	struct private *priv;	struct sockaddr_in *addr;	PRMSG(2, "MnxTcpCreateListener(%d,%s)\n", ciptr->fd, port, 0);	priv= (struct private *)ciptr->priv;	if (port == NULL)		num_port= 0;	else	{		num_port= strtol(port, &check, 10);		num_port= htons(num_port);		if (check[0] == '\0')			port= NULL;	}#ifdef X11_t	/*	 * X has a well known port, that is transport dependent. It is easier	 * to handle it here, than try and come up with a transport independent	 * representation that can be passed in and resolved the usual way.	 *	 * The port that is passed here is really a string containing the	 * idisplay from ConnectDisplay().	 */	if (port == NULL)		num_port= htons(ntohs(num_port) + X_TCP_PORT);#endif	if (port != NULL)	{		if ((servp = getservbyname (port, "tcp")) == NULL)		{			PRMSG(1,		"MnxTcpCreateListener: can't get service for %s\n",				port, 0, 0);			errno= EINVAL;			return TRANS_CREATE_LISTENER_FAILED;		}		num_port= servp->s_port;	}	tcpconf.nwtc_flags= NWTC_SHARED | NWTC_UNSET_RA | NWTC_UNSET_RP;	if (num_port != 0)	{		tcpconf.nwtc_locport= num_port;		tcpconf.nwtc_flags |= NWTC_LP_SET;	}	else		tcpconf.nwtc_flags |= NWTC_LP_SEL;	if (ioctl(ciptr->fd, NWIOSTCPCONF, &tcpconf) == -1)	{		PRMSG(1,		"MnxTcpCreateListener: NWIOSTCPCONF failed: %s\n",			strerror(errno),0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	if (ioctl(ciptr->fd, NWIOGTCPCONF, &tcpconf) == -1)	{		PRMSG(1,		"MnxTcpListen: NWIOGTCPCONF failed: %s\n",			strerror(errno),0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	priv->listen_port= tcpconf.nwtc_locport;	if ((addr= (struct sockaddr_in *)xalloc(sizeof(struct sockaddr_in)))		== NULL)	{		PRMSG(1, "MnxTcpAccept: malloc failed\n", 0, 0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	addr->sin_family= AF_INET;	addr->sin_addr.s_addr= tcpconf.nwtc_locaddr;	addr->sin_port= tcpconf.nwtc_locport;	if (ciptr->addr)		xfree(ciptr->addr);	ciptr->addr= (char *)addr;	ciptr->addrlen= sizeof(struct sockaddr_in);	flags= fcntl(ciptr->fd, F_GETFD);	if (flags == -1)	{		PRMSG(1,		"MnxTcpCreateListener: fcntl F_GETFD failed: %s\n",			strerror(errno), 0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	if (fcntl(ciptr->fd, F_SETFD, flags | FD_ASYNCHIO) == -1)	{		PRMSG(1,		"MnxTcpCreateListener: fcntl F_SETFD failed: %s\n",			strerror(errno), 0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	tcpcl.nwtcl_flags= 0;	r= ioctl(ciptr->fd, NWIOTCPLISTEN, &tcpcl);	s_errno= errno;	if (fcntl(ciptr->fd, F_SETFD, flags) == -1)	{		PRMSG(1,		"MnxTcpCreateListener: fcntl F_SETFD failed: %s\n",			strerror(errno), 0, 0);		return TRANS_CREATE_LISTENER_FAILED;	}	if (r == -1 && s_errno == EINPROGRESS)	{		nbio_inprogress(ciptr->fd, ASIO_IOCTL, 1 /* read */,			1 /* write */, 0 /* exception */);		return 0;	}	if (r == 0)	{		priv->listen_completed= 1;		return 0;	}	errno= s_errno;	PRMSG(1, "MnxTcpCreateListener: NWIOTCPLISTEN failed: %s\n",		strerror(errno), 0, 0);	return TRANS_CREATE_LISTENER_FAILED;}#endif /* TRANS_SERVER */#ifdef TRANS_SERVERstatic intTRANS(MnxTcpResetListener) (ciptr)XtransConnInfo	ciptr;{	PRMSG(2, "MnxTcpResetListener(%d)\n", ciptr->fd, 0, 0);	return TRANS_RESET_NOOP;}#endif /* TRANS_SERVER */#ifdef TRANS_SERVERstatic XtransConnInfoTRANS(MnxTcpAccept) (ciptr_listen, status)XtransConnInfo ciptr_listen;int	       *status;{	XtransConnInfo	ciptr;	int s_errno;	int fd;	nbio_ref_t ref;	struct private *priv;	nwio_tcpconf_t tcpconf;	struct sockaddr_in *addr;	PRMSG(2, "MnxTcpAccept(%d,%p)\n", ciptr_listen->fd, status, 0);	priv= (struct private *)ciptr_listen->priv;	*status= TRANS_ACCEPT_MISC_ERROR;	if (!priv->listen_completed)	{		PRMSG(1, "MnxTcpAccept: listen is not completed\n",			0, 0, 0);		*status= TRANS_ACCEPT_FAILED;		return NULL;	}	priv->listen_completed= 0;	if ((ciptr= alloc_ConnInfo(ciptr_listen->transptr)) == NULL)	{		PRMSG(1,			"MnxTcpAccept: alloc_ConnInfo failed\n",			0, 0, 0);		*status= TRANS_ACCEPT_BAD_MALLOC;		return NULL;	}	if ((ciptr->priv= (char *)alloc_private(RD_BUFSIZE, WR_BUFSIZE)) ==		NULL)	{		PRMSG(1,			"MnxTcpAccept: alloc_private() failed\n",			0, 0, 0);		s_errno= errno;		free_ConnInfo(ciptr);		errno= s_errno;		*status= TRANS_ACCEPT_BAD_MALLOC;		return NULL;	}	fd= dup(ciptr_listen->fd);	if (fd == -1)	{		s_errno= errno;		PRMSG(1, "MnxTcpAccept: dup failed: %s\n",			strerror(errno), 0, 0);		free_ConnInfo(ciptr);		*status= TRANS_ACCEPT_FAILED;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区视频在线| 欧美激情综合网| 日韩精品乱码免费| 91精品国产高清一区二区三区| 香蕉成人伊视频在线观看| 欧美日韩国产三级| 六月丁香综合在线视频| 久久综合给合久久狠狠狠97色69| 久久99蜜桃精品| 亚洲国产精品精华液ab| av毛片久久久久**hd| 亚洲一区欧美一区| 欧美一区二区三区啪啪| 国产精品456露脸| 亚洲美女视频在线观看| 欧美一区二区播放| 丁香桃色午夜亚洲一区二区三区| 亚洲人被黑人高潮完整版| 欧美日韩一卡二卡| 国产大陆a不卡| 夜夜嗨av一区二区三区四季av| 欧美日韩国产一区二区三区地区| 美腿丝袜亚洲综合| 欧美激情艳妇裸体舞| 欧美日韩电影在线播放| 国产不卡在线一区| 午夜精品成人在线| 国产精品久久久久久久久久免费看 | 国产一区 二区| 亚洲欧美色一区| 日韩欧美国产电影| 色综合视频一区二区三区高清| 日韩精品久久久久久| 国产精品理论在线观看| 日韩一卡二卡三卡| 日本丰满少妇一区二区三区| 久久国产精品99精品国产| 中文字幕一区在线观看| 日韩小视频在线观看专区| 一本大道av伊人久久综合| 久久99精品久久久久久| 一区二区三区资源| 亚洲国产精品二十页| 欧美一三区三区四区免费在线看| heyzo一本久久综合| 看国产成人h片视频| 亚洲免费av高清| 国产日产欧产精品推荐色 | eeuss鲁一区二区三区| 蜜桃精品视频在线| 亚洲成av人片一区二区梦乃| 国产精品卡一卡二| 欧美精品一区二区三区很污很色的 | 国产欧美日韩视频一区二区| 欧美人妇做爰xxxⅹ性高电影| aa级大片欧美| 国产精品一区二区三区乱码| 日韩电影在线看| 亚洲午夜电影在线| 亚洲欧美另类久久久精品2019| 久久精品视频免费| www国产成人| 欧美成人综合网站| 日韩欧美一区二区视频| 欧美日韩国产三级| 在线不卡中文字幕| 欧美日韩成人综合| 欧美日韩国产首页在线观看| 在线亚洲一区二区| 色偷偷久久人人79超碰人人澡| 不卡视频一二三| 99国产精品久久久久久久久久| 国产ts人妖一区二区| 国产99久久久国产精品免费看| 国产精品中文欧美| 国产成人午夜片在线观看高清观看| 精品无人区卡一卡二卡三乱码免费卡| 日产国产高清一区二区三区| 日韩av午夜在线观看| 蓝色福利精品导航| 激情成人综合网| 国产成人8x视频一区二区| 国产高清精品久久久久| 国产99久久久国产精品潘金网站| 国产不卡视频在线播放| 97久久人人超碰| 在线欧美小视频| 欧美人体做爰大胆视频| 日韩欧美国产综合一区 | 日韩免费电影一区| 精品成人免费观看| 久久久久9999亚洲精品| 欧美国产欧美亚州国产日韩mv天天看完整| 国产欧美综合在线| 自拍偷拍亚洲综合| 亚洲综合视频网| 香蕉乱码成人久久天堂爱免费| 青娱乐精品在线视频| 国产一区视频网站| 成人黄色777网| 欧美三级韩国三级日本三斤| 日韩亚洲欧美中文三级| 日本一区二区三级电影在线观看| 自拍偷拍欧美激情| 蜜桃视频一区二区三区在线观看| 国产精品一区二区在线观看网站| 97精品电影院| 日韩一级高清毛片| 一色桃子久久精品亚洲| 日韩精品一二区| 成人黄色小视频| 91精品国产全国免费观看| 欧美国产禁国产网站cc| 亚洲一二三四在线| 国产一区二区精品在线观看| 91美女福利视频| 欧美变态凌虐bdsm| 亚洲专区一二三| 国产精品影视网| 欧美日韩二区三区| 国产精品第一页第二页第三页| 日韩精品一二三四| 色综合天天综合网国产成人综合天 | 国产精品视频一二三区| 视频一区在线播放| 成人av电影在线播放| 日韩一区二区中文字幕| 亚洲欧美电影一区二区| 国产精品香蕉一区二区三区| 欧美视频日韩视频| 欧美高清一级片在线观看| 免费的成人av| 欧美在线观看视频在线| 久久久久99精品国产片| 蜜桃视频第一区免费观看| 色综合欧美在线| 国产欧美日韩视频在线观看| 青青草伊人久久| 欧美男女性生活在线直播观看| 国产精品美女一区二区三区| 久久成人免费电影| 777亚洲妇女| 亚洲综合一二三区| 97久久精品人人做人人爽| 国产色婷婷亚洲99精品小说| 免费成人在线网站| 欧美日韩在线观看一区二区| 自拍偷在线精品自拍偷无码专区 | 日本午夜精品视频在线观看 | 欧美成人欧美edvon| 五月婷婷综合网| 欧美专区亚洲专区| 一区二区三区在线视频免费| 成人h精品动漫一区二区三区| 2023国产一二三区日本精品2022| 麻豆成人91精品二区三区| 欧美浪妇xxxx高跟鞋交| 亚洲成av人片一区二区梦乃| 欧美在线制服丝袜| 亚洲综合激情另类小说区| 91福利在线播放| 亚洲激情图片一区| 欧美在线|欧美| 亚洲电影你懂得| 精品1区2区3区| 日本亚洲天堂网| 精品日韩一区二区三区| 久久草av在线| 久久蜜桃av一区精品变态类天堂| 久久se精品一区精品二区| 欧美成人高清电影在线| 国产精品一区二区在线观看网站| 久久奇米777| 成人免费高清在线| 亚洲欧美另类久久久精品2019| 在线亚洲人成电影网站色www| 亚洲自拍偷拍九九九| 欧美日韩精品一区二区三区四区| 天天色综合成人网| 欧美电影免费观看完整版| 国内成人自拍视频| 中文字幕中文字幕中文字幕亚洲无线 | 国产精品萝li| 在线观看亚洲专区| 丝袜美腿高跟呻吟高潮一区| 精品久久五月天| 成人激情校园春色| 亚洲最新视频在线播放| 91精品国产一区二区| 国产福利一区二区三区视频在线 | 欧美videossexotv100| 国产露脸91国语对白| 亚洲日本乱码在线观看| 欧美日本视频在线| 国模少妇一区二区三区| 亚洲人成小说网站色在线| 91精品国产欧美一区二区| 国产高清一区日本| 亚洲午夜久久久| 久久久久99精品一区|