mescc: Mes C Library: Fix ungetc.
[mes.git] / lib / mes / fdgetc.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * GNU Mes --- Maxwell Equations of Software
3  * Copyright © 2016,2017,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 <limits.h>
23 #include <sys/resource.h>
24
25 int __ungetc_buf[RLIMIT_NOFILE+1] = {0};
26
27 void
28 __ungetc_init ()
29 {
30   if (__ungetc_buf[RLIMIT_NOFILE] == 0)
31     memset (__ungetc_buf, -1, (RLIMIT_NOFILE+1)*sizeof (int));
32 }
33
34 int
35 fdgetc (int fd)
36 {
37   __ungetc_init ();
38
39   char c;
40   int i = __ungetc_buf[fd];
41   if (i >= 0)
42     __ungetc_buf[fd] = -1;
43   else
44     {
45       int r = read (fd, &c, 1);
46       if (r < 1)
47         return -1;
48       i = c;
49    }
50   if (i < 0)
51     i += 256;
52
53   return i;
54 }