* Makefile.am (check-DEJAGNU): New target.
(site.exp): Likewise. * acinclude.m4 (NEWLIB_CONFIGURE): Replace AC_CANONICAL_HOST with AC_CANONICAL_SYSTEM. Remove AC_CANONICAL_BUILD. * libc/locale/locale.c (_setlocale_r): Add UTF-8 support. * libc/stdlib/mbtowc_r.c (_mbtowc_r): Likewise. * libc/stdlib/wctomb_r.c (_wctomb_r): Likewise. * testsuite: New directory. * testsuite/config: Likewise. * testsuite/lib: Likewise. * testsuite/newlib.locale: Likewise. * testsuite/newlib.string: Likewise. * testsuite/config/default.exp: New file. * testsuite/lib/checkoutput.exp: New file. * testsuite/lib/newlib.exp: New file. * testsuite/lib/passfail.exp: New file. * testsuite/newlib.locale/UTF-8.c: New file. * testsuite/newlib.locale/UTF-8.exp: New file. * testsuite/newlib.locale/locale.exp: New file. * testsuite/newlib.string/string.exp: New file. * testsuite/newlib.string/tstring.c: New file.
This commit is contained in:
		
							
								
								
									
										7
									
								
								newlib/testsuite/config/default.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								newlib/testsuite/config/default.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| load_lib standard.exp | ||||
							
								
								
									
										40
									
								
								newlib/testsuite/lib/checkoutput.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								newlib/testsuite/lib/checkoutput.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| # newlib_check_output takes the basename of the test source file, and | ||||
