libexplain
1.4.D001
|
00001 /* 00002 * libexplain - Explain errno values returned by libc functions 00003 * Copyright (C) 2010, 2012, 2013 Peter Miller 00004 * 00005 * This program is free software; you can redistribute it and/or modify it 00006 * under the terms of the GNU Lesser General Public License as published by 00007 * the Free Software Foundation; either version 3 of the License, or (at 00008 * your option) any later version. 00009 * 00010 * This program is distributed in the hope that it will be useful, but 00011 * WITHOUT ANY WARRANTY; without even the implied warranty of 00012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser 00013 * General Public License for more details. 00014 * 00015 * You should have received a copy of the GNU Lesser General Public License 00016 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 */ 00018 00019 #include <libexplain/ac/errno.h> 00020 #include <libexplain/ac/stdio.h> 00021 00022 #include <libexplain/ungetc.h> 00023 #include <libexplain/output.h> 00024 00025 00026 int 00027 explain_ungetc_on_error(int c, FILE *fp) 00028 { 00029 int hold_errno; 00030 int result; 00031 00032 hold_errno = errno; 00033 errno = 0; 00034 result = ungetc(c, fp); 00035 if (result == EOF) 00036 { 00037 hold_errno = errno; 00038 if (hold_errno == 0) 00039 hold_errno = EINVAL; 00040 explain_output_error("%s", explain_errno_ungetc(hold_errno, c, fp)); 00041 } 00042 errno = hold_errno; 00043 return result; 00044 } 00045 00046 00047 /* vim: set ts=8 sw=4 et : */