Index: runtime/bin/file_android.cc |
diff --git a/runtime/bin/file_android.cc b/runtime/bin/file_android.cc |
index 985fbf8cd9d13b97bacc3072c91e5e520c23387f..afe09669b9afce2d091c9518520c05aa5ecc496e 100644 |
--- a/runtime/bin/file_android.cc |
+++ b/runtime/bin/file_android.cc |
@@ -17,8 +17,8 @@ |
#include <unistd.h> // NOLINT |
#include "bin/builtin.h" |
-#include "bin/fdutils.h" |
#include "bin/log.h" |
+ |
#include "platform/signal_blocker.h" |
#include "platform/utils.h" |
@@ -227,8 +227,7 @@ File* File::OpenStdio(int fd) { |
bool File::Exists(const char* name) { |
struct stat st; |
if (NO_RETRY_EXPECTED(stat(name, &st)) == 0) { |
- // Everything but a directory and a link is a file to Dart. |
- return !S_ISDIR(st.st_mode) && !S_ISLNK(st.st_mode); |
+ return S_ISREG(st.st_mode); |
} else { |
return false; |
} |
@@ -240,22 +239,7 @@ bool File::Create(const char* name) { |
if (fd < 0) { |
return false; |
} |
- // File.create returns a File, so we shouldn't be giving the illusion that the |
- // call has created a file or that a file already exists if there is already |
- // an entity at the same path that is a directory or a link. |
- bool is_file = true; |
- struct stat st; |
- if (NO_RETRY_EXPECTED(fstat(fd, &st)) == 0) { |
- if (S_ISDIR(st.st_mode)) { |
- errno = EISDIR; |
- is_file = false; |
- } else if (S_ISLNK(st.st_mode)) { |
- errno = ENOENT; |
- is_file = false; |
- } |
- } |
- FDUtils::SaveErrorAndClose(fd); |
- return is_file; |
+ return (close(fd) == 0); |
} |