Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
d1d23510
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d1d23510
编写于
4月 22, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
introduce and use IFileService#existsFile()
上级
161bc8dd
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
44 addition
and
24 deletion
+44
-24
src/vs/platform/files/common/files.ts
src/vs/platform/files/common/files.ts
+5
-0
src/vs/workbench/parts/files/browser/fileActions.ts
src/vs/workbench/parts/files/browser/fileActions.ts
+17
-24
src/vs/workbench/parts/files/common/workingFilesModel.ts
src/vs/workbench/parts/files/common/workingFilesModel.ts
+2
-0
src/vs/workbench/services/files/electron-browser/fileService.ts
.../workbench/services/files/electron-browser/fileService.ts
+4
-0
src/vs/workbench/services/files/node/fileService.ts
src/vs/workbench/services/files/node/fileService.ts
+4
-0
src/vs/workbench/services/files/test/node/fileService.test.ts
...vs/workbench/services/files/test/node/fileService.test.ts
+12
-0
未找到文件。
src/vs/platform/files/common/files.ts
浏览文件 @
d1d23510
...
...
@@ -29,6 +29,11 @@ export interface IFileService {
*/
resolveFile
(
resource
:
URI
,
options
?:
IResolveFileOptions
):
winjs
.
TPromise
<
IFileStat
>
;
/**
*Finds out if a file identified by the resource exists.
*/
existsFile
(
resource
:
URI
):
winjs
.
TPromise
<
boolean
>
;
/**
* Resolve the contents of a file identified by the resource.
*
...
...
src/vs/workbench/parts/files/browser/fileActions.ts
浏览文件 @
d1d23510
...
...
@@ -1818,36 +1818,29 @@ export class ReopenClosedFileAction extends Action {
}
public
run
():
TPromise
<
any
>
{
let
viewletPromise
=
TPromise
.
as
(
null
);
if
(
!
this
.
partService
.
isSideBarHidden
())
{
viewletPromise
=
this
.
viewletService
.
openViewlet
(
Files
.
VIEWLET_ID
,
false
);
}
let
workingFilesModel
:
Files
.
IWorkingFilesModel
=
this
.
textFileService
.
getWorkingFilesModel
();
let
entry
:
Files
.
IWorkingFileEntry
=
workingFilesModel
.
popLastClosedEntry
();
return
viewletPromise
.
then
(()
=>
{
let
workingFilesModel
:
Files
.
IWorkingFilesModel
=
this
.
textFileService
.
getWorkingFilesModel
(
);
let
entry
:
Files
.
IWorkingFileEntry
=
workingFilesModel
.
popLastClosedEntry
();
if
(
entry
===
null
)
{
return
TPromise
.
as
(
true
);
}
if
(
entry
===
null
)
{
return
TPromise
.
as
(
true
);
}
// If the current resource is the recently closed resource, run action again
let
activeResource
=
getUntitledOrFileResource
(
this
.
editorService
.
getActiveEditorInput
());
if
(
activeResource
&&
activeResource
.
path
===
entry
.
resource
.
path
)
{
return
this
.
run
();
}
// If the current resource is the recently closed resource, run action again
let
activeResource
=
getUntitledOrFileResource
(
this
.
editorService
.
getActiveEditorInput
());
if
(
activeResource
&&
activeResource
.
path
===
entry
.
resource
.
path
)
{
return
this
.
run
();
return
this
.
fileService
.
existsFile
(
entry
.
resource
).
then
((
exists
)
=>
{
if
(
!
exists
)
{
return
this
.
run
();
// repeat in case the last closed file got deleted meanwhile
}
return
this
.
fileService
.
resolveFile
(
entry
.
resource
).
then
(()
=>
{
workingFilesModel
.
addEntry
(
entry
.
resource
);
return
this
.
editorService
.
openEditor
(
entry
);
},
(
e
:
any
)
=>
{
// If the files no longer exists, run action again
if
(
e
.
code
===
'
ENOENT
'
)
{
return
this
.
run
();
}
// Make it a working file again
workingFilesModel
.
addEntry
(
entry
.
resource
);
return
TPromise
.
wrapError
(
e
);
}
);
// Open in editor
return
this
.
editorService
.
openEditor
(
entry
);
});
}
}
...
...
src/vs/workbench/parts/files/common/workingFilesModel.ts
浏览文件 @
d1d23510
...
...
@@ -309,6 +309,7 @@ export class WorkingFilesModel implements IWorkingFilesModel {
if
(
this
.
recentlyClosedEntries
.
length
>
0
)
{
return
this
.
recentlyClosedEntries
.
pop
();
}
return
null
;
}
...
...
@@ -332,6 +333,7 @@ export class WorkingFilesModel implements IWorkingFilesModel {
public
clear
():
void
{
this
.
recordRecentlyClosedEntries
(
this
.
entries
);
let
deleted
=
this
.
entries
;
this
.
entries
=
[];
this
.
mapEntryToResource
=
Object
.
create
(
null
);
...
...
src/vs/workbench/services/files/electron-browser/fileService.ts
浏览文件 @
d1d23510
...
...
@@ -106,6 +106,10 @@ export class FileService implements IFileService {
return
this
.
raw
.
resolveFile
(
resource
,
options
);
}
public
existsFile
(
resource
:
uri
):
TPromise
<
boolean
>
{
return
this
.
raw
.
existsFile
(
resource
);
}
public
resolveContent
(
resource
:
uri
,
options
?:
IResolveContentOptions
):
TPromise
<
IContent
>
{
let
contentId
=
resource
.
toString
();
let
timerEvent
=
timer
.
start
(
timer
.
Topic
.
WORKBENCH
,
strings
.
format
(
'
Load {0}
'
,
contentId
));
...
...
src/vs/workbench/services/files/node/fileService.ts
浏览文件 @
d1d23510
...
...
@@ -135,6 +135,10 @@ export class FileService implements files.IFileService {
return
this
.
resolve
(
resource
,
options
);
}
public
existsFile
(
resource
:
uri
):
TPromise
<
boolean
>
{
return
this
.
resolveFile
(
resource
).
then
(()
=>
true
,
()
=>
false
);
}
public
resolveContent
(
resource
:
uri
,
options
?:
files
.
IResolveContentOptions
):
TPromise
<
files
.
IContent
>
{
let
absolutePath
=
this
.
toAbsolutePath
(
resource
);
...
...
src/vs/workbench/services/files/test/node/fileService.test.ts
浏览文件 @
d1d23510
...
...
@@ -265,6 +265,18 @@ suite('FileService', () => {
});
});
test
(
'
existsFile
'
,
function
(
done
:
()
=>
void
)
{
service
.
existsFile
(
uri
.
file
(
testDir
)).
then
((
exists
)
=>
{
assert
.
equal
(
exists
,
true
);
service
.
existsFile
(
uri
.
file
(
testDir
+
'
something
'
)).
then
((
exists
)
=>
{
assert
.
equal
(
exists
,
false
);
done
();
});
});
});
test
(
'
updateContent
'
,
function
(
done
:
()
=>
void
)
{
let
resource
=
uri
.
file
(
path
.
join
(
testDir
,
'
small.txt
'
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录