Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
57c94f5b
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,发现更多精彩内容 >>
提交
57c94f5b
编写于
11月 01, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
improve handling of file delete events
上级
7f438ed3
变更
7
显示空白变更内容
内联
并排
Showing
7 changed file
with
83 addition
and
133 deletion
+83
-133
src/vs/platform/files/common/files.ts
src/vs/platform/files/common/files.ts
+16
-27
src/vs/platform/files/test/events.test.ts
src/vs/platform/files/test/events.test.ts
+13
-13
src/vs/workbench/parts/files/common/editors/fileEditorInput.ts
...s/workbench/parts/files/common/editors/fileEditorInput.ts
+13
-8
src/vs/workbench/parts/files/common/editors/fileEditorTracker.ts
...workbench/parts/files/common/editors/fileEditorTracker.ts
+6
-34
src/vs/workbench/parts/files/common/explorerViewModel.ts
src/vs/workbench/parts/files/common/explorerViewModel.ts
+4
-14
src/vs/workbench/services/files/node/watcher/common.ts
src/vs/workbench/services/files/node/watcher/common.ts
+2
-7
src/vs/workbench/services/history/browser/history.ts
src/vs/workbench/services/history/browser/history.ts
+29
-30
未找到文件。
src/vs/platform/files/common/files.ts
浏览文件 @
57c94f5b
...
...
@@ -9,6 +9,7 @@ import paths = require('vs/base/common/paths');
import
URI
from
'
vs/base/common/uri
'
;
import
glob
=
require
(
'
vs/base/common/glob
'
);
import
events
=
require
(
'
vs/base/common/events
'
);
import
{
isLinux
}
from
'
vs/base/common/platform
'
;
import
{
createDecorator
}
from
'
vs/platform/instantiation/common/instantiation
'
;
export
const
IFileService
=
createDecorator
<
IFileService
>
(
'
fileService
'
);
...
...
@@ -191,19 +192,6 @@ export class FileChangesEvent extends events.Event {
return
false
;
}
return
this
.
containsAny
([
resource
],
type
);
}
/**
* Returns true if this change event contains any of the provided files with the given change type. In case of
* type DELETED, this method will also return true if a folder got deleted that is the parent of any of the
* provided file paths.
*/
public
containsAny
(
resources
:
URI
[],
type
:
FileChangeType
):
boolean
{
if
(
!
resources
||
!
resources
.
length
)
{
return
false
;
}
return
this
.
_changes
.
some
((
change
)
=>
{
if
(
change
.
type
!==
type
)
{
return
false
;
...
...
@@ -211,22 +199,10 @@ export class FileChangesEvent extends events.Event {
// For deleted also return true when deleted folder is parent of target path
if
(
type
===
FileChangeType
.
DELETED
)
{
return
resources
.
some
((
a
:
URI
)
=>
{
if
(
!
a
)
{
return
false
;
return
isEqual
(
resource
.
fsPath
,
change
.
resource
.
fsPath
)
||
isParent
(
resource
.
fsPath
,
change
.
resource
.
fsPath
);
}
return
paths
.
isEqualOrParent
(
a
.
fsPath
,
change
.
resource
.
fsPath
);
});
}
return
resources
.
some
((
a
:
URI
)
=>
{
if
(
!
a
)
{
return
false
;
}
return
a
.
fsPath
===
change
.
resource
.
fsPath
;
});
return
isEqual
(
resource
.
fsPath
,
change
.
resource
.
fsPath
);
});
}
...
...
@@ -283,6 +259,19 @@ export class FileChangesEvent extends events.Event {
}
}
export
function
isEqual
(
path1
:
string
,
path2
:
string
)
{
const
identityEquals
=
(
path1
===
path2
);
if
(
isLinux
||
identityEquals
)
{
return
identityEquals
;
}
return
path1
.
toLowerCase
()
===
path2
.
toLowerCase
();
}
export
function
isParent
(
path
:
string
,
candidate
:
string
):
boolean
{
return
path
.
indexOf
(
candidate
+
paths
.
nativeSep
)
===
0
;
}
export
interface
IBaseStat
{
/**
...
...
src/vs/platform/files/test/events.test.ts
浏览文件 @
57c94f5b
...
...
@@ -39,24 +39,24 @@ suite('Workbench Events', () => {
test
(
'
File Changes Event
'
,
function
()
{
let
changes
=
[
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/foo/updated.txt
'
)),
type
:
0
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/foo/otherupdated.txt
'
)),
type
:
0
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/added.txt
'
)),
type
:
1
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/bar/deleted.txt
'
)),
type
:
2
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/bar/folder
'
)),
type
:
2
}
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/foo/updated.txt
'
)),
type
:
Files
.
FileChangeType
.
UPDATED
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/foo/otherupdated.txt
'
)),
type
:
Files
.
FileChangeType
.
UPDATED
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/added.txt
'
)),
type
:
Files
.
FileChangeType
.
ADDED
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/bar/deleted.txt
'
)),
type
:
Files
.
FileChangeType
.
DELETED
},
{
resource
:
URI
.
file
(
Paths
.
join
(
'
C:
\\
'
,
'
/bar/folder
'
)),
type
:
Files
.
FileChangeType
.
DELETED
}
];
let
r1
=
new
FileChangesEvent
(
changes
);
assert
(
!
r1
.
contains
(
toResource
(
'
/foo
'
),
0
));
assert
(
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
0
));
assert
(
!
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
1
));
assert
(
!
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
2
));
assert
(
!
r1
.
contains
(
toResource
(
'
/foo
'
),
Files
.
FileChangeType
.
UPDATED
));
assert
(
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
Files
.
FileChangeType
.
UPDATED
));
assert
(
!
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
Files
.
FileChangeType
.
ADDED
));
assert
(
!
r1
.
contains
(
toResource
(
'
/foo/updated.txt
'
),
Files
.
FileChangeType
.
DELETED
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder
'
),
2
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder/somefile
'
),
2
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder/somefile/test.txt
'
),
2
));
assert
(
!
r1
.
contains
(
toResource
(
'
/bar/folder2/somefile
'
),
2
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder
'
),
Files
.
FileChangeType
.
DELETED
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder/somefile
'
),
Files
.
FileChangeType
.
DELETED
));
assert
(
r1
.
contains
(
toResource
(
'
/bar/folder/somefile/test.txt
'
),
Files
.
FileChangeType
.
DELETED
));
assert
(
!
r1
.
contains
(
toResource
(
'
/bar/folder2/somefile
'
),
Files
.
FileChangeType
.
DELETED
));
assert
.
strictEqual
(
5
,
r1
.
changes
.
length
);
assert
.
strictEqual
(
1
,
r1
.
getAdded
().
length
);
...
...
src/vs/workbench/parts/files/common/editors/fileEditorInput.ts
浏览文件 @
57c94f5b
...
...
@@ -10,7 +10,7 @@ import labels = require('vs/base/common/labels');
import
URI
from
'
vs/base/common/uri
'
;
import
{
EditorModel
,
EncodingMode
,
ConfirmResult
}
from
'
vs/workbench/common/editor
'
;
import
{
BinaryEditorModel
}
from
'
vs/workbench/common/editor/binaryEditorModel
'
;
import
{
IFileOperationResult
,
FileOperationResult
,
FileChangesEvent
,
EventType
}
from
'
vs/platform/files/common/files
'
;
import
{
IFileOperationResult
,
FileOperationResult
,
FileChangesEvent
,
EventType
,
FileChangeType
}
from
'
vs/platform/files/common/files
'
;
import
{
BINARY_FILE_EDITOR_ID
,
TEXT_FILE_EDITOR_ID
,
FILE_EDITOR_INPUT_ID
,
FileEditorInput
as
CommonFileEditorInput
}
from
'
vs/workbench/parts/files/common/files
'
;
import
{
ITextFileService
,
AutoSaveMode
,
ModelState
,
TextFileModelChangeEvent
,
LocalFileChangeEvent
}
from
'
vs/workbench/services/textfile/common/textfiles
'
;
import
{
IWorkspaceContextService
}
from
'
vs/platform/workspace/common/workspace
'
;
...
...
@@ -78,9 +78,9 @@ export class FileEditorInput extends CommonFileEditorInput {
}
private
onFileChanges
(
e
:
FileChangesEvent
):
void
{
e
.
getDeleted
().
forEach
(
deleted
=>
{
this
.
disposeIfRelated
(
deleted
.
resourc
e
);
}
);
if
(
e
.
gotDeleted
())
{
this
.
disposeIfRelated
(
e
);
}
}
private
onDirtyStateChange
(
e
:
TextFileModelChangeEvent
):
void
{
...
...
@@ -207,7 +207,7 @@ export class FileEditorInput extends CommonFileEditorInput {
});
}
private
disposeIfRelated
(
resource
:
URI
,
movedTo
?:
URI
):
void
{
private
disposeIfRelated
(
arg1
:
URI
|
FileChangesEvent
,
movedTo
?:
URI
):
void
{
if
(
this
.
isDirty
())
{
return
;
// we never dispose dirty files
}
...
...
@@ -219,9 +219,14 @@ export class FileEditorInput extends CommonFileEditorInput {
return
;
}
// Check if path is identical or path is a folder that the content is inside
if
(
paths
.
isEqualOrParent
(
this
.
resource
.
toString
(),
resource
.
toString
()))
{
this
.
historyService
.
remove
(
this
);
let
matches
=
false
;
if
(
arg1
instanceof
FileChangesEvent
)
{
matches
=
arg1
.
contains
(
this
.
resource
,
FileChangeType
.
DELETED
);
}
else
{
matches
=
paths
.
isEqualOrParent
(
this
.
resource
.
toString
(),
arg1
.
toString
());
}
if
(
matches
)
{
this
.
dispose
();
}
}
...
...
src/vs/workbench/parts/files/common/editors/fileEditorTracker.ts
浏览文件 @
57c94f5b
...
...
@@ -175,55 +175,27 @@ export class FileEditorTracker implements IWorkbenchContribution {
return
input
instanceof
FileEditorInput
&&
input
.
getResource
().
toString
()
===
resource
.
toString
();
}
private
getMatchingFileEditorInputFromDiff
(
input
:
DiffEditorInput
,
deletedResource
:
URI
):
FileEditorInput
;
private
getMatchingFileEditorInputFromDiff
(
input
:
DiffEditorInput
,
updatedFiles
:
FileChangesEvent
):
FileEditorInput
;
private
getMatchingFileEditorInputFromDiff
(
input
:
DiffEditorInput
,
arg
:
any
):
FileEditorInput
{
private
getMatchingFileEditorInputFromDiff
(
input
:
DiffEditorInput
,
e
:
FileChangesEvent
):
FileEditorInput
{
// First try modifiedInput
const
modifiedInput
=
input
.
modifiedInput
;
const
res
=
this
.
getMatchingFileEditorInputFromInput
(
modifiedInput
,
arg
);
const
res
=
this
.
getMatchingFileEditorInputFromInput
(
modifiedInput
,
e
);
if
(
res
)
{
return
res
;
}
// Second try originalInput
return
this
.
getMatchingFileEditorInputFromInput
(
input
.
originalInput
,
arg
);
return
this
.
getMatchingFileEditorInputFromInput
(
input
.
originalInput
,
e
);
}
private
getMatchingFileEditorInputFromInput
(
input
:
EditorInput
,
deletedResource
:
URI
):
FileEditorInput
;
private
getMatchingFileEditorInputFromInput
(
input
:
EditorInput
,
updatedFiles
:
FileChangesEvent
):
FileEditorInput
;
private
getMatchingFileEditorInputFromInput
(
input
:
EditorInput
,
arg
:
any
):
FileEditorInput
{
if
(
input
instanceof
FileEditorInput
)
{
if
(
arg
instanceof
URI
)
{
const
deletedResource
=
<
URI
>
arg
;
if
(
this
.
containsResource
(
input
,
deletedResource
))
{
return
input
;
}
}
else
{
const
updatedFiles
=
<
FileChangesEvent
>
arg
;
if
(
updatedFiles
.
contains
(
input
.
getResource
(),
FileChangeType
.
UPDATED
))
{
private
getMatchingFileEditorInputFromInput
(
input
:
EditorInput
,
e
:
FileChangesEvent
):
FileEditorInput
{
if
(
input
instanceof
FileEditorInput
&&
e
.
contains
(
input
.
getResource
(),
FileChangeType
.
UPDATED
))
{
return
input
;
}
}
}
return
null
;
}
private
containsResource
(
input
:
FileEditorInput
,
resource
:
URI
):
boolean
;
private
containsResource
(
input
:
EditorInput
,
resource
:
URI
):
boolean
{
let
fileResource
:
URI
;
if
(
input
instanceof
FileEditorInput
)
{
fileResource
=
input
.
getResource
();
}
if
(
paths
.
isEqualOrParent
(
fileResource
.
fsPath
,
resource
.
fsPath
))
{
return
true
;
}
return
false
;
}
public
dispose
():
void
{
this
.
toUnbind
=
dispose
(
this
.
toUnbind
);
}
...
...
src/vs/workbench/parts/files/common/explorerViewModel.ts
浏览文件 @
57c94f5b
...
...
@@ -7,9 +7,8 @@
import
assert
=
require
(
'
vs/base/common/assert
'
);
import
URI
from
'
vs/base/common/uri
'
;
import
{
isLinux
}
from
'
vs/base/common/platform
'
;
import
paths
=
require
(
'
vs/base/common/paths
'
);
import
{
IFileStat
}
from
'
vs/platform/files/common/files
'
;
import
{
IFileStat
,
isEqual
,
isParent
}
from
'
vs/platform/files/common/files
'
;
export
enum
StatType
{
FILE
,
...
...
@@ -257,7 +256,7 @@ export class FileStat implements IFileStat {
public
find
(
resource
:
URI
):
FileStat
{
// Return if path found
if
(
this
.
fileResourceEquals
(
resource
,
this
.
resource
))
{
if
(
isEqual
(
resource
.
toString
(),
this
.
resource
.
toString
()
))
{
return
this
;
}
...
...
@@ -269,26 +268,17 @@ export class FileStat implements IFileStat {
for
(
let
i
=
0
;
i
<
this
.
children
.
length
;
i
++
)
{
const
child
=
this
.
children
[
i
];
if
(
this
.
fileResourceEquals
(
resource
,
child
.
resource
))
{
if
(
isEqual
(
resource
.
toString
(),
child
.
resource
.
toString
()
))
{
return
child
;
}
if
(
child
.
isDirectory
&&
paths
.
isEqualOr
Parent
(
resource
.
fsPath
,
child
.
resource
.
fsPath
))
{
if
(
child
.
isDirectory
&&
is
Parent
(
resource
.
fsPath
,
child
.
resource
.
fsPath
))
{
return
child
.
find
(
resource
);
}
}
return
null
;
//Unable to find
}
private
fileResourceEquals
(
r1
:
URI
,
r2
:
URI
)
{
const
identityEquals
=
(
r1
.
toString
()
===
r2
.
toString
());
if
(
isLinux
||
identityEquals
)
{
return
identityEquals
;
}
return
r1
.
toString
().
toLowerCase
()
===
r2
.
toString
().
toLowerCase
();
}
}
/* A helper that can be used to show a placeholder when creating a new stat */
...
...
src/vs/workbench/services/files/node/watcher/common.ts
浏览文件 @
57c94f5b
...
...
@@ -6,8 +6,7 @@
'
use strict
'
;
import
uri
from
'
vs/base/common/uri
'
;
import
paths
=
require
(
'
vs/base/common/paths
'
);
import
{
FileChangeType
,
FileChangesEvent
}
from
'
vs/platform/files/common/files
'
;
import
{
FileChangeType
,
FileChangesEvent
,
isParent
}
from
'
vs/platform/files/common/files
'
;
export
interface
IRawFileChange
{
type
:
FileChangeType
;
...
...
@@ -106,7 +105,7 @@ class EventNormalizer {
}).
sort
((
e1
,
e2
)
=>
{
return
e1
.
path
.
length
-
e2
.
path
.
length
;
// shortest path first
}).
filter
(
e
=>
{
if
(
deletedPaths
.
some
(
d
=>
this
.
isParent
(
e
.
path
,
d
)))
{
if
(
deletedPaths
.
some
(
d
=>
isParent
(
e
.
path
,
d
)))
{
return
false
;
// DELETE is ignored if parent is deleted already
}
...
...
@@ -116,8 +115,4 @@ class EventNormalizer {
return
true
;
}).
concat
(
addedChangeEvents
);
}
private
isParent
(
p
:
string
,
candidate
:
string
):
boolean
{
return
p
.
indexOf
(
candidate
+
paths
.
nativeSep
)
===
0
;
}
}
\ No newline at end of file
src/vs/workbench/services/history/browser/history.ts
浏览文件 @
57c94f5b
...
...
@@ -9,7 +9,6 @@ import { TPromise } from 'vs/base/common/winjs.base';
import
errors
=
require
(
'
vs/base/common/errors
'
);
import
platform
=
require
(
'
vs/base/common/platform
'
);
import
nls
=
require
(
'
vs/nls
'
);
import
paths
=
require
(
'
vs/base/common/paths
'
);
import
URI
from
'
vs/base/common/uri
'
;
import
product
from
'
vs/platform/product
'
;
import
{
IEditor
as
IBaseEditor
}
from
'
vs/platform/editor/common/editor
'
;
...
...
@@ -18,7 +17,7 @@ import { BaseTextEditor } from 'vs/workbench/browser/parts/editor/textEditor';
import
{
IWorkbenchEditorService
}
from
'
vs/workbench/services/editor/common/editorService
'
;
import
{
IEventService
}
from
'
vs/platform/event/common/event
'
;
import
{
IHistoryService
}
from
'
vs/workbench/services/history/common/history
'
;
import
{
FileChangesEvent
,
EventType
}
from
'
vs/platform/files/common/files
'
;
import
{
FileChangesEvent
,
EventType
,
FileChangeType
}
from
'
vs/platform/files/common/files
'
;
import
{
Selection
}
from
'
vs/editor/common/core/selection
'
;
import
{
IEditorInput
,
ITextEditorOptions
,
IResourceInput
}
from
'
vs/platform/editor/common/editor
'
;
import
{
IWorkspaceContextService
}
from
'
vs/platform/workspace/common/workspace
'
;
...
...
@@ -290,9 +289,9 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
}
private
onFileChanges
(
e
:
FileChangesEvent
):
void
{
e
.
getDeleted
().
forEach
(
deleted
=>
{
this
.
remove
(
deleted
.
resourc
e
);
// remove from history files that got deleted or moved
}
);
if
(
e
.
gotDeleted
())
{
this
.
remove
(
e
);
// remove from history files that got deleted or moved
}
}
private
onEditorClosed
(
event
:
IGroupEvent
):
void
{
...
...
@@ -420,18 +419,18 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
}
public
remove
(
input
:
IEditorInput
|
IResourceInput
):
void
;
public
remove
(
input
:
URI
):
void
;
public
remove
(
arg1
:
IEditorInput
|
IResourceInput
|
URI
):
void
{
public
remove
(
input
:
FileChangesEvent
):
void
;
public
remove
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
):
void
{
this
.
removeFromHistory
(
arg1
);
this
.
removeFromStack
(
arg1
);
this
.
removeFromRecentlyClosedFiles
(
arg1
);
}
private
removeFromHistory
(
input
:
IEditorInput
|
IResourceInput
|
URI
,
index
?:
number
):
void
{
private
removeFromHistory
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
,
index
?:
number
):
void
{
this
.
ensureLoaded
();
if
(
typeof
index
!==
'
number
'
)
{
index
=
this
.
indexOf
(
input
);
index
=
this
.
indexOf
(
arg1
);
}
if
(
index
>=
0
)
{
...
...
@@ -439,10 +438,10 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
}
}
private
indexOf
(
input
:
IEditorInput
|
IResourceInput
|
URI
):
number
{
private
indexOf
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
):
number
{
for
(
let
i
=
0
;
i
<
this
.
history
.
length
;
i
++
)
{
const
entry
=
this
.
history
[
i
];
if
(
this
.
matches
(
input
,
entry
))
{
if
(
this
.
matches
(
arg1
,
entry
))
{
return
i
;
}
}
...
...
@@ -582,9 +581,9 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
return
s1
.
startLineNumber
===
s2
.
startLineNumber
;
// we consider the history entry same if we are on the same line
}
private
removeFromStack
(
input
:
IEditorInput
|
IResourceInput
|
URI
):
void
{
private
removeFromStack
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
):
void
{
this
.
stack
.
forEach
((
e
,
i
)
=>
{
if
(
this
.
matches
(
input
,
e
.
input
))
{
if
(
this
.
matches
(
arg1
,
e
.
input
))
{
this
.
stack
.
splice
(
i
,
1
);
if
(
this
.
index
>=
i
)
{
this
.
index
--
;
// reduce index if the element is before index
...
...
@@ -593,9 +592,9 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
});
}
private
removeFromRecentlyClosedFiles
(
input
:
IEditorInput
|
IResourceInput
|
URI
):
void
{
private
removeFromRecentlyClosedFiles
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
):
void
{
this
.
recentlyClosedFiles
.
forEach
((
e
,
i
)
=>
{
if
(
this
.
matchesFile
(
e
.
resource
,
input
))
{
if
(
this
.
matchesFile
(
e
.
resource
,
arg1
))
{
this
.
recentlyClosedFiles
.
splice
(
i
,
1
);
}
});
...
...
@@ -613,47 +612,47 @@ export class HistoryService extends BaseHistoryService implements IHistoryServic
return
group
.
getEditors
().
some
(
e
=>
this
.
matchesFile
(
resource
,
e
));
}
private
matches
(
inputA
:
IEditorInput
|
IResourceInput
|
URI
,
inputB
:
IEditorInput
|
IResourceInput
):
boolean
{
if
(
inputA
instanceof
URI
)
{
private
matches
(
arg1
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
,
inputB
:
IEditorInput
|
IResourceInput
):
boolean
{
if
(
arg1
instanceof
FileChangesEvent
)
{
if
(
inputB
instanceof
EditorInput
)
{
return
false
;
// we only support this for IResourceInput
}
const
resourceInputB
=
inputB
as
IResourceInput
;
return
resourceInputB
&&
paths
.
isEqualOrParent
(
resourceInputB
.
resource
.
toString
(),
inputA
.
toString
()
);
return
arg1
.
contains
(
resourceInputB
.
resource
,
FileChangeType
.
DELETED
);
}
if
(
inputA
instanceof
EditorInput
&&
inputB
instanceof
EditorInput
)
{
return
inputA
.
matches
(
inputB
);
if
(
arg1
instanceof
EditorInput
&&
inputB
instanceof
EditorInput
)
{
return
arg1
.
matches
(
inputB
);
}
if
(
inputA
instanceof
EditorInput
)
{
return
this
.
matchesFile
((
inputB
as
IResourceInput
).
resource
,
inputA
);
if
(
arg1
instanceof
EditorInput
)
{
return
this
.
matchesFile
((
inputB
as
IResourceInput
).
resource
,
arg1
);
}
if
(
inputB
instanceof
EditorInput
)
{
return
this
.
matchesFile
((
inputA
as
IResourceInput
).
resource
,
inputB
);
return
this
.
matchesFile
((
arg1
as
IResourceInput
).
resource
,
inputB
);
}
const
resourceInputA
=
inputA
as
IResourceInput
;
const
resourceInputA
=
arg1
as
IResourceInput
;
const
resourceInputB
=
inputB
as
IResourceInput
;
return
resourceInputA
&&
resourceInputB
&&
resourceInputA
.
resource
.
toString
()
===
resourceInputB
.
resource
.
toString
();
}
private
matchesFile
(
resource
:
URI
,
input
:
IEditorInput
|
IResourceInput
|
URI
):
boolean
{
if
(
input
instanceof
URI
)
{
return
paths
.
isEqualOrParent
(
resource
.
toString
(),
input
.
toString
()
);
private
matchesFile
(
resource
:
URI
,
arg2
:
IEditorInput
|
IResourceInput
|
FileChangesEvent
):
boolean
{
if
(
arg2
instanceof
FileChangesEvent
)
{
return
arg2
.
contains
(
resource
,
FileChangeType
.
DELETED
);
}
if
(
input
instanceof
EditorInput
)
{
const
fileInput
=
asFileEditorInput
(
input
);
if
(
arg2
instanceof
EditorInput
)
{
const
fileInput
=
asFileEditorInput
(
arg2
);
return
fileInput
&&
fileInput
.
getResource
().
toString
()
===
resource
.
toString
();
}
const
resourceInput
=
input
as
IResourceInput
;
const
resourceInput
=
arg2
as
IResourceInput
;
return
resourceInput
&&
resourceInput
.
resource
.
toString
()
===
resource
.
toString
();
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录