Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
387864d5
提交
387864d5
authored
6 年前
作者:
Evgenij Ryazanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Remove leftover support of File.deleteOnExit()
上级
dbc36dc0
显示空白字符变更
内嵌
并排
正在显示
15 个修改的文件
包含
26 行增加
和
53 行删除
+26
-53
roadmap.html
h2/src/docsrc/html/roadmap.html
+0
-2
Database.java
h2/src/main/org/h2/engine/Database.java
+1
-1
SessionRemote.java
h2/src/main/org/h2/engine/SessionRemote.java
+1
-1
MVTempResult.java
h2/src/main/org/h2/mvstore/db/MVTempResult.java
+1
-1
FilePath.java
h2/src/main/org/h2/store/fs/FilePath.java
+1
-4
FilePathDisk.java
h2/src/main/org/h2/store/fs/FilePathDisk.java
+1
-11
FilePathRec.java
h2/src/main/org/h2/store/fs/FilePathRec.java
+3
-5
FilePathWrapper.java
h2/src/main/org/h2/store/fs/FilePathWrapper.java
+2
-3
FilePathZip.java
h2/src/main/org/h2/store/fs/FilePathZip.java
+2
-4
FileUtils.java
h2/src/main/org/h2/store/fs/FileUtils.java
+2
-5
ValueLobDb.java
h2/src/main/org/h2/value/ValueLobDb.java
+1
-1
TestFileSystem.java
h2/src/test/org/h2/test/unit/TestFileSystem.java
+4
-4
FilePathDebug.java
h2/src/test/org/h2/test/utils/FilePathDebug.java
+3
-4
FilePathUnstable.java
h2/src/test/org/h2/test/utils/FilePathUnstable.java
+2
-3
FilePathZip2.java
h2/src/tools/org/h2/dev/fs/FilePathZip2.java
+2
-4
没有找到文件。
h2/src/docsrc/html/roadmap.html
浏览文件 @
387864d5
...
...
@@ -63,8 +63,6 @@ See also <a href="build.html#providing_patches">Providing Patches</a>.
</li><li>
PostgreSQL catalog: use BEFORE SELECT triggers instead of views over metadata tables.
</li><li>
Test very large databases and LOBs (up to 256 GB).
</li><li>
Store all temp files in the temp directory.
</li><li>
Don't use temp files, specially not deleteOnExit (bug 4513817: File.deleteOnExit consumes memory).
Also to allow opening client / server (remote) connections when using LOBs.
</li><li>
Make DDL (Data Definition) operations transactional.
</li><li>
Deferred integrity checking (DEFERRABLE INITIALLY DEFERRED).
</li><li>
Groovy Stored Procedures: http://groovy.codehaus.org/GSQL
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/engine/Database.java
浏览文件 @
387864d5
...
...
@@ -1956,7 +1956,7 @@ public class Database implements DataHandler {
if
(!
persistent
)
{
name
=
"memFS:"
+
name
;
}
return
FileUtils
.
createTempFile
(
name
,
Constants
.
SUFFIX_TEMP_FILE
,
false
,
inTempDir
);
return
FileUtils
.
createTempFile
(
name
,
Constants
.
SUFFIX_TEMP_FILE
,
inTempDir
);
}
catch
(
IOException
e
)
{
throw
DbException
.
convertIOException
(
e
,
databaseName
);
}
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/engine/SessionRemote.java
浏览文件 @
387864d5
...
...
@@ -376,7 +376,7 @@ public class SessionRemote extends SessionWithState implements DataHandler {
traceSystem
.
setLevelFile
(
level
);
if
(
level
>
0
&&
level
<
4
)
{
String
file
=
FileUtils
.
createTempFile
(
prefix
,
Constants
.
SUFFIX_TRACE_FILE
,
false
,
false
);
Constants
.
SUFFIX_TRACE_FILE
,
false
);
traceSystem
.
setFileName
(
file
);
}
}
catch
(
IOException
e
)
{
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/mvstore/db/MVTempResult.java
浏览文件 @
387864d5
...
...
@@ -159,7 +159,7 @@ public abstract class MVTempResult implements ResultExternal {
*/
MVTempResult
(
Database
database
,
int
columnCount
,
int
visibleColumnCount
)
{
try
{
String
fileName
=
FileUtils
.
createTempFile
(
"h2tmp"
,
Constants
.
SUFFIX_TEMP_FILE
,
false
,
true
);
String
fileName
=
FileUtils
.
createTempFile
(
"h2tmp"
,
Constants
.
SUFFIX_TEMP_FILE
,
true
);
Builder
builder
=
new
MVStore
.
Builder
().
fileName
(
fileName
).
cacheSize
(
0
).
autoCommitDisabled
();
byte
[]
key
=
database
.
getFileEncryptionKey
();
if
(
key
!=
null
)
{
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FilePath.java
浏览文件 @
387864d5
...
...
@@ -250,14 +250,11 @@ public abstract class FilePath {
* Create a new temporary file.
*
* @param suffix the suffix
* @param deleteOnExit if the file should be deleted when the virtual
* machine exists
* @param inTempDir if the file should be stored in the temporary directory
* @return the name of the created file
*/
@SuppressWarnings
(
"unused"
)
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
while
(
true
)
{
FilePath
p
=
getPath
(
name
+
getNextTempFileNamePart
(
false
)
+
suffix
);
if
(
p
.
exists
()
||
!
p
.
createFile
())
{
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FilePathDisk.java
浏览文件 @
387864d5
...
...
@@ -381,8 +381,7 @@ public class FilePathDisk extends FilePath {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
String
fileName
=
name
+
"."
;
String
prefix
=
new
File
(
fileName
).
getName
();
File
dir
;
...
...
@@ -399,15 +398,6 @@ public class FilePathDisk extends FilePath {
getNextTempFileNamePart
(
true
);
continue
;
}
if
(
deleteOnExit
)
{
try
{
f
.
deleteOnExit
();
}
catch
(
Throwable
e
)
{
// sometimes this throws a NullPointerException
// at java.io.DeleteOnExitHook.add(DeleteOnExitHook.java:33)
// we can ignore it
}
}
return
get
(
f
.
getCanonicalPath
());
}
}
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FilePathRec.java
浏览文件 @
387864d5
...
...
@@ -46,11 +46,9 @@ public class FilePathRec extends FilePathWrapper {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
log
(
Recorder
.
CREATE_TEMP_FILE
,
unwrap
(
name
)
+
":"
+
suffix
+
":"
+
deleteOnExit
+
":"
+
inTempDir
);
return
super
.
createTempFile
(
suffix
,
deleteOnExit
,
inTempDir
);
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
log
(
Recorder
.
CREATE_TEMP_FILE
,
unwrap
(
name
)
+
":"
+
suffix
+
":"
+
inTempDir
);
return
super
.
createTempFile
(
suffix
,
inTempDir
);
}
@Override
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FilePathWrapper.java
浏览文件 @
387864d5
...
...
@@ -158,9 +158,8 @@ public abstract class FilePathWrapper extends FilePath {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
return
wrap
(
base
.
createTempFile
(
suffix
,
deleteOnExit
,
inTempDir
));
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
return
wrap
(
base
.
createTempFile
(
suffix
,
inTempDir
));
}
}
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FilePathZip.java
浏览文件 @
387864d5
...
...
@@ -234,13 +234,11 @@ public class FilePathZip extends FilePath {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
if
(!
inTempDir
)
{
throw
new
IOException
(
"File system is read-only"
);
}
return
new
FilePathDisk
().
getPath
(
name
).
createTempFile
(
suffix
,
deleteOnExit
,
true
);
return
new
FilePathDisk
().
getPath
(
name
).
createTempFile
(
suffix
,
true
);
}
@Override
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/store/fs/FileUtils.java
浏览文件 @
387864d5
...
...
@@ -335,15 +335,12 @@ public class FileUtils {
* @param prefix the prefix of the file name (including directory name if
* required)
* @param suffix the suffix
* @param deleteOnExit if the file should be deleted when the virtual
* machine exists
* @param inTempDir if the file should be stored in the temporary directory
* @return the name of the created file
*/
public
static
String
createTempFile
(
String
prefix
,
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
return
FilePath
.
get
(
prefix
).
createTempFile
(
suffix
,
deleteOnExit
,
inTempDir
).
toString
();
boolean
inTempDir
)
throws
IOException
{
return
FilePath
.
get
(
prefix
).
createTempFile
(
suffix
,
inTempDir
).
toString
();
}
/**
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/value/ValueLobDb.java
浏览文件 @
387864d5
...
...
@@ -179,7 +179,7 @@ public class ValueLobDb extends Value {
if
(
path
.
isEmpty
())
{
path
=
SysProperties
.
PREFIX_TEMP_FILE
;
}
return
FileUtils
.
createTempFile
(
path
,
Constants
.
SUFFIX_TEMP_FILE
,
false
,
true
);
return
FileUtils
.
createTempFile
(
path
,
Constants
.
SUFFIX_TEMP_FILE
,
true
);
}
/**
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/unit/TestFileSystem.java
浏览文件 @
387864d5
...
...
@@ -370,7 +370,7 @@ public class TestFileSystem extends TestDb {
new
AssertThrows
(
IOException
.
class
)
{
@Override
public
void
test
()
throws
IOException
{
FileUtils
.
createTempFile
(
f
,
".tmp"
,
false
,
false
);
FileUtils
.
createTempFile
(
f
,
".tmp"
,
false
);
}};
final
FileChannel
channel
=
FileUtils
.
open
(
f
,
"r"
);
new
AssertThrows
(
IOException
.
class
)
{
...
...
@@ -670,7 +670,7 @@ public class TestFileSystem extends TestDb {
private
void
testRandomAccess
(
String
fsBase
,
int
seed
)
throws
Exception
{
StringBuilder
buff
=
new
StringBuilder
();
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
,
false
);
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
);
File
file
=
new
File
(
TestBase
.
BASE_TEST_DIR
+
"/tmp"
);
file
.
getParentFile
().
mkdirs
();
file
.
delete
();
...
...
@@ -784,7 +784,7 @@ public class TestFileSystem extends TestDb {
private
void
testTempFile
(
String
fsBase
)
throws
Exception
{
int
len
=
10000
;
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
,
false
);
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
);
OutputStream
out
=
FileUtils
.
newOutputStream
(
s
,
false
);
byte
[]
buffer
=
new
byte
[
len
];
out
.
write
(
buffer
);
...
...
@@ -804,7 +804,7 @@ public class TestFileSystem extends TestDb {
}
private
void
testConcurrent
(
String
fsBase
)
throws
Exception
{
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
,
false
);
String
s
=
FileUtils
.
createTempFile
(
fsBase
+
"/tmp"
,
".tmp"
,
false
);
File
file
=
new
File
(
TestBase
.
BASE_TEST_DIR
+
"/tmp"
);
file
.
getParentFile
().
mkdirs
();
file
.
delete
();
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/utils/FilePathDebug.java
浏览文件 @
387864d5
...
...
@@ -191,10 +191,9 @@ public class FilePathDebug extends FilePathWrapper {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
trace
(
name
,
"createTempFile"
,
suffix
,
deleteOnExit
,
inTempDir
);
return
super
.
createTempFile
(
suffix
,
deleteOnExit
,
inTempDir
);
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
trace
(
name
,
"createTempFile"
,
suffix
,
inTempDir
);
return
super
.
createTempFile
(
suffix
,
inTempDir
);
}
/**
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/utils/FilePathUnstable.java
浏览文件 @
387864d5
...
...
@@ -198,9 +198,8 @@ public class FilePathUnstable extends FilePathWrapper {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
return
super
.
createTempFile
(
suffix
,
deleteOnExit
,
inTempDir
);
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
return
super
.
createTempFile
(
suffix
,
inTempDir
);
}
@Override
...
...
This diff is collapsed.
Click to expand it.
h2/src/tools/org/h2/dev/fs/FilePathZip2.java
浏览文件 @
387864d5
...
...
@@ -61,13 +61,11 @@ public class FilePathZip2 extends FilePath {
}
@Override
public
FilePath
createTempFile
(
String
suffix
,
boolean
deleteOnExit
,
boolean
inTempDir
)
throws
IOException
{
public
FilePath
createTempFile
(
String
suffix
,
boolean
inTempDir
)
throws
IOException
{
if
(!
inTempDir
)
{
throw
new
IOException
(
"File system is read-only"
);
}
return
new
FilePathDisk
().
getPath
(
name
).
createTempFile
(
suffix
,
deleteOnExit
,
true
);
return
new
FilePathDisk
().
getPath
(
name
).
createTempFile
(
suffix
,
true
);
}
@Override
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论