| # a list of pairs of the form "testname" "expectedoutput" | ||||
| # "testname" "expectedoutput"...  It assumes one line of output | ||||
| # per test. | ||||
|  | ||||
| proc newlib_check_output { srcfile expectlist } { | ||||
|     global objdir subdir srcdir | ||||
|  | ||||
|     set srcfullname "$srcdir/$subdir/$srcfile" | ||||
|     set test_driver "$objdir/testsuite/[file tail [file rootname $srcfullname].x]" | ||||
|  | ||||
|     set comp_output [newlib_target_compile "$srcfullname" "$test_driver" "executable" ""] | ||||
|  | ||||
|     if { $comp_output != "" } { | ||||
| 	fail "Failed to compile $srcfile.\n" | ||||
|     } else { | ||||
| 	pass "Compiled $srcfile.\n" | ||||
|     } | ||||
|  | ||||
|     set result [newlib_load $test_driver ""] | ||||
|     set status [lindex $result 0] | ||||
|     set output [lindex $result 1] | ||||
|  | ||||
|     set output_lines [split $output "\n"] | ||||
|  | ||||
|     foreach { testname expectedval } $expectlist { | ||||
| 	if [string match "$expectedval" "[lindex $output_lines 0]"] then { | ||||
| 	    pass $testname | ||||
| 	} else { | ||||
| 	    fail $testname | ||||
| 	} | ||||
| 	set output_lines [lrange $output_lines 1 end] | ||||
|     } | ||||
| } | ||||
							
								
								
									
										110
									
								
								newlib/testsuite/lib/newlib.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								newlib/testsuite/lib/newlib.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| proc newlib_version { } { | ||||
|     global tool_version | ||||
|  | ||||
|     verbose "In newlib version...\n" | ||||
|  | ||||
|     return $tool_version | ||||
| } | ||||
|  | ||||
| set newlib_initialized 0 | ||||
|  | ||||
| proc newlib_init { args } { | ||||
|     global gluefile wrap_flags | ||||
|     global newlib_initialized | ||||
|     global target_info | ||||
|     global CFLAGS_FOR_TARGET | ||||
|     # These values are initialized in the local site.exp file | ||||
|     global srcdir objdir | ||||
|     global build_triplet host_triplet | ||||
|     # newlib_cflags comes from acinclude.m4, through the site.exp file | ||||
|     global newlib_cflags | ||||
|     global old_ld_library_path | ||||
|  | ||||
|     verbose "In newlib_init...\n" | ||||
|  | ||||
|     if { $newlib_initialized == 1 } { return; } | ||||
|  | ||||
|     set CFLAGS_FOR_TARGET $newlib_cflags | ||||
|  | ||||
|     set_currtarget_info "wrap_compile_flags" "$newlib_cflags" | ||||
|  | ||||
|     if {[target_info needs_status_wrapper] != "" && \ | ||||
| 	    [target_info needs_status_wrapper] != "0" && \ | ||||
| 	    ![info exists gluefile]} { | ||||
| 	set gluefile ${objdir}/testglue.o; | ||||
| 	set result [build_wrapper $gluefile]; | ||||
| 	if { $result != "" } { | ||||
| 	    set gluefile [lindex $result 0]; | ||||
| 	    set wrap_flags [lindex $result 1]; | ||||
| 	} else { | ||||
| 	    unset gluefile | ||||
| 	} | ||||
|     } | ||||
|  | ||||
|     if [string match $build_triplet $host_triplet] then { | ||||
| 	if [string match "i686-pc-linux-gnu" $build_triplet] then { | ||||
| 	    set old_ld_library_path [getenv LD_LIBRARY_PATH] | ||||
| 	    setenv LD_LIBRARY_PATH "$objdir/.libs" | ||||
| 	} | ||||
|     } | ||||
| } | ||||
|  | ||||
| proc newlib_target_compile { source dest type options } { | ||||
|     global gluefile wrap_flags | ||||
|     global srcdir objdir | ||||
|     global build_triplet | ||||
|     global host_triplet | ||||
|  | ||||
|     verbose "In newlib_target_compile...\n" | ||||
| 	 | ||||
|     if {[target_info needs_status_wrapper] != "" && \ | ||||
| 	    [target_info needs_status_wrapper] != "0" && \ | ||||
| 	    [info exists gluefile] } { | ||||
| 	lappend options "libs=$gluefile" | ||||
| 	# This method of finding libgloss_target_dir may not work for some targets | ||||
| 	set libgloss_target_dir [lindex [split $host_triplet "-"] 0] | ||||
| 	lappend options "ldflags=$wrap_flags -B$objdir/../libgloss/$libgloss_target_dir \ | ||||
|                                              -L$objdir/../libgloss/$libgloss_target_dir \ | ||||
|                                              -L$srcdir/../../libgloss/$libgloss_target_dir \ | ||||
|                                              -L$objdir" | ||||
|     } | ||||
|  | ||||
|     if [string match $build_triplet $host_triplet] then { | ||||
| 	if [string match "i686-pc-linux-gnu" $build_triplet] then { | ||||
| 	    lappend options "libs=$objdir/crt0.o -lc" | ||||
| 	    lappend options "ldflags=-nostdlib -L$objdir/.libs -lgcc" | ||||
| 	} | ||||
|     } | ||||
|  | ||||
|     return [target_compile $source $dest $type $options] | ||||
| } | ||||
|  | ||||
| proc newlib_finish { } { | ||||
|     global old_ld_library_path | ||||
|     global build_triplet host_triplet | ||||
|  | ||||
|     verbose "In newlib_finish...\n" | ||||
|  | ||||
|     if [string match $build_triplet $host_triplet] then { | ||||
| 	if [string match "i686-pc-linux-gnu" $build_triplet] then { | ||||
| 	    setenv LD_LIBRARY_PATH "$old_ld_library_path" | ||||
| 	} | ||||
|     } | ||||
| } | ||||
|  | ||||
| proc newlib_exit { } { | ||||
|     global gluefile; | ||||
|      | ||||
|     verbose "In newlib_exit...\n" | ||||
|  | ||||
|     if [info exists gluefile] { | ||||
| 	file_on_build delete $gluefile; | ||||
| 	unset gluefile; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										39
									
								
								newlib/testsuite/lib/passfail.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								newlib/testsuite/lib/passfail.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| # newlib_pass_fail compiles and runs all the source files in the test | ||||
| # directory that are not included in the check_output_tests list. | ||||
| # check_output_tests lists the sources' basenames. | ||||
|  | ||||
| proc newlib_pass_fail { check_output_tests } { | ||||
|     global srcdir objdir subdir runtests | ||||
|  | ||||
|     foreach testcase [glob -nocomplain $srcdir/$subdir/*.c] { | ||||
| 	# If we're only testing specific files and this isn't one of them, skip it. | ||||
| 	if ![runtest_file_p $runtests $testcase] then { | ||||
| 	    continue | ||||
| 	} | ||||
|  | ||||
| 	# Exclude tests which require their output to be checked | ||||
| 	if {[lsearch $check_output_tests "[file tail $testcase]"] != -1} then { | ||||
| 	    continue | ||||
| 	} | ||||
|  | ||||
| 	set test_driver "$objdir/testsuite/[file tail [file rootname $testcase].x]" | ||||
|  | ||||
| 	set comp_output [newlib_target_compile "$testcase" "$test_driver" "executable" ""] | ||||
| 	 | ||||
| 	if { $comp_output != "" } { | ||||
| 	    fail "Failed to compile $testcase.\n" | ||||
| 	    fail "$testcase" | ||||
| 	} else { | ||||
| 	    pass "Compiled $testcase.\n" | ||||
| 	    set result [newlib_load $test_driver ""] | ||||
| 	    set status [lindex $result 0] | ||||
| 	    $status "$testcase" | ||||
| 	} | ||||
|     } | ||||
| } | ||||
							
								
								
									
										397
									
								
								newlib/testsuite/newlib.locale/UTF-8.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										397
									
								
								newlib/testsuite/newlib.locale/UTF-8.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,397 @@ | ||||
| /* | ||||
|  *  Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
|  * | ||||
|  *  Permission to use, copy, modify, and distribute this software | ||||
|  *  is freely granted, provided that this notice is preserved. | ||||
|  * | ||||
|  *  Tests gleaned from Markus Kuhn's UTF-8 and Unicode FAQ, | ||||
|  *  and specifically, his UTF-8-test.txt decoder stress test file. | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <locale.h> | ||||
|  | ||||
| #define MAX_BYTES 65 | ||||
|  | ||||
| int num_invalid(const char *s, int len); | ||||
|  | ||||
| char first[6][6] = { | ||||
|   {0x0},                                   /* U-00000000 */ | ||||
|   {0xc2, 0x80},                            /* U-00000080 */ | ||||
|   {0xe0, 0xa0, 0x80},                      /* U-00000800 */ | ||||
|   {0xf0, 0x90, 0x80, 0x80},                /* U-00010000 */ | ||||
|   {0xf8, 0x88, 0x80, 0x80, 0x80},          /* U-00200000 */ | ||||
|   {0xfc, 0x84, 0x80, 0x80, 0x80, 0x80}     /* U-04000000 */ | ||||
| }; | ||||
|  | ||||
| char last[6][6] = { | ||||
|   {0x7f},                                  /* U-0000007F */ | ||||
|   {0xdf, 0xbf},                            /* U-000007FF */ | ||||
|   {0xef, 0xbf, 0xbf},                      /* U-0000FFFF */ | ||||
|   {0xf7, 0xbf, 0xbf, 0xbf},                /* U-001FFFFF */ | ||||
|   {0xfb, 0xbf, 0xbf, 0xbf, 0xbf},          /* U-03FFFFFF */ | ||||
|   {0xfd, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf}     /* U-7FFFFFFF */ | ||||
| }; | ||||
|  | ||||
| char boundary[5][6] = { | ||||
|   {0xed, 0x9f, 0xbf},                      /* U-0000D7FF */ | ||||
|   {0xee, 0x80, 0x80},                      /* U-0000E000 */ | ||||
|   {0xef, 0xbf, 0xbd},                      /* U-0000FFFD */ | ||||
|   {0xf4, 0x8f, 0xbf, 0xbf},                /* U-0010FFFF */ | ||||
|   {0xf4, 0x90, 0x80, 0x80}                 /* U-00110000 */ | ||||
| }; | ||||
|  | ||||
| char continuation_bytes[8][7] = { | ||||
|   {0x80}, | ||||
|   {0xbf}, | ||||
|   {0x80, 0xbf}, | ||||
|   {0x80, 0xbf, 0x80}, | ||||
|   {0x80, 0xbf, 0x80, 0xbf}, | ||||
|   {0x80, 0xbf, 0x80, 0xbf, 0x80}, | ||||
|   {0x80, 0xbf, 0x80, 0xbf, 0x80, 0xbf}, | ||||
|   {0x80, 0xbf, 0x80, 0xbf, 0x80, 0xbf, 0x80} | ||||
| }; | ||||
|  | ||||
| char all_continuation_bytes[64]; | ||||
|  | ||||
|  | ||||
| char all_two_byte_seq[32]; | ||||
| char all_three_byte_seq[16]; | ||||
| char all_four_byte_seq[8]; | ||||
| char all_five_byte_seq[4]; | ||||
| char all_six_byte_seq[2]; | ||||
|  | ||||
| char incomplete_seq[10][6] = { | ||||
|   {0xc2},                            /* U-00000080 */ | ||||
|   {0xe0, 0x80},                      /* U-00000800 */ | ||||
|   {0xf0, 0x80, 0x80},                /* U-00010000 */ | ||||
|   {0xf8, 0x80, 0x80, 0x80},          /* U-00200000 */ | ||||
|   {0xfc, 0x80, 0x80, 0x80, 0x80},    /* U-04000000 */ | ||||
|   {0xdf},                            /* U-000007FF */ | ||||
|   {0xef, 0xbf},                      /* U-0000FFFF */ | ||||
|   {0xf7, 0xbf, 0xbf},                /* U-001FFFFF */ | ||||
|   {0xfb, 0xbf, 0xbf, 0xbf},          /* U-03FFFFFF */ | ||||
|   {0xfd, 0xbf, 0xbf, 0xbf, 0xbf}     /* U-7FFFFFFF */ | ||||
| }; | ||||
|  | ||||
| char incomplete_seq_concat[30]; | ||||
|  | ||||
| char impossible_bytes[3][4] = { | ||||
|   {0xfe}, | ||||
|   {0xff}, | ||||
|   {0xfe, 0xfe, 0xff, 0xff} | ||||
| }; | ||||
|  | ||||
| char overlong[5][6] = { | ||||
|   {0xc0, 0xaf}, | ||||
|   {0xe0, 0x80, 0xaf}, | ||||
|   {0xf0, 0x80, 0x80, 0xaf}, | ||||
|   {0xf8, 0x80, 0x80, 0x80, 0xaf}, | ||||
|   {0xfc, 0x80, 0x80, 0x80, 0x80, 0xaf} | ||||
| }; | ||||
|  | ||||
| char overlong_max[5][6] = { | ||||
|   {0xc1, 0xbf}, | ||||
|   {0xe0, 0x9f, 0xbf}, | ||||
|   {0xf0, 0x8f, 0xbf, 0xbf}, | ||||
|   {0xf8, 0x87, 0xbf, 0xbf, 0xbf}, | ||||
|   {0xfc, 0x83, 0xbf, 0xbf, 0xbf, 0xbf} | ||||
| }; | ||||
|  | ||||
| char overlong_nul[5][6] = { | ||||
|   {0xc0, 0x80}, | ||||
|   {0xe0, 0x80, 0x80}, | ||||
|   {0xf0, 0x80, 0x80, 0x80}, | ||||
|   {0xf8, 0x80, 0x80, 0x80, 0x80}, | ||||
|   {0xfc, 0x80, 0x80, 0x80, 0x80, 0x80} | ||||
| }; | ||||
|  | ||||
| char single_surrogates[7][3] = { | ||||
|   {0xed, 0xa0, 0x80}, | ||||
|   {0xed, 0xad, 0xbf}, | ||||
|   {0xed, 0xae, 0x80}, | ||||
|   {0xed, 0xaf, 0xbf}, | ||||
|   {0xed, 0xb0, 0x80}, | ||||
|   {0xed, 0xbe, 0x80}, | ||||
|   {0xed, 0xbf, 0xbf} | ||||
| }; | ||||
|  | ||||
| char paired_surrogates[8][6] = { | ||||
|   {0xed, 0xa0, 0x80, 0xed, 0xb0, 0x80}, | ||||
|   {0xed, 0xa0, 0x80, 0xed, 0xbf, 0xbf}, | ||||
|   {0xed, 0xad, 0xbf, 0xed, 0xb0, 0x80}, | ||||
|   {0xed, 0xad, 0xbf, 0xed, 0xbf, 0xbf}, | ||||
|   {0xed, 0xae, 0x80, 0xed, 0xb0, 0x80}, | ||||
|   {0xed, 0xae, 0x80, 0xed, 0xbf, 0xbf}, | ||||
|   {0xed, 0xaf, 0xbf, 0xed, 0xb0, 0x80}, | ||||
|   {0xed, 0xaf, 0xbf, 0xed, 0xbf, 0xbf} | ||||
| }; | ||||
|  | ||||
| char illegal_pos[2][3] = { | ||||
|   {0xff, 0xfe}, | ||||
|   {0xff, 0xff} | ||||
| }; | ||||
|    | ||||
| int main() | ||||
|   { | ||||
|     wchar_t wchar; | ||||
|     int retval; | ||||
|     int i; | ||||
|  | ||||
|     if (!setlocale(LC_CTYPE, "UTF-8")) | ||||
|       { | ||||
|         fprintf(stderr, "Failed to set UTF-8 locale.\n"); | ||||
|         return 1; | ||||
|       } | ||||
|     else | ||||
|       fprintf(stderr, "Set UTF-8 locale.\n"); | ||||
|  | ||||
|     /* 2  Boundary condition test cases */ | ||||
|     /* 2.1  First possible sequence of a certain length */ | ||||
|     retval = mbtowc(&wchar, first[0], MAX_BYTES); | ||||
|     if (retval == 0) | ||||
|       printf("2.1.1: U-%08d \n", wchar); | ||||
|     else | ||||
|       printf("2.1.1: Invalid \n"); | ||||
|  | ||||
|     for (i = 2; i < 7; i++) | ||||
|     { | ||||
|       retval = mbtowc (&wchar, first[i-1], MAX_BYTES); | ||||
|       if (retval == i) | ||||
|         printf("2.1.%d: U-%08x \n", i, wchar); | ||||
|       else | ||||
|         printf("2.1.%d: Invalid \n", i); | ||||
|     } | ||||
|  | ||||
|     /* 2.2  Last possible sequence of a certain length */ | ||||
|     for (i = 1; i < 7; i++) | ||||
|     { | ||||
|       retval = mbtowc (&wchar, last[i-1], MAX_BYTES); | ||||
|       if (retval == i) | ||||
|         printf("2.2.%d: U-%08x \n", i, wchar); | ||||
|       else | ||||
|         printf("2.2.%d: Invalid \n", i); | ||||
|     } | ||||
|  | ||||
|     /* 2.3  Other boundary conditions */ | ||||
|     for (i = 1; i < 6; i++) | ||||
|       { | ||||
|         retval = mbtowc (&wchar, boundary[i-1], MAX_BYTES); | ||||
|         if ((i < 4 && retval == 3) || (i > 3 && retval == 4)) | ||||
|           printf("2.3.%d: U-%08x \n", i, wchar); | ||||
|         else | ||||
|           printf("2.3.%d: Invalid \n", i); | ||||
|       } | ||||
|  | ||||
|     /* 3  Malformed sequences */ | ||||
|     /* 3.1  Unexpected continuation bytes */ | ||||
|     retval = mbtowc (&wchar, continuation_bytes[0], MAX_BYTES); | ||||
|     if (retval == 1) | ||||
|       printf("3.1.1: U-%08x \n", wchar); | ||||
|     else | ||||
|       printf("3.1.1: 1 Invalid \n"); | ||||
|  | ||||
|     retval = mbtowc (&wchar, continuation_bytes[1], MAX_BYTES); | ||||
|     if (retval == 1) | ||||
|       printf("3.1.2: U-%08x \n", wchar); | ||||
|     else | ||||
|       printf("3.1.2: 1 Invalid \n"); | ||||
|  | ||||
|     for(i=2; i< 8; i++) | ||||
|       { | ||||
|         retval = num_invalid(continuation_bytes[i], i); | ||||
|         if (retval == -1) | ||||
|           printf("3.1.%d: Valid Character Found\n", i+1); | ||||
|         else | ||||
|           printf("3.1.%d: %d Invalid \n", i+1, retval); | ||||
|       } | ||||
|  | ||||
|     for(i = 0x80; i < 0xc0; i++) | ||||
|       all_continuation_bytes[i-0x80] = i; | ||||
|  | ||||
|     retval = num_invalid(all_continuation_bytes, 0xc0 - 0x80); | ||||
|     if (retval == -1) | ||||
|       printf("3.1.9: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.1.9: %d Invalid \n", retval); | ||||
|  | ||||
|     /* 3.2  Lonely start characters */ | ||||
|     for(i = 0xc0; i < 0xe0; i++) | ||||
|       all_two_byte_seq[i-0xc0] = i; | ||||
|  | ||||
|     retval = num_invalid(all_two_byte_seq, 0xe0 - 0xc0); | ||||
|     if (retval == -1) | ||||
|       printf("3.2.1: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.2.1: %d Invalid \n", retval); | ||||
|  | ||||
|     for(i = 0xe0; i < 0xf0; i++) | ||||
|       all_three_byte_seq[i-0xe0] = i; | ||||
|  | ||||
|     retval = num_invalid(all_three_byte_seq, 0xf0 - 0xe0); | ||||
|     if (retval == -1) | ||||
|       printf("3.2.2: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.2.2: %d Invalid \n", retval); | ||||
|      | ||||
|     for(i = 0xf0; i < 0xf8; i++) | ||||
|       all_four_byte_seq[i-0xf0] = i; | ||||
|  | ||||
|     retval = num_invalid(all_four_byte_seq, 0xf8 - 0xf0); | ||||
|     if (retval == -1) | ||||
|       printf("3.2.3: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.2.3: %d Invalid \n", retval); | ||||
|      | ||||
|     for(i = 0xf8; i < 0xfc; i++) | ||||
|       all_five_byte_seq[i-0xf8] = i; | ||||
|  | ||||
|     retval = num_invalid(all_five_byte_seq, 0xfc - 0xf8); | ||||
|     if (retval == -1) | ||||
|       printf("3.2.4: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.2.4: %d Invalid \n", retval); | ||||
|  | ||||
|     for(i = 0xfc; i < 0xfe; i++) | ||||
|       all_six_byte_seq[i-0xfc] = i; | ||||
|  | ||||
|     retval = num_invalid(all_six_byte_seq, 0xfe - 0xfc); | ||||
|     if (retval == -1) | ||||
|       printf("3.2.5: Valid Character Found\n"); | ||||
|     else | ||||
|       printf("3.2.5: %d Invalid \n", retval); | ||||
|  | ||||
|     /* 3.3  Sequences with last continuation byte missing */ | ||||
|     for(i = 1; i < 6; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, incomplete_seq[i-1], i); | ||||
|         if(retval == -1) | ||||
|           printf("3.3.%d: 1 Invalid \n", i); | ||||
|         else | ||||
|           printf("3.3.%d: Valid Character Found\n", i); | ||||
|       } | ||||
|  | ||||
|     for(i = 6; i < 11; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, incomplete_seq[i-1], i - 5); | ||||
|         if(retval == -1) | ||||
|           printf("3.3.%d: 1 Invalid \n", i); | ||||
|         else | ||||
|           printf("3.3.%d: Valid Character Found\n", i); | ||||
|       } | ||||
|  | ||||
|     /* 3.4  Concatenation of incomplete sequences */ | ||||
|     /* This test is excluded because the mbtowc function does not return the | ||||
|        number of bytes read in an invalid multi-byte sequence. */ | ||||
|  | ||||
|     /* 3.5  Impossible bytes */ | ||||
|     retval = mbtowc(&wchar, impossible_bytes[0], 1); | ||||
|     if(retval == -1) | ||||
|       printf("3.5.1: 1 Invalid \n"); | ||||
|     else | ||||
|       printf("3.5.1: Valid Character Found\n"); | ||||
|  | ||||
|     retval = mbtowc(&wchar, impossible_bytes[1], 1); | ||||
|     if(retval == -1) | ||||
|       printf("3.5.2: 1 Invalid \n"); | ||||
|     else | ||||
|       printf("3.5.2: Valid Character Found\n"); | ||||
|  | ||||
|     retval = mbtowc(&wchar, impossible_bytes[2], 4); | ||||
|     if(retval == -1) | ||||
|       printf("3.5.3: 1 Invalid \n"); | ||||
|     else | ||||
|       printf("3.5.3: Valid Character Found\n"); | ||||
|  | ||||
|     /* 4  Overlong sequences */ | ||||
|     /* 4.1  Examples of an overlong ASCII character */ | ||||
|     for(i = 2; i < 7; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, overlong[i-2], i); | ||||
|         if(retval == -1) | ||||
|           printf("4.1.%d: 1 Invalid \n", i-1); | ||||
|         else | ||||
|           printf("4.1.%d: Valid Character Found\n", i-1); | ||||
|       } | ||||
|  | ||||
|     /* 4.2  Maximum overlong sequences */ | ||||
|     for(i = 2; i < 7; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, overlong_max[i-2], i); | ||||
|         if(retval == -1) | ||||
|           printf("4.2.%d: 1 Invalid \n", i-1); | ||||
|         else | ||||
|           printf("4.2.%d: Valid Character Found\n", i-1); | ||||
|       } | ||||
|  | ||||
|     /* 4.3  Overlong representation of the NUL character */ | ||||
|     for(i = 2; i < 7; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, overlong_nul[i-2], i); | ||||
|         if(retval == -1) | ||||
|           printf("4.3.%d: 1 Invalid \n", i-1); | ||||
|         else | ||||
|           printf("4.3.%d: Valid Character Found\n", i-1); | ||||
|       } | ||||
|  | ||||
|     /* 5  Illegal code positions */ | ||||
|     /* 5.1 Single UTF-16 surrogates */ | ||||
|     for (i = 1; i < 8; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, single_surrogates[i-1], 3); | ||||
|         if(retval == -1) | ||||
|           printf("5.1.%d: 1 Invalid \n", i); | ||||
|         else | ||||
|           printf("5.1.%d: Valid Character Found\n", i); | ||||
|       } | ||||
|      | ||||
|     /* 5.2 Paired UTF-16 surrogates */ | ||||
|     for (i = 1; i < 8; i++) | ||||
|       { | ||||
|         retval = mbtowc(&wchar, paired_surrogates[i-1], 6); | ||||
|         if(retval == -1) | ||||
|           printf("5.2.%d: 1 Invalid \n", i); | ||||
|         else | ||||
|           printf("5.2.%d: Valid Character Found\n", i); | ||||
|       } | ||||
|  | ||||
|     /* 5.3 Other illegal code positions */ | ||||
|     retval = mbtowc(&wchar, illegal_pos[0], 3); | ||||
|     if(retval == -1) | ||||
|       printf("5.3.1: 1 Invalid \n"); | ||||
|     else | ||||
|       printf("5.3.1: Valid Character Found\n"); | ||||
|  | ||||
|     retval = mbtowc(&wchar, illegal_pos[1], 3); | ||||
|     if(retval == -1) | ||||
|       printf("5.3.2: 1 Invalid \n"); | ||||
|     else | ||||
|       printf("5.3.2: Valid Character Found\n"); | ||||
|      | ||||
|     return 0; | ||||
|   } | ||||
|  | ||||
| /* return number of invalid characters in string, | ||||
|    returns -1 if a valid character is found */ | ||||
| int | ||||
| num_invalid(const char *s, int len) | ||||
| { | ||||
|   int retval = 0; | ||||
|   int i = 0; | ||||
|   int num_inv = 0; | ||||
|   wchar_t wchar; | ||||
|   const char *t; | ||||
|  | ||||
|   t = s; | ||||
|  | ||||
|   for(i=0; i<len; t++, i++) | ||||
|     { | ||||
|       retval = mbtowc (&wchar, t, len - i); | ||||
|       if(retval == -1) | ||||
|         num_inv++; | ||||
|       else | ||||
|         return -1; | ||||
|     } | ||||
|   return num_inv; | ||||
| } | ||||
							
								
								
									
										88
									
								
								newlib/testsuite/newlib.locale/UTF-8.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								newlib/testsuite/newlib.locale/UTF-8.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| load_lib checkoutput.exp | ||||
