// // aegis - project change supervisor // Copyright (C) 1991-2006, 2008 Peter Miller // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, see // . // #include #include #include #include #include #include #include #include #include void os_unlink_errok(const nstring &path) { trace(("os_unlink_errok(path = \"%s\")\n{\n", path.c_str())); os_become_must_be_active(); // // We must check that we are not unlinking a directory, // because we are set-uid-root, and root can unlink directories! // struct stat st; #ifdef S_IFLNK int oret = glue_lstat(path.c_str(), &st); #else int oret = glue_stat(path.c_str(), &st); #endif if (oret && errno == ENOENT) { // Don't complaint if it's not there. trace(("}\n")); return; } if (oret) { int errno_old = errno; sub_context_ty *scp = sub_context_new(); sub_errno_setx(scp, errno_old); sub_var_set_string(scp, "File_Name", path); if (errno != ENOENT && errno != ENOTDIR) fatal_intl(scp, i18n("stat $filename: $errno")); error_intl(scp, i18n("warning: stat $filename: $errno")); sub_context_delete(scp); } else if ((st.st_mode & S_IFMT) == S_IFDIR) { sub_context_ty *scp = sub_context_new(); sub_errno_setx(scp, EISDIR); sub_var_set_string(scp, "File_Name", path); error_intl(scp, i18n("warning: unlink $filename: $errno")); sub_context_delete(scp); } else if (glue_unlink(path.c_str())) { int errno_old = errno; sub_context_ty *scp = sub_context_new(); sub_errno_setx(scp, errno_old); sub_var_set_string(scp, "File_Name", path); error_intl(scp, i18n("warning: unlink $filename: $errno")); sub_context_delete(scp); } trace(("}\n")); } void os_unlink_errok(string_ty *path) { os_unlink_errok(nstring(path)); }