亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
丰满白嫩尤物一区二区| 秋霞国产午夜精品免费视频| 国产高清不卡二三区| 国产精品国产三级国产aⅴ入口 | 久久久久久久综合狠狠综合| 久久99九九99精品| 精品国产免费人成电影在线观看四季| 日韩av午夜在线观看| 91麻豆精品国产91久久久资源速度 | 日本不卡在线视频| 91精品国产综合久久精品麻豆| 日本亚洲欧美天堂免费| 欧美一区二区三区免费大片 | 亚洲欧美在线另类| 色视频成人在线观看免| 亚洲图片有声小说| 日韩欧美一区二区三区在线| 国产一区二区在线看| 日本一区二区三区四区在线视频| 粉嫩aⅴ一区二区三区四区 | 国产精品国模大尺度视频| 91丝袜美腿高跟国产极品老师| 一级日本不卡的影视| 91麻豆精品国产无毒不卡在线观看| 久久成人综合网| 国产精品日韩成人| 欧美性大战久久久久久久蜜臀| 日韩av不卡一区二区| 久久久另类综合| 91在线免费视频观看| 日韩av一区二区三区四区| 久久久久综合网| 欧美在线视频全部完| 久草热8精品视频在线观看| 国产精品久久夜| 91精品国产入口| 99精品在线免费| 蜜臀av一区二区| 亚洲欧美日韩小说| 日韩欧美激情在线| 一本久久a久久精品亚洲| 免费在线观看精品| 亚洲欧美视频在线观看| 精品国产百合女同互慰| 在线视频国产一区| 丁香网亚洲国际| 青青国产91久久久久久| 亚洲人成网站精品片在线观看| 日韩一级视频免费观看在线| 色综合中文综合网| 亚洲国产婷婷综合在线精品| 久久久久久久久久美女| 欧美日韩国产免费一区二区 | 99麻豆久久久国产精品免费| 麻豆成人91精品二区三区| 一区二区三区成人在线视频| 国产日韩欧美一区二区三区乱码| 91精品国产色综合久久不卡蜜臀| 99re热视频这里只精品| 国产99久久久精品| 蜜臀av一级做a爰片久久| 亚洲国产精品一区二区久久恐怖片 | 精品日韩在线观看| 欧美无乱码久久久免费午夜一区 | 国内一区二区在线| 一区二区三区在线影院| 欧美变态凌虐bdsm| 欧美一区二区成人| 99麻豆久久久国产精品免费| 免费高清视频精品| 亚洲精品视频免费观看| 久久一区二区三区四区| 欧美一区二区播放| 色域天天综合网| 岛国精品一区二区| 日韩黄色一级片| 婷婷综合在线观看| 日韩毛片精品高清免费| 久久理论电影网| 91精品蜜臀在线一区尤物| 972aa.com艺术欧美| 国产成人精品三级| 蜜桃视频在线观看一区| 亚洲成av人片一区二区三区| 亚洲日本在线天堂| 欧美一级日韩不卡播放免费| 91精品免费在线| 欧美老年两性高潮| 欧美亚洲一区二区在线观看| 99国产精品国产精品久久| 国产精品99久久久久久久vr| 美国十次综合导航| 日韩精品电影在线观看| 亚洲高清不卡在线| 18成人在线视频| 亚洲自拍都市欧美小说| 亚洲精品美腿丝袜| 日韩一区在线看| 中文字幕一区二区三区视频| 亚洲国产成人一区二区三区| 久久久噜噜噜久噜久久综合| 26uuu精品一区二区三区四区在线| 91精品国产日韩91久久久久久| 色婷婷精品大视频在线蜜桃视频 | 色噜噜夜夜夜综合网| a美女胸又www黄视频久久| 国产不卡免费视频| 福利91精品一区二区三区| 大胆欧美人体老妇| 成人av综合在线| a亚洲天堂av| 91国产视频在线观看| 日韩西西人体444www| 日韩免费成人网| 久久青草欧美一区二区三区| 国产日韩欧美精品综合| 亚洲天堂av老司机| 夜夜嗨av一区二区三区中文字幕 | 日韩欧美中文字幕一区| 亚洲乱码国产乱码精品精可以看| 中文字幕视频一区| 亚洲一区自拍偷拍| 日韩国产在线观看一区| 免费看日韩精品| gogo大胆日本视频一区| 91黄视频在线观看| 91精品免费观看| 久久人人超碰精品| 一区二区三区在线免费观看| 亚洲3atv精品一区二区三区| 精品一区二区三区免费观看| 国产福利一区二区三区视频在线 | 色综合久久久久网| 日韩一区二区三区三四区视频在线观看| 在线播放中文字幕一区| 日韩欧美在线综合网| 国产精品三级av在线播放| 一二三四社区欧美黄| 精品一区二区综合| 99v久久综合狠狠综合久久| 精品视频一区三区九区| 久久嫩草精品久久久精品| 亚洲乱码国产乱码精品精的特点 | 亚洲国产成人一区二区三区| 亚洲va欧美va人人爽| 国产福利一区二区三区在线视频| 在线观看欧美黄色| 久久这里只有精品6| 亚洲免费观看高清完整版在线观看熊 | 风间由美中文字幕在线看视频国产欧美 | 久久婷婷国产综合精品青草| 亚洲男人都懂的| 国产一区 二区| 欧美日韩精品专区| 亚洲四区在线观看| 久久97超碰色| 欧美亚洲综合在线| 中文字幕中文在线不卡住| 日韩电影在线一区| 91浏览器在线视频| 亚洲精品一区二区三区福利| 亚洲综合色成人| 国产精品夜夜嗨| 精品国产欧美一区二区| 亚洲一区二区欧美激情| 成人高清免费观看| 亚洲精品在线三区| 午夜天堂影视香蕉久久| 成人av网址在线| 26uuu亚洲综合色欧美| ...av二区三区久久精品| 成人黄色小视频| 国产偷v国产偷v亚洲高清| 日日摸夜夜添夜夜添国产精品| 91免费精品国自产拍在线不卡| 久久色成人在线| 免费观看久久久4p| 91.com在线观看| 亚洲成人三级小说| 岛国av在线一区| 国产欧美日韩在线| 国产伦精品一区二区三区免费| 欧美日韩大陆在线| 亚洲成年人网站在线观看| 在线观看中文字幕不卡| 亚洲视频小说图片| 色播五月激情综合网| 亚洲区小说区图片区qvod| 99免费精品在线观看| 日本一区二区成人| 激情图片小说一区| 一区在线观看视频| www.在线成人| 1000部国产精品成人观看| aaa亚洲精品| 一区二区三区自拍| 日本久久电影网| 青娱乐精品视频在线| 日韩美女主播在线视频一区二区三区 | 精品国产乱码久久久久久老虎 |