|  | ||||
| set tests { | ||||
| "Setting UTF-8 locale" "*Set UTF-8 locale*" | ||||
| "2.1.1" "* U-00000000 *" | ||||
| "2.1.2" "* U-00000080 *" | ||||
| "2.1.3" "* U-00000800 *" | ||||
| "2.1.4" "* U-00010000 *" | ||||
| "2.1.5" "* U-00200000 *" | ||||
| "2.1.6" "* U-04000000 *" | ||||
| "2.2.1" "* U-0000007f *" | ||||
| "2.2.2" "* U-000007ff *" | ||||
| "2.2.3" "* U-0000ffff *" | ||||
| "2.2.4" "* U-001fffff *" | ||||
| "2.2.5" "* U-03ffffff *" | ||||
| "2.2.6" "* U-7fffffff *" | ||||
| "2.3.1" "* U-0000d7ff *" | ||||
| "2.3.2" "* U-0000e000 *" | ||||
| "2.3.3" "* U-0000fffd *" | ||||
| "2.3.4" "* U-0010ffff *" | ||||
| "2.3.5" "* U-00110000 *" | ||||
| "3.1.1" "* 1 Invalid *" | ||||
| "3.1.2" "* 1 Invalid *" | ||||
| "3.1.3" "* 2 Invalid *" | ||||
| "3.1.4" "* 3 Invalid *" | ||||
| "3.1.5" "* 4 Invalid *" | ||||
| "3.1.6" "* 5 Invalid *" | ||||
| "3.1.7" "* 6 Invalid *" | ||||
| "3.1.8" "* 7 Invalid *" | ||||
| "3.1.9" "* 64 Invalid *" | ||||
| "3.2.1" "* 32 Invalid *" | ||||
| "3.2.2" "* 16 Invalid *" | ||||
| "3.2.3" "* 8 Invalid *" | ||||
| "3.2.4" "* 4 Invalid *" | ||||
| "3.2.5" "* 2 Invalid *" | ||||
| "3.3.1" "* 1 Invalid *" | ||||
| "3.3.2" "* 1 Invalid *" | ||||
| "3.3.3" "* 1 Invalid *" | ||||
| "3.3.4" "* 1 Invalid *" | ||||
| "3.3.5" "* 1 Invalid *" | ||||
| "3.3.6" "* 1 Invalid *" | ||||
| "3.3.7" "* 1 Invalid *" | ||||
| "3.3.8" "* 1 Invalid *" | ||||
| "3.3.9" "* 1 Invalid *" | ||||
| "3.3.10" "* 1 Invalid *" | ||||
| "3.5.1" "* 1 Invalid *" | ||||
| "3.5.2" "* 1 Invalid *" | ||||
| "3.5.3" "* 1 Invalid *" | ||||
| "4.1.1" "* 1 Invalid *" | ||||
| "4.1.2" "* 1 Invalid *" | ||||
| "4.1.3" "* 1 Invalid *" | ||||
| "4.1.4" "* 1 Invalid *" | ||||
| "4.1.5" "* 1 Invalid *" | ||||
| "4.2.1" "* 1 Invalid *" | ||||
| "4.2.2" "* 1 Invalid *" | ||||
| "4.2.3" "* 1 Invalid *" | ||||
| "4.2.4" "* 1 Invalid *" | ||||
| "4.2.5" "* 1 Invalid *" | ||||
| "4.3.1" "* 1 Invalid *" | ||||
| "4.3.2" "* 1 Invalid *" | ||||
| "4.3.3" "* 1 Invalid *" | ||||
| "4.3.4" "* 1 Invalid *" | ||||
| "4.3.5" "* 1 Invalid *" | ||||
| "5.1.1" "* 1 Invalid *" | ||||
| "5.1.2" "* 1 Invalid *" | ||||
| "5.1.3" "* 1 Invalid *" | ||||
| "5.1.4" "* 1 Invalid *" | ||||
| "5.1.5" "* 1 Invalid *" | ||||
| "5.1.6" "* 1 Invalid *" | ||||
| "5.1.7" "* 1 Invalid *" | ||||
| "5.2.1" "* 1 Invalid *" | ||||
| "5.2.2" "* 1 Invalid *" | ||||
| "5.2.3" "* 1 Invalid *" | ||||
| "5.2.4" "* 1 Invalid *" | ||||
| "5.2.5" "* 1 Invalid *" | ||||
| "5.2.6" "* 1 Invalid *" | ||||
| "5.2.7" "* 1 Invalid *" | ||||
| "5.3.1" "* 1 Invalid *" | ||||
| "5.3.2" "* 1 Invalid *" | ||||
| } | ||||
|  | ||||
| newlib_check_output "UTF-8.c" "$tests" | ||||
							
								
								
									
										13
									
								
								newlib/testsuite/newlib.locale/locale.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								newlib/testsuite/newlib.locale/locale.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| load_lib passfail.exp | ||||
