mescc: Mes C Library: Start test suite.
[mes.git] / scaffold / tests / 91-fseek.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 <libmes.h>
22 #include <unistd.h>
23 #include <fcntl.h>
24 #include <string.h>
25 #include <stdio.h>
26
27 int
28 main ()
29 {
30   int fd = open ("COPYING", 0);
31   if (fd <= 0)
32     return 1;
33   FILE* f = fdopen (fd, "r");
34   int r = fseek (f, 0, SEEK_CUR);
35   if (r != 0)
36     return 2;
37   int pos = ftell (f);
38   if (pos != 0)
39     return 3;
40
41   r = fseek (f, 0, SEEK_END);
42   if (r != 0)
43     return 4;
44
45   pos = ftell (f);
46   eputs ("size="); eputs (itoa (pos)); eputs ("\n");
47   if (pos != 35147)
48     return 5;
49   r = fseek (f, 0, SEEK_SET);
50
51   char buf[4096];
52   fgets (buf, 200, f);
53   eputs ("buf:"); eputs (buf);
54   if (strcmp (buf, "                    GNU GENERAL PUBLIC LICENSE\n"))
55     return 6;
56
57   return 0;
58 }