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

📄 string.c

📁 linux下用PCMCIA无线网卡虚拟无线AP的程序源码
💻 C
📖 第 1 页 / 共 3 页
字号:
/* Tester for string functions.   Copyright (C) 1995, 1996, 1997, 1998, 1999 Free Software Foundation, Inc.   This file is part of the GNU C Library.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Library General Public License as   published by the Free Software Foundation; either version 2 of the   License, or (at your option) any later version.   The GNU C Library 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   Library General Public License for more details.   You should have received a copy of the GNU Library General Public   License along with the GNU C Library; see the file COPYING.LIB.  If not,   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,   Boston, MA 02111-1307, USA.  *//* Make sure we don't test the optimized inline functions if we want to   test the real implementation.  */#undef __USE_STRING_INLINES#include <errno.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <strings.h>#include <fcntl.h>#ifndef HAVE_GNU_LD#define _sys_nerr	sys_nerr#define _sys_errlist	sys_errlist#endif#define	STREQ(a, b)	(strcmp((a), (b)) == 0)const char *it = "<UNSET>";	/* Routine name for message routines. */size_t errors = 0;/* Complain if condition is not true.  */voidcheck (int thing, int number){  if (!thing)    {      printf("%s flunked test %d\n", it, number);      ++errors;    }}/* Complain if first two args don't strcmp as equal.  */voidequal (const char *a, const char *b, int number){  check(a != NULL && b != NULL && (strcmp(a, b)==0), number);}char one[50];char two[50];char *cp;voidtest_strcmp (void){  it = "strcmp";  check (strcmp ("", "") == 0, 1);		/* Trivial case. */  check (strcmp ("a", "a") == 0, 2);		/* Identity. */  check (strcmp ("abc", "abc") == 0, 3);	/* Multicharacter. */  check (strcmp ("abc", "abcd") < 0, 4);	/* Length mismatches. */  check (strcmp ("abcd", "abc") > 0, 5);  check (strcmp ("abcd", "abce") < 0, 6);	/* Honest miscompares. */  check (strcmp ("abce", "abcd") > 0, 7);  check (strcmp ("a\203", "a") > 0, 8);		/* Tricky if char signed. */  check (strcmp ("a\203", "a\003") > 0, 9);  {    char buf1[0x40], buf2[0x40];    int i, j;    for (i=0; i < 0x10; i++)      for (j = 0; j < 0x10; j++)	{	  int k;	  for (k = 0; k < 0x3f; k++)	    {	      buf1[j] = '0' ^ (k & 4);	      buf2[j] = '4' ^ (k & 4);	    }	  buf1[i] = buf1[0x3f] = 0;	  buf2[j] = buf2[0x3f] = 0;	  for (k = 0; k < 0xf; k++)	    {	      int cnum = 0x10+0x10*k+0x100*j+0x1000*i;	      check (strcmp (buf1+i,buf2+j) == 0, cnum);	      buf1[i+k] = 'A' + i + k;	      buf1[i+k+1] = 0;	      check (strcmp (buf1+i,buf2+j) > 0, cnum+1);	      check (strcmp (buf2+j,buf1+i) < 0, cnum+2);	      buf2[j+k] = 'B' + i + k;	      buf2[j+k+1] = 0;	      check (strcmp (buf1+i,buf2+j) < 0, cnum+3);	      check (strcmp (buf2+j,buf1+i) > 0, cnum+4);	      buf2[j+k] = 'A' + i + k;	      buf1[i] = 'A' + i + 0x80;	      check (strcmp (buf1+i,buf2+j) > 0, cnum+5);	      check (strcmp (buf2+j,buf1+i) < 0, cnum+6);	      buf1[i] = 'A' + i;	    }	}  }}voidtest_strcpy (void){  int i;  it = "strcpy";  check (strcpy (one, "abcd") == one, 1); /* Returned value. */  equal (one, "abcd", 2);		/* Basic test. */  (void) strcpy (one, "x");  equal (one, "x", 3);			/* Writeover. */  equal (one+2, "cd", 4);		/* Wrote too much? */  (void) strcpy (two, "hi there");  (void) strcpy (one, two);  equal (one, "hi there", 5);		/* Basic test encore. */  equal (two, "hi there", 6);		/* Stomped on source? */  (void) strcpy (one, "");  equal (one, "", 7);			/* Boundary condition. */  for (i = 0; i < 16; i++)    {      (void) strcpy (one + i, "hi there");	/* Unaligned destination. */      equal (one + i, "hi there", 8 + (i * 2));      (void) strcpy (two, one + i);		/* Unaligned source. */      equal (two, "hi there", 9 + (i * 2));    }}voidtest_stpcpy (void){  int i;  it = "stpcpy";  check (stpcpy (one, "abcd") == one+4, 1); /* Returned value. */  equal (one, "abcd", 2);		/* Basic test. */  (void) stpcpy (one, "x");  equal (one, "x", 3);			/* Writeover. */  equal (one+2, "cd", 4);		/* Wrote too much? */  (void) stpcpy (two, "hi there");  (void) stpcpy (one, two);  equal (one, "hi there", 5);		/* Basic test encore. */  equal (two, "hi there", 6);		/* Stomped on source? */  (void) stpcpy (one, "");  equal (one, "", 7);			/* Boundary condition. */  for (i = 0; i < 16; i++)    {      (void) stpcpy (one + i, "hi there");	/* Unaligned destination. */      equal (one + i, "hi there", 8 + (i * 2));      (void) stpcpy (two, one + i);		/* Unaligned source. */      equal (two, "hi there", 9 + (i * 2));    }}voidtest_strcat (void){  it = "strcat";  (void) strcpy (one, "ijk");  check (strcat (one, "lmn") == one, 1); /* Returned value. */  equal (one, "ijklmn", 2);		/* Basic test. */  (void) strcpy (one, "x");  (void) strcat (one, "yz");  equal (one, "xyz", 3);			/* Writeover. */  equal (one+4, "mn", 4);			/* Wrote too much? */  (void) strcpy (one, "gh");  (void) strcpy (two, "ef");  (void) strcat (one, two);  equal (one, "ghef", 5);			/* Basic test encore. */  equal (two, "ef", 6);			/* Stomped on source? */  (void) strcpy (one, "");  (void) strcat (one, "");  equal (one, "", 7);			/* Boundary conditions. */  (void) strcpy (one, "ab");  (void) strcat (one, "");  equal (one, "ab", 8);  (void) strcpy (one, "");  (void) strcat (one, "cd");  equal (one, "cd", 9);}voidtest_strncat (void){  /* First test it as strcat, with big counts, then test the count     mechanism.  */  it = "strncat";  (void) strcpy (one, "ijk");  check (strncat (one, "lmn", 99) == one, 1);	/* Returned value. */  equal (one, "ijklmn", 2);		/* Basic test. */  (void) strcpy (one, "x");  (void) strncat (one, "yz", 99);  equal (one, "xyz", 3);		/* Writeover. */  equal (one+4, "mn", 4);		/* Wrote too much? */  (void) strcpy (one, "gh");  (void) strcpy (two, "ef");  (void) strncat (one, two, 99);  equal (one, "ghef", 5);			/* Basic test encore. */  equal (two, "ef", 6);			/* Stomped on source? */  (void) strcpy (one, "");  (void) strncat (one, "", 99);  equal (one, "", 7);			/* Boundary conditions. */  (void) strcpy (one, "ab");  (void) strncat (one, "", 99);  equal (one, "ab", 8);  (void) strcpy (one, "");  (void) strncat (one, "cd", 99);  equal (one, "cd", 9);  (void) strcpy (one, "ab");  (void) strncat (one, "cdef", 2);  equal (one, "abcd", 10);			/* Count-limited. */  (void) strncat (one, "gh", 0);  equal (one, "abcd", 11);			/* Zero count. */  (void) strncat (one, "gh", 2);  equal (one, "abcdgh", 12);		/* Count and length equal. */}voidtest_strncmp (void){  /* First test as strcmp with big counts, then test count code.  */  it = "strncmp";  check (strncmp ("", "", 99) == 0, 1);	/* Trivial case. */  check (strncmp ("a", "a", 99) == 0, 2);	/* Identity. */  check (strncmp ("abc", "abc", 99) == 0, 3);	/* Multicharacter. */  check (strncmp ("abc", "abcd", 99) < 0, 4);	/* Length unequal. */  check (strncmp ("abcd", "abc", 99) > 0, 5);  check (strncmp ("abcd", "abce", 99) < 0, 6);	/* Honestly unequal. */  check (strncmp ("abce", "abcd", 99) > 0, 7);  check (strncmp ("a\203", "a", 2) > 0, 8);	/* Tricky if '\203' < 0 */  check (strncmp ("a\203", "a\003", 2) > 0, 9);  check (strncmp ("abce", "abcd", 3) == 0, 10);	/* Count limited. */  check (strncmp ("abce", "abc", 3) == 0, 11);	/* Count == length. */  check (strncmp ("abcd", "abce", 4) < 0, 12);	/* Nudging limit. */  check (strncmp ("abc", "def", 0) == 0, 13);	/* Zero count. */}voidtest_strncpy (void){  /* Testing is a bit different because of odd semantics.  */  it = "strncpy";  check (strncpy (one, "abc", 4) == one, 1);	/* Returned value. */  equal (one, "abc", 2);			/* Did the copy go right? */  (void) strcpy (one, "abcdefgh");  (void) strncpy (one, "xyz", 2);  equal (one, "xycdefgh", 3);			/* Copy cut by count. */  (void) strcpy (one, "abcdefgh");  (void) strncpy (one, "xyz", 3);		/* Copy cut just before NUL. */  equal (one, "xyzdefgh", 4);  (void) strcpy (one, "abcdefgh");  (void) strncpy (one, "xyz", 4);		/* Copy just includes NUL. */  equal (one, "xyz", 5);  equal (one+4, "efgh", 6);			/* Wrote too much? */  (void) strcpy (one, "abcdefgh");  (void) strncpy (one, "xyz", 5);		/* Copy includes padding. */  equal (one, "xyz", 7);  equal (one+4, "", 8);  equal (one+5, "fgh", 9);  (void) strcpy (one, "abc");  (void) strncpy (one, "xyz", 0);		/* Zero-length copy. */  equal (one, "abc", 10);  (void) strncpy (one, "", 2);		/* Zero-length source. */  equal (one, "", 11);  equal (one+1, "", 12);  equal (one+2, "c", 13);  (void) strcpy (one, "hi there");  (void) strncpy (two, one, 9);  equal (two, "hi there", 14);		/* Just paranoia. */  equal (one, "hi there", 15);		/* Stomped on source? */}voidtest_strlen (void){  it = "strlen";  check (strlen ("") == 0, 1);		/* Empty. */  check (strlen ("a") == 1, 2);		/* Single char. */  check (strlen ("abcd") == 4, 3);	/* Multiple chars. */  {    char buf[4096];    int i;    char *p;    for (i=0; i < 0x100; i++)      {	p = (char *) ((unsigned long int)(buf + 0xff) & ~0xff) + i;	strcpy (p, "OK");	strcpy (p+3, "BAD/WRONG");	check (strlen (p) == 2, 4+i);      }   }}voidtest_strchr (void){  it = "strchr";  check (strchr ("abcd", 'z') == NULL, 1);	/* Not found. */  (void) strcpy (one, "abcd");  check (strchr (one, 'c') == one+2, 2);	/* Basic test. */  check (strchr (one, 'd') == one+3, 3);	/* End of string. */  check (strchr (one, 'a') == one, 4);		/* Beginning. */  check (strchr (one, '\0') == one+4, 5);	/* Finding NUL. */  (void) strcpy (one, "ababa");  check (strchr (one, 'b') == one+1, 6);	/* Finding first. */  (void) strcpy (one, "");  check (strchr (one, 'b') == NULL, 7);		/* Empty string. */  check (strchr (one, '\0') == one, 8);		/* NUL in empty string. */  {    char buf[4096];    int i;    char *p;    for (i=0; i < 0x100; i++)      {	p = (char *) ((unsigned long int) (buf + 0xff) & ~0xff) + i;	strcpy (p, "OK");	strcpy (p+3, "BAD/WRONG");	check (strchr (p, '/') == NULL, 9+i);      }   }}void

⌨️ 快捷键说明

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