| #include <mcheck.h> |
| #include <stdio.h> |
| |
| |
| #ifndef CHAR_T |
| # define CHAR_T char |
| # define W(o) o |
| # define OPEN_MEMSTREAM open_memstream |
| #endif |
| |
| #define S(s) S1 (s) |
| #define S1(s) #s |
| |
| |
| static void |
| mcheck_abort (enum mcheck_status ev) |
| { |
| printf ("mecheck failed with status %d\n", (int) ev); |
| exit (1); |
| } |
| |
| |
| static int |
| do_test (void) |
| { |
| mcheck_pedantic (mcheck_abort); |
| |
| CHAR_T *buf = (CHAR_T *) 1l; |
| size_t len = 12345; |
| FILE *fp = OPEN_MEMSTREAM (&buf, &len); |
| if (fp == NULL) |
| { |
| printf ("%s failed\n", S(OPEN_MEMSTREAM)); |
| return 1; |
| } |
| |
| for (int outer = 0; outer < 800; ++outer) |
| { |
| for (int inner = 0; inner < 100; ++inner) |
| if (fputc (W('a') + (outer * 100 + inner) % 26, fp) == EOF) |
| { |
| printf ("fputc at %d:%d failed\n", outer, inner); |
| return 1; |
| } |
| |
| if (fflush (fp) != 0) |
| { |
| puts ("fflush failed"); |
| return 1; |
| } |
| |
| if (len != (outer + 1) * 100) |
| { |
| printf ("string in round %d not %d bytest long\n", |
| outer + 1, (outer + 1) * 100); |
| return 1; |
| } |
| if (buf == (CHAR_T *) 1l) |
| { |
| printf ("round %d: buf not updated\n", outer + 1); |
| return 1; |
| } |
| for (int inner = 0; inner < (outer + 1) * 100; ++inner) |
| if (buf[inner] != W('a') + inner % 26) |
| { |
| printf ("round %d: buf[%d] != '%c'\n", outer + 1, inner, |
| (char) (W('a') + inner % 26)); |
| return 1; |
| } |
| } |
| |
| buf = (CHAR_T *) 1l; |
| len = 12345; |
| if (fclose (fp) != 0) |
| { |
| puts ("fclose failed"); |
| return 1; |
| } |
| |
| if (len != 800 * 100) |
| { |
| puts ("string after close not 80000 bytes long"); |
| return 1; |
| } |
| if (buf == (CHAR_T *) 1l) |
| { |
| puts ("buf not updated"); |
| return 1; |
| } |
| for (int inner = 0; inner < 800 * 100; ++inner) |
| if (buf[inner] != W('a') + inner % 26) |
| { |
| printf ("after close: buf[%d] != %c\n", inner, |
| (char) (W('a') + inner % 26)); |
| return 1; |
| } |
| |
| free (buf); |
| |
| return 0; |
| } |
| |
| #define TEST_FUNCTION do_test () |
| #include "../test-skeleton.c" |