libexplain  1.4.D001
libexplain/buffer/errno/setsid.c
Go to the documentation of this file.
00001 /*
00002  * libexplain - Explain errno values returned by libc functions
00003  * Copyright (C) 2011, 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/gettext.h>
00022 #include <libexplain/buffer/errno/generic.h>
00023 #include <libexplain/buffer/errno/setsid.h>
00024 #include <libexplain/explanation.h>
00025 
00026 
00027 static void
00028 explain_buffer_errno_setsid_system_call(explain_string_buffer_t *sb, int errnum)
00029 {
00030     (void)errnum;
00031     explain_string_buffer_puts(sb, "setsid()");
00032 }
00033 
00034 
00035 void
00036 explain_buffer_errno_setsid_explanation(explain_string_buffer_t *sb, int errnum,
00037     const char *syscall_name)
00038 {
00039     /*
00040      * http://www.opengroup.org/onlinepubs/009695399/functions/setsid.html
00041      */
00042     switch (errnum)
00043     {
00044     case EPERM:
00045         /*
00046          * The process group ID of any process equals the PID of the
00047          * calling process.  Thus, in particular, setsid() fails if the
00048          * calling process is already a process group leader.
00049          */
00050         explain_buffer_gettext
00051         (
00052             sb,
00053             /*
00054              * xgettext: this error message is used to explain an EPERM error
00055              * returned by the setsid system call, in the case where the calling
00056              * process is already a process group leader.
00057              */
00058             i18n("the process is already a process group leader")
00059         );
00060         break;
00061 
00062     default:
00063         explain_buffer_errno_generic(sb, errnum, syscall_name);
00064         break;
00065     }
00066 }
00067 
00068 
00069 void
00070 explain_buffer_errno_setsid(explain_string_buffer_t *sb, int errnum)
00071 {
00072     explain_explanation_t exp;
00073 
00074     explain_explanation_init(&exp, errnum);
00075     explain_buffer_errno_setsid_system_call(&exp.system_call_sb, errnum);
00076     explain_buffer_errno_setsid_explanation(&exp.explanation_sb, errnum,
00077         "setsid");
00078     explain_explanation_assemble(&exp, sb);
00079 }
00080 
00081 
00082 /* vim: set ts=8 sw=4 et : */