Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1651)

Unified Diff: fusl/src/unistd/dup3.c

Issue 1714623002: [fusl] clang-format fusl (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: headers too Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: fusl/src/unistd/dup3.c
diff --git a/fusl/src/unistd/dup3.c b/fusl/src/unistd/dup3.c
index 0eb6caf59e6e1b0015b231632b6c20f879c5ad95..1a694a701b0ab3d841eb8c7c8d05476207e13f40 100644
--- a/fusl/src/unistd/dup3.c
+++ b/fusl/src/unistd/dup3.c
@@ -5,21 +5,26 @@
#include "syscall.h"
#include "libc.h"
-int __dup3(int old, int new, int flags)
-{
- int r;
+int __dup3(int old, int new, int flags) {
+ int r;
#ifdef SYS_dup2
- if (old==new) return __syscall_ret(-EINVAL);
- if (flags & O_CLOEXEC) {
- while ((r=__syscall(SYS_dup3, old, new, flags))==-EBUSY);
- if (r!=-ENOSYS) return __syscall_ret(r);
- }
- while ((r=__syscall(SYS_dup2, old, new))==-EBUSY);
- if (flags & O_CLOEXEC) __syscall(SYS_fcntl, new, F_SETFD, FD_CLOEXEC);
+ if (old == new)
+ return __syscall_ret(-EINVAL);
+ if (flags & O_CLOEXEC) {
+ while ((r = __syscall(SYS_dup3, old, new, flags)) == -EBUSY)
+ ;
+ if (r != -ENOSYS)
+ return __syscall_ret(r);
+ }
+ while ((r = __syscall(SYS_dup2, old, new)) == -EBUSY)
+ ;
+ if (flags & O_CLOEXEC)
+ __syscall(SYS_fcntl, new, F_SETFD, FD_CLOEXEC);
#else
- while ((r=__syscall(SYS_dup3, old, new, flags))==-EBUSY);
+ while ((r = __syscall(SYS_dup3, old, new, flags)) == -EBUSY)
+ ;
#endif
- return __syscall_ret(r);
+ return __syscall_ret(r);
}
weak_alias(__dup3, dup3);

Powered by Google App Engine
This is Rietveld 408576698