|  | ||||
| set nonpassfailtests { | ||||
| "UTF-8.c" | ||||
| } | ||||
|  | ||||
| newlib_pass_fail $nonpassfailtests | ||||
							
								
								
									
										12
									
								
								newlib/testsuite/newlib.string/string.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								newlib/testsuite/newlib.string/string.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| # Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
| # | ||||
| # Permission to use, copy, modify, and distribute this software | ||||
| # is freely granted, provided that this notice is preserved. | ||||
| # | ||||
|  | ||||
| load_lib passfail.exp | ||||
|  | ||||
| set nonpassfailtests { | ||||
| } | ||||
|  | ||||
| newlib_pass_fail $nonpassfailtests | ||||
							
								
								
									
										349
									
								
								newlib/testsuite/newlib.string/tstring.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										349
									
								
								newlib/testsuite/newlib.string/tstring.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,349 @@ | ||||
| /* | ||||
|  * Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software | ||||
|  * is freely granted, provided that this notice is preserved. | ||||
|  */ | ||||
|  | ||||
| #include <string.h> | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #ifndef MAX_1 | ||||
| #define MAX_1 66000 | ||||
| #endif | ||||
|  | ||||
| #define MAX_2 (2 * MAX_1 + MAX_1 / 10) | ||||
|  | ||||
| void eprintf (int line, char *result, char *expected, int size) | ||||
| { | ||||
|   if (size != 0) | ||||
|     printf ("Failure at line %d, result is <%.*s>, should be <%s> of size %d\n", | ||||
|              line, size, result, expected, size); | ||||
|   else | ||||
|     printf ("Failure at line %d, result is <%s>, should be <%s>\n", | ||||
|              line, result, expected); | ||||
| } | ||||
|  | ||||
| void mycopy (char *target, char *source, int size) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   for (i = 0; i < size; ++i) | ||||
|     { | ||||
|       target[i] = source[i]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| void myset (char *target, char ch, int size) | ||||
| { | ||||
|   int i; | ||||
|    | ||||
|   for (i = 0; i < size; ++i) | ||||
|     { | ||||
|       target[i] = ch; | ||||
|     } | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|   char target[MAX_1] = "A"; | ||||
|   char first_char; | ||||
|   char second_char; | ||||
|   char array[] = "abcdefghijklmnopqrstuvwxz"; | ||||
|   char array2[] = "0123456789!@#$%^&*("; | ||||
|   char buffer2[MAX_1]; | ||||
|   char buffer3[MAX_1]; | ||||
|   char buffer4[MAX_1]; | ||||
|   char buffer5[MAX_2]; | ||||
|   char buffer6[MAX_2]; | ||||
|   char buffer7[MAX_2]; | ||||
|   char expected[MAX_1]; | ||||
|   char *tmp1, *tmp2, *tmp3, *tmp4, *tmp5, *tmp6, *tmp7; | ||||
|   int i, j, k, x, z, align_test_iterations; | ||||
|  | ||||
|   int test_failed = 0; | ||||
|  | ||||
|   tmp1 = target; | ||||
|   tmp2 = buffer2; | ||||
|   tmp3 = buffer3; | ||||
|   tmp4 = buffer4; | ||||
|   tmp5 = buffer5; | ||||
|   tmp6 = buffer6; | ||||
|   tmp7 = buffer7; | ||||
|  | ||||
|   tmp2[0] = 'Z'; | ||||
|   tmp2[1] = '\0'; | ||||
|  | ||||
|   if (memset (target, 'X', 0) != target || | ||||
|       memcpy (target, "Y", 0) != target || | ||||
|       memmove (target, "K", 0) != target || | ||||
|       strncpy (tmp2, "4", 0) != tmp2 || | ||||
|       strncat (tmp2, "123", 0) != tmp2 || | ||||
|       strcat (target, "") != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "A", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strcmp (target, "A") || strlen(target) != 1 || memchr (target, 'A', 0) != NULL | ||||
|       || memcmp (target, "J", 0) || strncmp (target, "A", 1) || strncmp (target, "J", 0) || | ||||
|       tmp2[0] != 'Z' || tmp2[1] != '\0') | ||||
|     { | ||||
|       eprintf (__LINE__, target, "A", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   tmp2[2] = 'A'; | ||||
|   if (strcpy (target, "") != target || | ||||
|       strncpy (tmp2, "", 4) != tmp2 || | ||||
|       strcat (target, "") != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (target[0] != '\0' || strncmp (target, "", 1) || | ||||
|       memcmp (tmp2, "\0\0\0\0", 4)) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   tmp2[2] = 'A'; | ||||
|   if (strncat (tmp2, "1", 3) != tmp2 || | ||||
|       memcmp (tmp2, "1\0A", 3)) | ||||
|     { | ||||
|       eprintf (__LINE__, tmp2, "1\0A", 3); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strcpy (tmp3, target) != tmp3 || | ||||
|       strcat (tmp3, "X") != tmp3 || | ||||
|       strncpy (tmp2, "X", 2) != tmp2 || | ||||
|       memset (target, tmp2[0], 1) != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "X", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strcmp (target, "X") || strlen (target) != 1 || | ||||
|       memchr (target, 'X', 2) != target || | ||||
|       strchr (target, 'X') != target || | ||||
|       memchr (target, 'Y', 2) != NULL || | ||||
|       strchr (target, 'Y') != NULL || | ||||
|       strcmp (tmp3, target) || | ||||
|       strncmp (tmp3, target, 2) || | ||||
|       memcmp (target, "K", 0) || | ||||
|       strncmp (target, tmp3, 3)) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "X", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strcpy (tmp3, "Y") != tmp3 || | ||||
|       strcat (tmp3, "Y") != tmp3 || | ||||
|       memset (target, 'Y', 2) != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "Y", 0); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   target[2] = '\0'; | ||||
|   if (memcmp (target, "YY", 2) || strcmp (target, "YY") || | ||||
|       strlen (target) != 2 || memchr (target, 'Y', 2) != target || | ||||
|       strcmp (tmp3, target) || | ||||
|       strncmp (target, tmp3, 3) || | ||||
|       strncmp (target, tmp3, 4) || | ||||
|       strncmp (target, tmp3, 2) || | ||||
|       strchr (target, 'Y') != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "YY", 2); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   strcpy (target, "WW"); | ||||
|   if (memcmp (target, "WW", 2) || strcmp (target, "WW") || | ||||
|       strlen (target) != 2 || memchr (target, 'W', 2) != target || | ||||
|       strchr (target, 'W') != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "WW", 2); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strncpy (target, "XX", 16) != target || | ||||
|       memcmp (target, "XX\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 16)) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "XX\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 16); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   if (strcpy (tmp3, "ZZ") != tmp3 || | ||||
|       strcat (tmp3, "Z") != tmp3 || | ||||
|       memcpy (tmp4, "Z", 2) != tmp4 || | ||||
|       strcat (tmp4, "ZZ") != tmp4 || | ||||
|       memset (target, 'Z', 3) != target) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "ZZZ", 3); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   target[3] = '\0'; | ||||
|   tmp5[0] = '\0'; | ||||
|   strncat (tmp5, "123", 2); | ||||
|   if (memcmp (target, "ZZZ", 3) || strcmp (target, "ZZZ") || | ||||
|       strcmp (tmp3, target) || strcmp (tmp4, target) || | ||||
|       strncmp (target, "ZZZ", 4) || strncmp (target, "ZZY", 3) <= 0 || | ||||
|       strncmp ("ZZY", target, 4) >= 0 || | ||||
|       memcmp (tmp5, "12", 3) || | ||||
|       strlen (target) != 3) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "ZZZ", 3); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|  | ||||
|   target[2] = 'K'; | ||||
|   if (memcmp (target, "ZZZ", 2) || strcmp (target, "ZZZ") >= 0 || | ||||
|       memcmp (target, "ZZZ", 3) >= 0 || strlen (target) != 3 || | ||||
|       memchr (target, 'K', 3) != target + 2 || | ||||
|       strncmp (target, "ZZZ", 2) || strncmp (target, "ZZZ", 4) >= 0 || | ||||
|       strchr (target, 'K') != target + 2) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "ZZK", 3); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|    | ||||
|   strcpy (target, "AAA"); | ||||
|   if (memcmp (target, "AAA", 3) || strcmp (target, "AAA") || | ||||
|       strncmp (target, "AAA", 3) || | ||||
|       strlen (target) != 3) | ||||
|     { | ||||
|       eprintf (__LINE__, target, "AAA", 3); | ||||
|       test_failed = 1; | ||||
|     } | ||||
|    | ||||
|   j = 5; | ||||
|   while (j < MAX_1) | ||||
|     { | ||||
|       for (i = j-1; i <= j+1; ++i) | ||||
|         { | ||||
| 	  /* don't bother checking unaligned data in the larger | ||||
| 	     sizes since it will waste time without performing additional testing */ | ||||
| 	  if (i <= 16 * sizeof(long)) | ||||
| 	    { | ||||
| 	      align_test_iterations = 2*sizeof(long); | ||||
|               if (i <= 2 * sizeof(long) + 1) | ||||
|                 z = 2; | ||||
| 	      else | ||||
| 	        z = 2 * sizeof(long); | ||||
|             } | ||||
| 	  else | ||||
|             { | ||||
| 	      align_test_iterations = 1; | ||||
|             } | ||||
|  | ||||
| 	  for (x = 0; x < align_test_iterations; ++x) | ||||
| 	    { | ||||
| 	      tmp1 = target + x; | ||||
| 	      tmp2 = buffer2 + x; | ||||
| 	      tmp3 = buffer3 + x; | ||||
| 	      tmp4 = buffer4 + x; | ||||
| 	      tmp5 = buffer5 + x; | ||||
| 	      tmp6 = buffer6 + x; | ||||
|  | ||||
| 	      first_char = array[i % (sizeof(array) - 1)]; | ||||
| 	      second_char = array2[i % (sizeof(array2) - 1)]; | ||||
| 	      memset (tmp1, first_char, i); | ||||
| 	      mycopy (tmp2, tmp1, i); | ||||
| 	      myset (tmp2 + z, second_char, i - z - 1); | ||||
| 	      if (memcpy (tmp1 + z, tmp2 + z, i - z - 1) != tmp1 + z) | ||||
| 		{ | ||||
| 		  printf ("error at line %d\n", __LINE__); | ||||
| 		  test_failed = 1; | ||||
| 		} | ||||
|  | ||||
| 	      tmp1[i] = '\0'; | ||||
| 	      tmp2[i] = '\0'; | ||||
| 	      if (strcpy (expected, tmp2) != expected) | ||||
| 		{ | ||||
| 		  printf ("error at line %d\n", __LINE__); | ||||
| 		  test_failed = 1; | ||||
| 		} | ||||
| 	      tmp2[i-z] = first_char + 1; | ||||
| 	      if (memmove (tmp2 + z + 1, tmp2 + z, i - z - 1) != tmp2 + z + 1 || | ||||
| 		  memset (tmp3, first_char, i) != tmp3) | ||||
| 		{ | ||||
| 		  printf ("error at line %d\n", __LINE__); | ||||
| 		  test_failed = 1; | ||||
| 		} | ||||
|  | ||||
| 	      myset (tmp4, first_char, i); | ||||
| 	      tmp5[0] = '\0'; | ||||
| 	      if (strncpy (tmp5, tmp1, i+1) != tmp5 || | ||||
| 		  strcat (tmp5, tmp1) != tmp5) | ||||
| 		{ | ||||
| 		  printf ("error at line %d\n", __LINE__); | ||||
| 		  test_failed = 1; | ||||
| 		} | ||||
| 	      mycopy (tmp6, tmp1, i); | ||||
| 	      mycopy (tmp6 + i, tmp1, i + 1); | ||||
|  | ||||
| 	      tmp7[2*i+z] = second_char; | ||||
|               strcpy (tmp7, tmp1); | ||||
|           | ||||
| 	      strchr (tmp1, second_char); | ||||
|   | ||||
| 	      if (memcmp (tmp1, expected, i) || strcmp (tmp1, expected) || | ||||
| 		  strncmp (tmp1, expected, i) || | ||||
|                   strncmp (tmp1, expected, i+1) || | ||||
| 		  strcmp (tmp1, tmp2) >= 0 || memcmp (tmp1, tmp2, i) >= 0 || | ||||
| 		  strncmp (tmp1, tmp2, i+1) >= 0 || | ||||
| 		  strlen (tmp1) != i || memchr (tmp1, first_char, i) != tmp1 || | ||||
| 		  strchr (tmp1, first_char) != tmp1 || | ||||
| 		  memchr (tmp1, second_char, i) != tmp1 + z || | ||||
| 		  strchr (tmp1, second_char) != tmp1 + z || | ||||
| 		  strcmp (tmp5, tmp6) || | ||||
| 		  strncat (tmp7, tmp1, i+2) != tmp7 || | ||||
| 		  strcmp (tmp7, tmp6) || | ||||
| 		  tmp7[2*i+z] != second_char) | ||||
| 		{ | ||||
| 		  eprintf (__LINE__, tmp1, expected, 0); | ||||
| 		  printf ("x is %d\n",x); | ||||
| 		  printf ("i is %d\n", i); | ||||
| 		  printf ("tmp1 is <%p>\n", tmp1); | ||||
| 		  printf ("tmp5 is <%p> <%s>\n", tmp5, tmp5); | ||||
| 		  printf ("tmp6 is <%p> <%s>\n", tmp6, tmp6); | ||||
| 		  test_failed = 1; | ||||
| 		} | ||||
|  | ||||
| 	      for (k = 1; k <= align_test_iterations && k <= i; ++k) | ||||
| 		{ | ||||
| 		  if (memcmp (tmp3, tmp4, i - k + 1) != 0 || | ||||
| 		      strncmp (tmp3, tmp4, i - k + 1) != 0) | ||||
| 		    { | ||||
| 		      printf ("Failure at line %d, comparing %.*s with %.*s\n", | ||||
| 			      __LINE__, i, tmp3, i, tmp4); | ||||
| 		      test_failed = 1; | ||||
| 		    } | ||||
| 		  tmp4[i-k] = first_char + 1; | ||||
| 		  if (memcmp (tmp3, tmp4, i) >= 0 || | ||||
| 		      strncmp (tmp3, tmp4, i) >= 0 || | ||||
| 		      memcmp (tmp4, tmp3, i) <= 0 || | ||||
| 		      strncmp (tmp4, tmp3, i) <= 0) | ||||
| 		    { | ||||
| 		      printf ("Failure at line %d, comparing %.*s with %.*s\n", | ||||
| 			      __LINE__, i, tmp3, i, tmp4); | ||||
| 		      test_failed = 1; | ||||
| 		    } | ||||
| 		  tmp4[i-k] = first_char; | ||||
| 		} | ||||
| 	    }               | ||||
|         } | ||||
|       j = ((2 * j) >> 2) << 2; | ||||
|     } | ||||
|  | ||||
|   if (test_failed) | ||||
|     abort(); | ||||
|   else | ||||
|     exit(0); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user