libexplain  1.4.D001
libexplain/buffer/errno/ungetc.c
Go to the documentation of this file.
00001 /*
00002  * libexplain - Explain errno values returned by libc functions
00003  * Copyright (C) 2010, 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 
00021 #include <libexplain/buffer/char_or_eof.h>
00022 #include <libexplain/buffer/einval.h>
00023 #include <libexplain/buffer/ebadf.h>
00024 #include <libexplain/buffer/enomem.h>
00025 #include <libexplain/buffer/errno/generic.h>
00026 #include <libexplain/buffer/errno/ungetc.h>
00027 #include <libexplain/buffer/stream.h>
00028 #include <libexplain/explanation.h>
00029 #include <libexplain/stream_to_fildes.h>
00030 
00031 
00032 static void
00033 explain_buffer_errno_ungetc_system_call(explain_string_buffer_t *sb, int errnum,
00034     int c, FILE *fp)
00035 {
00036     (void)errnum;
00037     explain_string_buffer_puts(sb, "ungetc(c = ");
00038     explain_buffer_char_or_eof(sb, c);
00039     explain_string_buffer_puts(sb, ", fp = ");
00040     explain_buffer_stream(sb, fp);
00041     explain_string_buffer_putc(sb, ')');
00042 }
00043 
00044 
00045 void
00046 explain_buffer_errno_ungetc_explanation(explain_string_buffer_t *sb, int errnum,
00047     const char *syscall_name, int c, FILE *fp)
00048 {
00049     /*
00050      * http://www.opengroup.org/onlinepubs/009695399/functions/ungetc.html
00051      */
00052     switch (errnum)
00053     {
00054     case 0:
00055         explain_buffer_einval_ungetc(sb, syscall_name);
00056         break;
00057 
00058     case EBADF:
00059         explain_buffer_ebadf_stream(sb, "fp");
00060         break;
00061 
00062     case EINVAL:
00063         if (c == EOF)
00064         {
00065             explain_buffer_einval_ungetc(sb, syscall_name);
00066             break;
00067         }
00068         if (explain_stream_to_fildes(fp) == -1)
00069         {
00070             explain_buffer_ebadf_stream(sb, "fp");
00071             break;
00072         }
00073         goto generic;
00074 
00075     case ENOMEM:
00076         explain_buffer_enomem_user(sb, 0);
00077         break;
00078 
00079     default:
00080         generic:
00081         explain_buffer_errno_generic(sb, errnum, syscall_name);
00082         break;
00083     }
00084 }
00085 
00086 
00087 void
00088 explain_buffer_errno_ungetc(explain_string_buffer_t *sb, int errnum, int c,
00089     FILE *fp)
00090 {
00091     explain_explanation_t exp;
00092 
00093     explain_explanation_init(&exp, errnum);
00094     explain_buffer_errno_ungetc_system_call(&exp.system_call_sb, errnum, c, fp);
00095     explain_buffer_errno_ungetc_explanation(&exp.explanation_sb, errnum,
00096         "ungetc", c, fp);
00097     explain_explanation_assemble(&exp, sb);
00098 }
00099 
00100 
00101 /* vim: set ts=8 sw=4 et : */