Subversion Repositories HelenOS

Rev

Rev 4055 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 4055 Rev 4201
Line 27... Line 27...
27
 */
27
 */
28
 
28
 
29
#include <print.h>
29
#include <print.h>
30
#include <test.h>
30
#include <test.h>
31
 
31
 
32
#define BUFFER_SIZE 32
-
 
33
 
-
 
34
char * test_print1(bool quiet)
32
char *test_print1(bool quiet)
35
{
33
{
36
    if (!quiet) {
34
    if (!quiet) {
37
        int retval;
-
 
38
        unative_t nat = 0x12345678u;
-
 
39
       
-
 
40
        char buffer[BUFFER_SIZE];
-
 
41
       
-
 
42
        printf(" text 10.8s %*.*s \n", 5, 3, "text");
35
        printf("Testing printf(\"%%*.*s\", 5, 3, \"text\"):\n");
43
        printf(" very long text 10.8s %10.8s \n", "very long text");
-
 
44
        printf(" text 8.10s %8.10s \n", "text");
36
        printf("Expected output: \"  tex\"\n");
45
        printf(" very long text 8.10s %8.10s \n", "very long text");
37
        printf("Real output:     \"%*.*s\"\n\n", 5, 3, "text");
46
       
38
       
47
        printf(" char: c '%c', 3.2c '%3.2c', -3.2c '%-3.2c', 2.3c '%2.3c', -2.3c '%-2.3c' \n", 'a', 'b', 'c', 'd', 'e');
-
 
48
        printf(" int: d '%d', 3.2d '%3.2d', -3.2d '%-3.2d', 2.3d '%2.3d', -2.3d '%-2.3d' \n", 1, 1, 1, 1, 1);
39
        printf("Testing printf(\"%%10.8s\", \"very long text\"):\n");
49
        printf(" -int: d '%d', 3.2d '%3.2d', -3.2d '%-3.2d', 2.3d '%2.3d', -2.3d '%-2.3d' \n", -1, -1, -1, -1, -1);
40
        printf("Expected output: \"  very lon\"\n");
50
        printf(" 0xint: x '%#x', 5.3x '%#5.3x', -5.3x '%#-5.3x', 3.5x '%#3.5x', -3.5x '%#-3.5x' \n", 17, 17, 17, 17, 17);
-
 
51
       
-
 
52
        printf("'%#llx' 64bit, '%#x' 32bit, '%#hhx' 8bit, '%#hx' 16bit, unative_t '%#" PRIxn "'. '%#llx' 64bit and '%s' string.\n", 0x1234567887654321ll, 0x12345678, 0x12, 0x1234, nat, 0x1234567887654321ull, "Lovely string" );
-
 
53
       
-
 
54
        printf(" Print to NULL '%s'\n", NULL);
41
        printf("Real output:     \"%10.8s\"\n\n", "very long text");
55
       
42
       
56
        retval = snprintf(buffer, BUFFER_SIZE, "Short text without parameters.");
43
        printf("Testing printf(\"%%8.10s\", \"text\"):\n");
57
        printf("Result is: '%s', retval = %d\n", buffer, retval);
44
        printf("Expected output: \"text\"\n");
58
       
-
 
59
        retval = snprintf(buffer, BUFFER_SIZE, "Very very very long text without parameters.");
-
 
60
        printf("Result is: '%s', retval = %d\n", buffer, retval);
45
        printf("Real output:     \"%8.10s\"\n\n", "text");
61
       
46
       
62
        printf("Print short text to %d char long buffer via snprintf.\n", BUFFER_SIZE);
47
        printf("Testing printf(\"%%8.10s\", \"very long text\"):\n");
63
        retval = snprintf(buffer, BUFFER_SIZE, "Short %s", "text");
48
        printf("Expected output: \"very long \"\n");
64
        printf("Result is: '%s', retval = %d\n", buffer, retval);
49
        printf("Real output:     \"%8.10s\"\n\n", "very long text");
65
       
50
       
66
        printf("Print long text to %d char long buffer via snprintf.\n", BUFFER_SIZE);
51
        printf("Testing printf(\"%%s\", NULL):\n");
67
        retval = snprintf(buffer, BUFFER_SIZE, "Very long %s. This text`s length is more than %d. We are interested in the result.", "text" , BUFFER_SIZE);
52
        printf("Expected output: \"(NULL)\"\n");
68
        printf("Result is: '%s', retval = %d\n", buffer, retval);
53
        printf("Real output:     \"%s\"\n\n", NULL);
69
    }
54
    }
70
   
55
   
71
    return NULL;
56
    return NULL;
72
}
57
}