diff options
author | Junior Rantila <junior.rantila@gmail.com> | 2021-12-29 21:47:38 +0100 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2022-01-06 18:20:07 +0100 |
commit | 9a38d1de07aa19af171d3b9143d0560d5e92cf47 (patch) | |
tree | da2b809a5461108f6e79ce798bcedf3e933070fc /Userland/Libraries/LibCore/System.cpp | |
parent | 080c3164c7df77e622eea86541ae62d52fd4e471 (diff) | |
download | serenity-9a38d1de07aa19af171d3b9143d0560d5e92cf47.zip |
LibCore+ImageViewer: Add unlink() wrapper, use it
Diffstat (limited to 'Userland/Libraries/LibCore/System.cpp')
-rw-r--r-- | Userland/Libraries/LibCore/System.cpp | 16 |
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()) |