summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibCore/System.cpp
diff options
context:
space:
mode:
authorJunior Rantila <junior.rantila@gmail.com>2021-12-29 21:47:38 +0100
committerAndreas Kling <kling@serenityos.org>2022-01-06 18:20:07 +0100
commit9a38d1de07aa19af171d3b9143d0560d5e92cf47 (patch)
treeda2b809a5461108f6e79ce798bcedf3e933070fc /Userland/Libraries/LibCore/System.cpp
parent080c3164c7df77e622eea86541ae62d52fd4e471 (diff)
downloadserenity-9a38d1de07aa19af171d3b9143d0560d5e92cf47.zip
LibCore+ImageViewer: Add unlink() wrapper, use it
Diffstat (limited to 'Userland/Libraries/LibCore/System.cpp')
-rw-r--r--Userland/Libraries/LibCore/System.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/Userland/Libraries/LibCore/System.cpp b/Userland/Libraries/LibCore/System.cpp
index 99b5b1cacc..46d21b2b13 100644
--- a/Userland/Libraries/LibCore/System.cpp
+++ b/Userland/Libraries/LibCore/System.cpp
@@ -644,6 +644,22 @@ ErrorOr<void> rename(StringView old_path, StringView new_path)
#endif
}
+ErrorOr<void> unlink(StringView path)
+{
+ if (path.is_null())
+ return Error::from_errno(EFAULT);
+
+#ifdef __serenity__
+ int rc = syscall(SC_unlink, path.characters_without_null_termination(), path.length());
+ HANDLE_SYSCALL_RETURN_VALUE("unlink"sv, rc, {});
+#else
+ String path_string = path;
+ if (::unlink(path_string.characters()) < 0)
+ return Error::from_syscall("unlink"sv, -errno);
+ return {};
+#endif
+}
+
ErrorOr<void> utime(StringView path, Optional<struct utimbuf> maybe_buf)
{
if (path.is_null())