mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
File.createNewFile should return false if the file already exists
This commit is contained in:
parent
6cc0ddda7c
commit
4aefa211a3
@ -48,7 +48,6 @@
|
|||||||
# define R_OK 4
|
# define R_OK 4
|
||||||
# else
|
# else
|
||||||
# define OPEN _wopen
|
# define OPEN _wopen
|
||||||
# define CREAT _wcreat
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# define GET_CHARS GetStringChars
|
# define GET_CHARS GetStringChars
|
||||||
@ -71,7 +70,6 @@ typedef wchar_t char_t;
|
|||||||
# define STRUCT_STAT struct stat
|
# define STRUCT_STAT struct stat
|
||||||
# define MKDIR mkdir
|
# define MKDIR mkdir
|
||||||
# define CHMOD chmod
|
# define CHMOD chmod
|
||||||
# define CREAT creat
|
|
||||||
# define UNLINK unlink
|
# define UNLINK unlink
|
||||||
# define RENAME rename
|
# define RENAME rename
|
||||||
# define OPEN_MASK 0
|
# define OPEN_MASK 0
|
||||||
@ -102,12 +100,6 @@ OPEN(string_t path, int mask, int mode)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int
|
|
||||||
CREAT(string_t path, int mode)
|
|
||||||
{
|
|
||||||
return OPEN(path, _O_CREAT, mode);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
inline bool
|
inline bool
|
||||||
@ -407,21 +399,28 @@ Java_java_io_File_mkdir(JNIEnv* e, jclass, jstring path)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT jboolean JNICALL
|
||||||
Java_java_io_File_createNewFile(JNIEnv* e, jclass, jstring path)
|
Java_java_io_File_createNewFile(JNIEnv* e, jclass, jstring path)
|
||||||
{
|
{
|
||||||
|
bool result = false;
|
||||||
string_t chars = getChars(e, path);
|
string_t chars = getChars(e, path);
|
||||||
if (chars) {
|
if (chars) {
|
||||||
|
fprintf(stderr, "create file \"%s\"\n", chars);
|
||||||
if (not exists(chars)) {
|
if (not exists(chars)) {
|
||||||
int fd = CREAT(chars, 0600);
|
int fd = OPEN(chars, O_CREAT | O_WRONLY | O_EXCL, 0600);
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
throwNewErrno(e, "java/io/IOException");
|
fprintf(stderr, "errno %d\n", errno);
|
||||||
|
if (errno != EEXIST) {
|
||||||
|
throwNewErrno(e, "java/io/IOException");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
result = true;
|
||||||
doClose(e, fd);
|
doClose(e, fd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
releaseChars(e, path, chars);
|
releaseChars(e, path, chars);
|
||||||
}
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
|
@ -204,15 +204,10 @@ public class File implements Serializable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native void createNewFile(String path) throws IOException;
|
private static native boolean createNewFile(String path) throws IOException;
|
||||||
|
|
||||||
public boolean createNewFile() {
|
public boolean createNewFile() throws IOException {
|
||||||
try {
|
return createNewFile(path);
|
||||||
createNewFile(path);
|
|
||||||
return true;
|
|
||||||
} catch (IOException e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static native void delete(String path) throws IOException;
|
public static native void delete(String path) throws IOException;
|
||||||
|
@ -42,7 +42,6 @@
|
|||||||
# define S_IWUSR _S_IWRITE
|
# define S_IWUSR _S_IWRITE
|
||||||
# else
|
# else
|
||||||
# define OPEN _open
|
# define OPEN _open
|
||||||
# define CREAT _creat
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# define O_RDONLY _O_RDONLY
|
# define O_RDONLY _O_RDONLY
|
||||||
@ -82,6 +81,8 @@ typedef int socklen_t;
|
|||||||
|
|
||||||
#endif // not PLATFORM_WINDOWS
|
#endif // not PLATFORM_WINDOWS
|
||||||
|
|
||||||
|
#define JVM_EEXIST -100
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
@ -97,12 +98,6 @@ OPEN(string_t path, int mask, int mode)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int
|
|
||||||
CREAT(string_t path, int mode)
|
|
||||||
{
|
|
||||||
return OPEN(path, _O_CREAT, mode);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace local {
|
namespace local {
|
||||||
@ -4819,7 +4814,12 @@ EXPORT(JVM_NativePath)(char* path)
|
|||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
EXPORT(JVM_Open)(const char* path, jint flags, jint mode)
|
EXPORT(JVM_Open)(const char* path, jint flags, jint mode)
|
||||||
{
|
{
|
||||||
return OPEN(path, flags, mode);
|
int r = OPEN(path, flags, mode);
|
||||||
|
if (r == -1) {
|
||||||
|
return errno == EEXIST ? JVM_EEXIST : -1;
|
||||||
|
} else {
|
||||||
|
return r;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
|
@ -40,6 +40,12 @@ public class Files {
|
|||||||
isAbsoluteTest(false);
|
isAbsoluteTest(false);
|
||||||
setExecutableTestWithPermissions(true);
|
setExecutableTestWithPermissions(true);
|
||||||
setExecutableTestWithPermissions(false);
|
setExecutableTestWithPermissions(false);
|
||||||
|
|
||||||
|
{ File f = new File("test.txt");
|
||||||
|
f.createNewFile();
|
||||||
|
expect(! f.createNewFile());
|
||||||
|
f.delete();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user