Fix dtoab.
[mes.git] / lib / tests / stdio / 90-fread-fwrite.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * GNU Mes --- Maxwell Equations of Software
3  * Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
4  *
5  * This file is part of GNU Mes.
6  *
7  * GNU Mes is free software; you can redistribute it and/or modify it
8  * under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3 of the License, or (at
10  * your option) any later version.
11  *
12  * GNU Mes is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with GNU Mes.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 #include <mes/lib.h>
22 #include <fcntl.h>
23 #include <unistd.h>
24 #include <stdio.h>
25 #include <string.h>
26 #include <stdlib.h>
27
28 int
29 main ()
30 {
31   char *temp = "COPYING.tmp";
32   char *new = "COPYING.new";
33
34   unlink (temp);
35   unlink (new);
36
37   FILE *t = fopen (temp, "wb+");
38   FILE *n = fopen (new, "wb");
39
40   char *header = "!<header>\n";
41   fwrite (header, strlen (header), 1, n);
42
43   char *data = "foo bar baz\n";
44   fwrite (data, strlen (data), 1, t);
45
46   fseek (t, 0, SEEK_END);
47   int size = ftell (t);
48   fprintf (stderr, "  size=>%d\n", size);
49   fseek (t, 0, SEEK_SET);
50   char *p = (char *) malloc (size + 1);
51   fread (p, size, 1, t);
52   fwrite (p, size, 1, n);
53
54   char header_plus_data[200];
55   strcpy (header_plus_data, header);
56   strcat (header_plus_data, data);
57
58   FILE *test = fopen (new, "r");
59   char buf[200];
60   fflush (n);
61   fread (buf, strlen (header_plus_data), 1, test);
62   eputs ("buf=");
63   eputs (buf);
64   eputs ("\n");
65   if (strcmp (buf, header_plus_data))
66     return 1;
67
68   if (access (temp, R_OK))
69     return 22;
70
71   unlink (temp);
72
73   if (!access (temp, R_OK))
74     return 3;
75
76   unlink (new);
77
78   return 0;
79 }