source: trunk/essentials/sys-devel/m4/lib/fopen-safer.c

Last change on this file was 3090, checked in by bird, 18 years ago

m4 1.4.8

File size: 1.5 KB
Line 
1/* Invoke fopen, but avoid some glitches.
2
3 Copyright (C) 2001, 2004, 2005, 2006 Free Software Foundation, Inc.
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2, or (at your option)
8 any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software Foundation,
17 Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
18
19/* Written by Paul Eggert. */
20
21#include <config.h>
22
23#include "stdio-safer.h"
24
25#include <errno.h>
26#include <unistd.h>
27#include "unistd-safer.h"
28
29#ifndef STDERR_FILENO
30# define STDERR_FILENO 2
31#endif
32
33/* Like fopen, but do not return stdin, stdout, or stderr. */
34
35FILE *
36fopen_safer (char const *file, char const *mode)
37{
38 FILE *fp = fopen (file, mode);
39
40 if (fp)
41 {
42 int fd = fileno (fp);
43
44 if (0 <= fd && fd <= STDERR_FILENO)
45 {
46 int f = dup_safer (fd);
47
48 if (f < 0)
49 {
50 int e = errno;
51 fclose (fp);
52 errno = e;
53 return NULL;
54 }
55
56 if (fclose (fp) != 0
57 || ! (fp = fdopen (f, mode)))
58 {
59 int e = errno;
60 close (f);
61 errno = e;
62 return NULL;
63 }
64 }
65 }
66
67 return fp;
68}
Note: See TracBrowser for help on using the repository browser.