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

📄 genget.c

📁 Linux下的socks的程序源程序,用于socks的代理服务
💻 C
字号:
/*- * Copyright (c) 1991 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted provided * that: (1) source distributions retain this entire copyright notice and * comment, and (2) distributions including binaries display the following * acknowledgement:  ``This product includes software developed by the * University of California, Berkeley and its contributors'' in the * documentation or other materials provided with the distribution and in * all advertising materials mentioning features or use of this software. * Neither the name of the University nor the names of its contributors may * be used to endorse or promote products derived from this software without * specific prior written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */#ifndef lintstatic char sccsid[] = "@(#)genget.c	5.1 (Berkeley) 2/28/91";#endif /* not lint */#include <ctype.h>#define	LOWER(x) (isupper(x) ? tolower(x) : (x))/* * The prefix function returns 0 if *s1 is not a prefix * of *s2.  If *s1 exactly matches *s2, the negative of * the length is returned.  If *s1 is a prefix of *s2, * the length of *s1 is returned. */	intisprefix(s1, s2)	register char *s1, *s2;{        register int n = 0;        char *os1;	register char c1, c2;        if (*s1 == '\0')                return(-1);        os1 = s1;	c1 = *s1;	c2 = *s2;        while (LOWER(c1) == LOWER(c2)) {		if (c1 == '\0')			break;                c1 = *++s1;                c2 = *++s2;        }        return(*s1 ? 0 : (*s2 ? (s1 - os1) : (os1 - s1)));}static char *ambiguous;		/* special return value for command routines */	char **genget(name, table, stlen)	char	*name;		/* name to match */	char	**table;	/* name entry in table */	int	stlen;{	register char **c, **found;	register int n;	if (name == 0)	    return 0;	found = 0;	for (c = table; *c != 0; c = (char **)((char *)c + stlen)) {		if ((n = isprefix(name, *c)) == 0)			continue;		if (n < 0)		/* exact match */			return(c);		if (found)			return(&ambiguous);		found = c;	}	return(found);}/* * Function call version of Ambiguous() */	intAmbiguous(s)	char *s;{	return((char **)s == &ambiguous);}

⌨️ 快捷键说明

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