//
// 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));
}