summaryrefslogtreecommitdiff
path: root/Userland
diff options
context:
space:
mode:
Diffstat (limited to 'Userland')
-rw-r--r--Userland/Libraries/LibCore/System.cpp21
-rw-r--r--Userland/Libraries/LibCore/System.h1
2 files changed, 22 insertions, 0 deletions
diff --git a/Userland/Libraries/LibCore/System.cpp b/Userland/Libraries/LibCore/System.cpp
index 8defd74759..18d11244bf 100644
--- a/Userland/Libraries/LibCore/System.cpp
+++ b/Userland/Libraries/LibCore/System.cpp
@@ -503,4 +503,25 @@ ErrorOr<int> mkstemp(Span<char> pattern)
return fd;
}
+ErrorOr<void> rename(StringView old_path, StringView new_path)
+{
+ if (old_path.is_null() || new_path.is_null())
+ return Error::from_errno(EFAULT);
+
+#ifdef __serenity__
+ Syscall::SC_rename_params params {
+ .old_path = { old_path.characters_without_null_termination(), old_path.length() },
+ .new_path = { new_path.characters_without_null_termination(), new_path.length() },
+ };
+ int rc = syscall(SC_rename, &params);
+ HANDLE_SYSCALL_RETURN_VALUE("rename"sv, rc, {});
+#else
+ String old_path_string = old_path;
+ String new_path_string = new_path;
+ if (::rename(old_path_string.characters(), new_path_string.characters()) < 0)
+ return Error::from_syscall("rename"sv, -errno);
+ return {};
+#endif
+}
+
}
diff --git a/Userland/Libraries/LibCore/System.h b/Userland/Libraries/LibCore/System.h
index 46e3dfb302..6bffc771c3 100644
--- a/Userland/Libraries/LibCore/System.h
+++ b/Userland/Libraries/LibCore/System.h
@@ -67,5 +67,6 @@ ErrorOr<void> mkdir(StringView path, mode_t);
ErrorOr<pid_t> fork();
ErrorOr<int> mkstemp(Span<char> pattern);
ErrorOr<void> fchmod(int fd, mode_t mode);
+ErrorOr<void> rename(StringView old_path, StringView new_path);
}