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

📄 sprintf1.c

📁 eCos1.31版
💻 C
📖 第 1 页 / 共 2 页
字号:
//=================================================================////        sprintf1.c////        Testcase for C library sprintf()////=================================================================//####COPYRIGHTBEGIN####//                                                                          // -------------------------------------------                              // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (the "License"); you may not use this file except in         // compliance with the License.  You may obtain a copy of the License at    // http://www.redhat.com/                                                   //                                                                          // Software distributed under the License is distributed on an "AS IS"      // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See the // License for the specific language governing rights and limitations under // the License.                                                             //                                                                          // The Original Code is eCos - Embedded Configurable Operating System,      // released September 30, 1998.                                             //                                                                          // The Initial Developer of the Original Code is Red Hat.                   // Portions created by Red Hat are                                          // Copyright (C) 1998, 1999, 2000 Red Hat, Inc.                             // All Rights Reserved.                                                     // -------------------------------------------                              //                                                                          //####COPYRIGHTEND####//=================================================================//#####DESCRIPTIONBEGIN####//// Author(s):     ctarpy, jlarmour// Contributors:    jlarmour// Date:          1998/6/3// Description:   Contains testcode for C library sprintf() function//////####DESCRIPTIONEND####// Declarations for test system://// TESTCASE_TYPE=CYG_TEST_MODULE// CONFIGURATION#include <pkgconf/libc.h>   // Configuration header// INCLUDES#include <stdio.h>#include <cyg/infra/testcase.h>#include <sys/cstartup.h>          // C library initialisation// HOW TO START TESTS#if defined(CYGPKG_LIBC) && defined(CYGPKG_LIBC_STDIO)# define START_TEST( test ) test(0)#else# define START_TEST( test ) CYG_EMPTY_STATEMENT#endif        // FUNCTIONSexternC voidcyg_package_start( void ){#ifdef CYGPKG_LIBC    cyg_iso_c_start();#else    (void)main(0, NULL);#endif} // cyg_package_start()#if defined(CYGPKG_LIBC) && defined(CYGPKG_LIBC_STDIO)// Functions to avoid having to use libc stringsstatic int my_strlen(const char *s){    const char *ptr;    ptr = s;    for ( ptr=s ; *ptr != '\0' ; ptr++ )        ;    return (int)(ptr-s);} // my_strlen()static int my_strcmp(const char *s1, const char *s2){    for ( ; *s1 == *s2 ; s1++,s2++ )    {        if ( *s1 == '\0' )            break;    } // for    return (*s1 - *s2);} // my_strcmp()static char *my_strcpy(char *s1, const char *s2){    while (*s2 != '\0') {        *(s1++) = *(s2++);    }    *s1 = '\0';    return s1; } // my_strcpy()static void test(CYG_ADDRWORD data){    static char x[500];    static char y[500];    int ret;    int tmp;    int *ptr;    // Check 1    ret = sprintf(x, "%d", 20);    CYG_TEST_PASS_FAIL(my_strcmp(x, "20")==0, "%d test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%d test return code");    // Check 2    my_strcpy(y, "Pigs noses. Get 'em while there 'ot");    ret = sprintf(x, "%s", y);    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "%s test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%s test return code");    // Check 3    ret = sprintf(x, "||%7d||", 2378);    CYG_TEST_PASS_FAIL(my_strcmp(x, "||   2378||")==0, "padding test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "padding test return code");    // Check 4    ret = sprintf(x, "%x", 3573);    CYG_TEST_PASS_FAIL(my_strcmp(x, "df5")==0, "hex conversion (lowercase)");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "hex conv (lowercase) return code");    // Check 5    ret = sprintf(x, "%X", 3573);    CYG_TEST_PASS_FAIL(my_strcmp(x, "DF5")==0, "hex conversion (uppercase)");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "hex conv (upperbase ) return code");    // Check 6    ret = sprintf(x, "%c", 65);    CYG_TEST_PASS_FAIL(my_strcmp(x, "A")==0, "%c test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%c test return code");    // Check 7    ret = sprintf(x, "%o",4628);    CYG_TEST_PASS_FAIL(my_strcmp(x, "11024")==0, "octal conversion");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "octal conversion return code");    // Check 8    ret = sprintf(x, "%u", (unsigned int) 4738);    CYG_TEST_PASS_FAIL(my_strcmp(x, "4738")==0, "%u test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%u test return code");    // Check 9    ptr = &tmp;    ret = sprintf(x, "1234567x%n||", ptr);    CYG_TEST_PASS_FAIL(tmp==8, "%n test");    CYG_TEST_PASS_FAIL(ret==10, "%n test return code");    // Check 10    ret = sprintf(x, "%%");    CYG_TEST_PASS_FAIL(my_strcmp(x, "%")==0, "%% test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%% test return code");    // Check 11    ret = sprintf(x, "%ld", (long)1<<30);    CYG_TEST_PASS_FAIL(my_strcmp(x, "1073741824")==0, "%ld test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%ld test return code");    // Check 12    ret = sprintf(x, "%lu", (unsigned long)(1<<31) + 100);    CYG_TEST_PASS_FAIL(my_strcmp(x, "2147483748")==0, "%lu test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%lu test return code");    // Check 13    ret = sprintf(x, "%x", 0x789a);    CYG_TEST_PASS_FAIL(my_strcmp(x, "789a")==0, "%x test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%x test return code");    // Check 14    ret = sprintf(x, "%X", 0x789ab2);    CYG_TEST_PASS_FAIL(my_strcmp(x, "789AB2")==0, "%X test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%x test return code");    // Check 15    ret = sprintf(x, "%08x", 0xdea2f2);    CYG_TEST_PASS_FAIL(my_strcmp(x, "00dea2f2")==0, "%0x test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%0x test return code");    // Check 16    ret = sprintf(x, "%09X", 0x12fa1c);    CYG_TEST_PASS_FAIL(my_strcmp(x, "00012FA1C")==0, "%0X test");    CYG_TEST_PASS_FAIL(ret==my_strlen(x), "%0X test return code");    // Check 17    ptr=&tmp;    ret = sprintf(x, "%p", (void *)ptr);    // just check _something_ was returned    CYG_TEST_PASS_FAIL((ret==my_strlen(x)) && (ret > 0),                       "%p test return code");#ifdef CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT    CYG_TEST_INFO("Starting floating point specific tests");    // Check 18    ret = sprintf(x, "%f", 2.5);    my_strcpy( y, "2.500000" );    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "simple %f test #1");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "simple %f test #1 return code");    // Check 19    ret = sprintf(x, "hello %f world", 1.234);    my_strcpy( y, "hello 1.234000 world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "simple %f test #2");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "simple %f test #2 return code");    // Check 20    ret = sprintf(x, "hello%fworld", 2.3456781);    my_strcpy( y, "hello2.345678world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "simple %f test #3");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "simple %f test #3 return code");    // Check 21    ret = sprintf(x, "%s%f%d%s", "testing", -0.591, 3, "123");    my_strcpy( y, "testing-0.5910003123");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "%f mixed with others");    CYG_TEST_PASS_FAIL(ret == my_strlen(y),"%f mixed with others return code");    // Check 22    ret = sprintf(x, "%s%f%d%s", "testing", -0.591, 3, "123");    my_strcpy( y, "testing-0.5910003123");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "%f mixed with others");    CYG_TEST_PASS_FAIL(ret == my_strlen(y),"%f mixed with others return code");    // Check 23    ret = sprintf(x, "hello%fworld", 2.3456786);    my_strcpy( y, "hello2.345679world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "rounding test #1");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "rounding test #1 return code");    // Check 24    ret = sprintf(x, "hello%fworld", -2.3456786);    my_strcpy( y, "hello-2.345679world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "rounding test #2");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "rounding test #2 return code");    // Check 25    ret = sprintf(x, "hello%+fworld", -6.54321);    my_strcpy( y, "hello-6.543210world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "+ modifier #1");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "+ modifier #1 return code");    // Check 26    ret = sprintf(x, "hello%+fworld", 6.54321);    my_strcpy( y, "hello+6.543210world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "+ modifier #2");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "+ modifier #2 return code");    // Check 27    ret = sprintf(x, "hello%5fworld", 6.5);    my_strcpy( y, "hello6.500000world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "width modifier #1");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "width modifier #1 return code");    // Check 28    ret = sprintf(x, "hello%2fworld", 4.3);    my_strcpy( y, "hello4.300000world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "width modifier #2");    CYG_TEST_PASS_FAIL(ret == my_strlen(y), "width modifier #2 return code");    // Check 29    ret = sprintf(x, "hello%2.1fworld", 5.6);    my_strcpy( y, "hello5.6world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "width and precision modifier #1");    CYG_TEST_PASS_FAIL(ret == my_strlen(y),                       "width and precision modifier #1 return code");    // Check 30    ret = sprintf(x, "hello%5.1fworld", 6.7);    my_strcpy( y, "hello  6.7world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "width and precision modifier #2");    CYG_TEST_PASS_FAIL(ret == my_strlen(y),                       "width and precision modifier #2 return code");    // Check 31    ret = sprintf(x, "hello%3.1fworld", 7.8);    my_strcpy( y, "hello7.8world");    CYG_TEST_PASS_FAIL(my_strcmp(x, y)==0, "width and precision modifier #3");    CYG_TEST_PASS_FAIL(ret == my_strlen(y),

⌨️ 快捷键说明

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