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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? inet_net_pton.c

?? package of develop dns
?? C
字號:
/* * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") * Copyright (c) 1996,1999 by Internet Software Consortium. * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */#if defined(LIBC_SCCS) && !defined(lint)static const char rcsid[] = "$Id: inet_net_pton.c,v 1.4.2.1.8.2 2004/03/17 00:29:47 marka Exp $";#endif#include "port_before.h"#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <arpa/nameser.h>#include <arpa/inet.h>#include <isc/assertions.h>#include <ctype.h>#include <errno.h>#include <stdio.h>#include <string.h>#include <stdlib.h>#include "port_after.h"#ifdef SPRINTF_CHAR# define SPRINTF(x) strlen(sprintf/**/x)#else# define SPRINTF(x) ((size_t)sprintf x)#endif/* * static int * inet_net_pton_ipv4(src, dst, size) *	convert IPv4 network number from presentation to network format. *	accepts hex octets, hex strings, decimal octets, and /CIDR. *	"size" is in bytes and describes "dst". * return: *	number of bits, either imputed classfully or specified with /CIDR, *	or -1 if some failure occurred (check errno).  ENOENT means it was *	not an IPv4 network specification. * note: *	network byte order assumed.  this means 192.5.5.240/28 has *	0b11110000 in its fourth octet. * author: *	Paul Vixie (ISC), June 1996 */static intinet_net_pton_ipv4(const char *src, u_char *dst, size_t size) {	static const char xdigits[] = "0123456789abcdef";	static const char digits[] = "0123456789";	int n, ch, tmp = 0, dirty, bits;	const u_char *odst = dst;	ch = *src++;	if (ch == '0' && (src[0] == 'x' || src[0] == 'X')	    && isascii((unsigned char)(src[1]))	    && isxdigit((unsigned char)(src[1]))) {		/* Hexadecimal: Eat nybble string. */		if (size <= 0U)			goto emsgsize;		dirty = 0;		src++;	/* skip x or X. */		while ((ch = *src++) != '\0' && isascii(ch) && isxdigit(ch)) {			if (isupper(ch))				ch = tolower(ch);			n = strchr(xdigits, ch) - xdigits;			INSIST(n >= 0 && n <= 15);			if (dirty == 0)				tmp = n;			else				tmp = (tmp << 4) | n;			if (++dirty == 2) {				if (size-- <= 0U)					goto emsgsize;				*dst++ = (u_char) tmp;				dirty = 0;			}		}		if (dirty) {  /* Odd trailing nybble? */			if (size-- <= 0U)				goto emsgsize;			*dst++ = (u_char) (tmp << 4);		}	} else if (isascii(ch) && isdigit(ch)) {		/* Decimal: eat dotted digit string. */		for (;;) {			tmp = 0;			do {				n = strchr(digits, ch) - digits;				INSIST(n >= 0 && n <= 9);				tmp *= 10;				tmp += n;				if (tmp > 255)					goto enoent;			} while ((ch = *src++) != '\0' &&				 isascii(ch) && isdigit(ch));			if (size-- <= 0U)				goto emsgsize;			*dst++ = (u_char) tmp;			if (ch == '\0' || ch == '/')				break;			if (ch != '.')				goto enoent;			ch = *src++;			if (!isascii(ch) || !isdigit(ch))				goto enoent;		}	} else		goto enoent;	bits = -1;	if (ch == '/' && isascii((unsigned char)(src[0])) &&	    isdigit((unsigned char)(src[0])) && dst > odst) {		/* CIDR width specifier.  Nothing can follow it. */		ch = *src++;	/* Skip over the /. */		bits = 0;		do {			n = strchr(digits, ch) - digits;			INSIST(n >= 0 && n <= 9);			bits *= 10;			bits += n;		} while ((ch = *src++) != '\0' && isascii(ch) && isdigit(ch));		if (ch != '\0')			goto enoent;		if (bits > 32)			goto emsgsize;	}	/* Firey death and destruction unless we prefetched EOS. */	if (ch != '\0')		goto enoent;	/* If nothing was written to the destination, we found no address. */	if (dst == odst)		goto enoent;	/* If no CIDR spec was given, infer width from net class. */	if (bits == -1) {		if (*odst >= 240)	/* Class E */			bits = 32;		else if (*odst >= 224)	/* Class D */			bits = 8;		else if (*odst >= 192)	/* Class C */			bits = 24;		else if (*odst >= 128)	/* Class B */			bits = 16;		else			/* Class A */			bits = 8;		/* If imputed mask is narrower than specified octets, widen. */		if (bits < ((dst - odst) * 8))			bits = (dst - odst) * 8;		/*		 * If there are no additional bits specified for a class D		 * address adjust bits to 4.		 */		if (bits == 8 && *odst == 224)			bits = 4;	}	/* Extend network to cover the actual mask. */	while (bits > ((dst - odst) * 8)) {		if (size-- <= 0U)			goto emsgsize;		*dst++ = '\0';	}	return (bits); enoent:	errno = ENOENT;	return (-1); emsgsize:	errno = EMSGSIZE;	return (-1);}static intgetbits(const char *src, int *bitsp) {	static const char digits[] = "0123456789";	int n;	int val;	char ch;	val = 0;	n = 0;	while ((ch = *src++) != '\0') {		const char *pch;		pch = strchr(digits, ch);		if (pch != NULL) {			if (n++ != 0 && val == 0)	/* no leading zeros */				return (0);			val *= 10;			val += (pch - digits);			if (val > 128)			/* range */				return (0);			continue;		}		return (0);	}	if (n == 0)		return (0);	*bitsp = val;	return (1);}static intgetv4(const char *src, u_char *dst, int *bitsp) {	static const char digits[] = "0123456789";	u_char *odst = dst;	int n;	u_int val;	char ch;	val = 0;	n = 0;	while ((ch = *src++) != '\0') {		const char *pch;		pch = strchr(digits, ch);		if (pch != NULL) {			if (n++ != 0 && val == 0)	/* no leading zeros */				return (0);			val *= 10;			val += (pch - digits);			if (val > 255)			/* range */				return (0);			continue;		}		if (ch == '.' || ch == '/') {			if (dst - odst > 3)		/* too many octets? */				return (0);			*dst++ = val;			if (ch == '/')				return (getbits(src, bitsp));			val = 0;			n = 0;			continue;		}		return (0);	}	if (n == 0)		return (0);	if (dst - odst > 3)		/* too many octets? */		return (0);	*dst++ = val;	return (1);}static intinet_net_pton_ipv6(const char *src, u_char *dst, size_t size) {	static const char xdigits_l[] = "0123456789abcdef",			  xdigits_u[] = "0123456789ABCDEF";	u_char tmp[NS_IN6ADDRSZ], *tp, *endp, *colonp;	const char *xdigits, *curtok;	int ch, saw_xdigit;	u_int val;	int digits;	int bits;	size_t bytes;	int words;	int ipv4;	memset((tp = tmp), '\0', NS_IN6ADDRSZ);	endp = tp + NS_IN6ADDRSZ;	colonp = NULL;	/* Leading :: requires some special handling. */	if (*src == ':')		if (*++src != ':')			goto enoent;	curtok = src;	saw_xdigit = 0;	val = 0;	digits = 0;	bits = -1;	ipv4 = 0;	while ((ch = *src++) != '\0') {		const char *pch;		if ((pch = strchr((xdigits = xdigits_l), ch)) == NULL)			pch = strchr((xdigits = xdigits_u), ch);		if (pch != NULL) {			val <<= 4;			val |= (pch - xdigits);			if (++digits > 4)				goto enoent;			saw_xdigit = 1;			continue;		}		if (ch == ':') {			curtok = src;			if (!saw_xdigit) {				if (colonp)					goto enoent;				colonp = tp;				continue;			} else if (*src == '\0')				goto enoent;			if (tp + NS_INT16SZ > endp)				return (0);			*tp++ = (u_char) (val >> 8) & 0xff;			*tp++ = (u_char) val & 0xff;			saw_xdigit = 0;			digits = 0;			val = 0;			continue;		}		if (ch == '.' && ((tp + NS_INADDRSZ) <= endp) &&		     getv4(curtok, tp, &bits) > 0) {			tp += NS_INADDRSZ;			saw_xdigit = 0;			ipv4 = 1;			break;	/* '\0' was seen by inet_pton4(). */		}		if (ch == '/' && getbits(src, &bits) > 0)			break;		goto enoent;	}	if (saw_xdigit) {		if (tp + NS_INT16SZ > endp)			goto enoent;		*tp++ = (u_char) (val >> 8) & 0xff;		*tp++ = (u_char) val & 0xff;	}	if (bits == -1)		bits = 128;	words = (bits + 15) / 16;	if (words < 2)		words = 2;	if (ipv4)		words = 8;	endp =  tmp + 2 * words;	if (colonp != NULL) {		/*		 * Since some memmove()'s erroneously fail to handle		 * overlapping regions, we'll do the shift by hand.		 */		const int n = tp - colonp;		int i;		if (tp == endp)			goto enoent;		for (i = 1; i <= n; i++) {			endp[- i] = colonp[n - i];			colonp[n - i] = 0;		}		tp = endp;	}	if (tp != endp)		goto enoent;	bytes = (bits + 7) / 8;	if (bytes > size)		goto emsgsize;	memcpy(dst, tmp, bytes);	return (bits); enoent:	errno = ENOENT;	return (-1); emsgsize:	errno = EMSGSIZE;	return (-1);}/* * int * inet_net_pton(af, src, dst, size) *	convert network number from presentation to network format. *	accepts hex octets, hex strings, decimal octets, and /CIDR. *	"size" is in bytes and describes "dst". * return: *	number of bits, either imputed classfully or specified with /CIDR, *	or -1 if some failure occurred (check errno).  ENOENT means it was *	not a valid network specification. * author: *	Paul Vixie (ISC), June 1996 */intinet_net_pton(int af, const char *src, void *dst, size_t size) {	switch (af) {	case AF_INET:		return (inet_net_pton_ipv4(src, dst, size));	case AF_INET6:		return (inet_net_pton_ipv6(src, dst, size));	default:		errno = EAFNOSUPPORT;		return (-1);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久综合| 99热在这里有精品免费| 91精品午夜视频| 天堂久久久久va久久久久| 在线观看av一区二区| 亚洲高清一区二区三区| 欧美日韩一级二级| 秋霞电影一区二区| 欧美不卡激情三级在线观看| 国产精品一区二区久久不卡 | 一本到不卡精品视频在线观看| 中文av一区特黄| 99久久伊人久久99| 亚洲国产综合91精品麻豆| 欧美精品亚洲一区二区在线播放| 天天免费综合色| 久久综合av免费| 99久久99久久精品免费观看| 亚洲成人三级小说| 日韩欧美不卡在线观看视频| 国产超碰在线一区| 亚洲小少妇裸体bbw| 欧美va亚洲va香蕉在线| 国产高清在线精品| 亚洲美女精品一区| 日韩一级片网站| 国产成人在线色| 亚洲国产精品视频| 2020国产精品| 91色视频在线| 精品制服美女久久| 亚洲免费毛片网站| 日韩女优av电影| 一本久久精品一区二区| 麻豆成人免费电影| 自拍偷自拍亚洲精品播放| 欧美一区二区三级| av影院午夜一区| 免费高清在线一区| 亚洲免费电影在线| 久久在线观看免费| 欧美日韩激情一区| 成人开心网精品视频| 日本成人超碰在线观看| 亚洲欧美在线观看| 精品国产91久久久久久久妲己| 99久久婷婷国产综合精品电影| 日韩av电影免费观看高清完整版 | 精品中文av资源站在线观看| 亚洲欧美激情插 | wwwwww.欧美系列| 欧洲在线/亚洲| www.激情成人| 国产一区二区不卡| 日本va欧美va瓶| 亚洲精品国久久99热| 国产午夜精品在线观看| 欧美妇女性影城| 色哟哟亚洲精品| 成人影视亚洲图片在线| 精品在线免费视频| 午夜精品一区二区三区电影天堂 | 日韩一级精品视频在线观看| 91久久精品午夜一区二区| 国产aⅴ精品一区二区三区色成熟| 天天综合网天天综合色| 亚洲自拍偷拍麻豆| 亚洲婷婷综合久久一本伊一区| www亚洲一区| 欧美成人精品1314www| 欧美日韩国产精品成人| 欧美网站一区二区| 在线观看一区不卡| 色狠狠色狠狠综合| av电影在线不卡| 99久久免费视频.com| 粉嫩在线一区二区三区视频| 国产精品自拍在线| 国产一区二区三区久久悠悠色av| 久久99国产精品尤物| 美女免费视频一区| 久久精品理论片| 老司机午夜精品99久久| 久久精品国产99国产精品| 蜜臀国产一区二区三区在线播放| 日韩国产在线观看一区| 午夜精品久久久久久不卡8050 | 亚洲国产va精品久久久不卡综合| 亚洲少妇中出一区| 亚洲乱码国产乱码精品精的特点 | 亚洲欧美日韩一区二区| 亚洲精品水蜜桃| 亚洲永久免费av| 天天色综合成人网| 麻豆精品一区二区三区| 精品一区二区成人精品| 国产精品资源网| 成人免费看视频| 色婷婷av久久久久久久| 欧美日韩久久久一区| 欧美一区二区成人| 亚洲精品在线免费播放| 欧美国产精品一区二区三区| 国产精品国产自产拍高清av | 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 亚洲天堂中文字幕| 亚洲国产精品久久人人爱蜜臀| 婷婷国产v国产偷v亚洲高清| 精品亚洲porn| 99久久精品情趣| 欧美色图一区二区三区| 日韩美女视频一区二区在线观看| 国产嫩草影院久久久久| 亚洲激情自拍偷拍| 奇米888四色在线精品| 国产精品99久久不卡二区| 色老汉一区二区三区| 日韩一区二区三区视频| 亚洲国产精华液网站w| 亚洲一区二区三区三| 国内精品久久久久影院一蜜桃| 成人免费观看av| 欧美麻豆精品久久久久久| 久久久激情视频| 亚洲国产欧美一区二区三区丁香婷| 美女性感视频久久| 91蝌蚪porny| 精品国产免费人成电影在线观看四季| 国产精品入口麻豆原神| 日韩黄色在线观看| eeuss鲁片一区二区三区在线看| 欧美日本一区二区三区| 中文字幕第一页久久| 免费不卡在线视频| 色狠狠色噜噜噜综合网| 国产日韩欧美精品在线| 亚洲va韩国va欧美va精品| 成人妖精视频yjsp地址| 91精品久久久久久蜜臀| 综合久久久久久| 国产激情偷乱视频一区二区三区| 欧美少妇xxx| 亚洲视频香蕉人妖| 国产福利不卡视频| 日韩午夜在线观看| 亚洲高清免费观看| 一本久久精品一区二区| 国产人成一区二区三区影院| 日本欧美加勒比视频| 日本久久电影网| 中文字幕一区二区在线播放| 久久精工是国产品牌吗| 欧美日韩三级一区| 一区二区三区在线看| 成人一区二区三区在线观看| 欧美成人性战久久| 日韩电影在线观看网站| 欧美亚洲国产一区在线观看网站| 国产精品美女久久久久久久久久久| 久久99热这里只有精品| 欧美一二三在线| 日韩激情视频在线观看| 欧美绝品在线观看成人午夜影视| 亚洲精品免费在线观看| 91碰在线视频| 中文字幕日韩av资源站| 成av人片一区二区| 亚洲国产精品黑人久久久| 国产成人亚洲综合a∨婷婷图片 | 色综合久久中文综合久久牛| 国产精品全国免费观看高清 | 99综合电影在线视频| 欧美激情中文不卡| 国产suv一区二区三区88区| 国产欧美日产一区| 成人午夜电影久久影院| 中文字幕欧美国产| 波多野结衣中文一区| 国产精品久久毛片a| www.欧美精品一二区| 亚洲欧洲综合另类| 日本精品一区二区三区高清| 亚洲国产综合色| 69堂精品视频| 久久国产夜色精品鲁鲁99| 精品噜噜噜噜久久久久久久久试看| 美女在线视频一区| 国产亚洲欧美一级| 高清在线观看日韩| 亚洲欧美一区二区不卡| 欧美伊人久久久久久久久影院| 一区二区欧美精品| 日韩三级视频在线看| 国产一区二区三区四| 日韩一区在线播放| 欧美日韩中文精品| 久久66热re国产| 国产精品国产成人国产三级| 91论坛在线播放| 久久精品二区亚洲w码|