Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
73e34886
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,发现更多精彩内容 >>
提交
73e34886
编写于
3月 20, 2018
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
remote - move out search provider, #45000
上级
aa14020c
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
120 addition
and
74 deletion
+120
-74
src/vs/vscode.proposed.d.ts
src/vs/vscode.proposed.d.ts
+30
-22
src/vs/workbench/api/electron-browser/mainThreadFileSystem.ts
...vs/workbench/api/electron-browser/mainThreadFileSystem.ts
+53
-32
src/vs/workbench/api/node/extHost.api.impl.ts
src/vs/workbench/api/node/extHost.api.impl.ts
+5
-2
src/vs/workbench/api/node/extHost.protocol.ts
src/vs/workbench/api/node/extHost.protocol.ts
+2
-1
src/vs/workbench/api/node/extHostFileSystem.ts
src/vs/workbench/api/node/extHostFileSystem.ts
+30
-17
未找到文件。
src/vs/vscode.proposed.d.ts
浏览文件 @
73e34886
...
...
@@ -203,24 +203,6 @@ declare module 'vscode' {
type
:
FileType
;
}
export
interface
TextSearchQuery
{
pattern
:
string
;
isRegex
?:
boolean
;
isCaseSensitive
?:
boolean
;
isWordMatch
?:
boolean
;
}
export
interface
TextSearchOptions
{
includes
:
GlobPattern
[];
excludes
:
GlobPattern
[];
}
export
interface
TextSearchResult
{
uri
:
Uri
;
range
:
Range
;
preview
:
{
leading
:
string
,
matching
:
string
,
trailing
:
string
};
}
// todo@joh discover files etc
// todo@joh CancellationToken everywhere
// todo@joh add open/close calls?
...
...
@@ -265,15 +247,41 @@ declare module 'vscode' {
// todo@remote
// create(resource: Uri): Thenable<FileStat>;
}
export
namespace
workspace
{
export
function
registerFileSystemProvider
(
scheme
:
string
,
provider
:
FileSystemProvider
):
Disposable
;
}
// find files by names
// todo@joh, move into its own provider
findFiles
?(
query
:
string
,
progress
:
Progress
<
Uri
>
,
token
:
CancellationToken
):
Thenable
<
void
>
;
//#endregion
//#region Joh: remote, search provider
export
interface
TextSearchQuery
{
pattern
:
string
;
isRegex
?:
boolean
;
isCaseSensitive
?:
boolean
;
isWordMatch
?:
boolean
;
}
export
interface
TextSearchOptions
{
includes
:
GlobPattern
[];
excludes
:
GlobPattern
[];
}
export
interface
TextSearchResult
{
uri
:
Uri
;
range
:
Range
;
preview
:
{
leading
:
string
,
matching
:
string
,
trailing
:
string
};
}
export
interface
SearchProvider
{
provideFileSearchResults
?(
query
:
string
,
progress
:
Progress
<
Uri
>
,
token
:
CancellationToken
):
Thenable
<
void
>
;
provideTextSearchResults
?(
query
:
TextSearchQuery
,
options
:
TextSearchOptions
,
progress
:
Progress
<
TextSearchResult
>
,
token
:
CancellationToken
):
Thenable
<
void
>
;
}
export
namespace
workspace
{
export
function
register
FileSystemProvider
(
scheme
:
string
,
provider
:
FileSystem
Provider
):
Disposable
;
export
function
register
SearchProvider
(
scheme
:
string
,
provider
:
Search
Provider
):
Disposable
;
}
//#endregion
...
...
src/vs/workbench/api/electron-browser/mainThreadFileSystem.ts
浏览文件 @
73e34886
...
...
@@ -20,7 +20,8 @@ import { isFalsyOrEmpty } from 'vs/base/common/arrays';
export
class
MainThreadFileSystem
implements
MainThreadFileSystemShape
{
private
readonly
_proxy
:
ExtHostFileSystemShape
;
private
readonly
_provider
=
new
Map
<
number
,
RemoteFileSystemProvider
>
();
private
readonly
_fileProvider
=
new
Map
<
number
,
RemoteFileSystemProvider
>
();
private
readonly
_searchProvider
=
new
Map
<
number
,
RemoteSearchProvider
>
();
constructor
(
extHostContext
:
IExtHostContext
,
...
...
@@ -31,31 +32,38 @@ export class MainThreadFileSystem implements MainThreadFileSystemShape {
}
dispose
():
void
{
this
.
_
p
rovider
.
forEach
(
value
=>
dispose
());
this
.
_
p
rovider
.
clear
();
this
.
_
fileP
rovider
.
forEach
(
value
=>
dispose
());
this
.
_
fileP
rovider
.
clear
();
}
$registerFileSystemProvider
(
handle
:
number
,
scheme
:
string
):
void
{
this
.
_
provider
.
set
(
handle
,
new
RemoteFileSystemProvider
(
this
.
_fileService
,
this
.
_search
Service
,
scheme
,
handle
,
this
.
_proxy
));
this
.
_
fileProvider
.
set
(
handle
,
new
RemoteFileSystemProvider
(
this
.
_file
Service
,
scheme
,
handle
,
this
.
_proxy
));
}
$unregisterFileSystemProvider
(
handle
:
number
):
void
{
dispose
(
this
.
_provider
.
get
(
handle
));
this
.
_provider
.
delete
(
handle
);
$registerSearchProvider
(
handle
:
number
,
scheme
:
string
):
void
{
this
.
_searchProvider
.
set
(
handle
,
new
RemoteSearchProvider
(
this
.
_searchService
,
scheme
,
handle
,
this
.
_proxy
));
}
$unregisterProvider
(
handle
:
number
):
void
{
dispose
(
this
.
_fileProvider
.
get
(
handle
));
this
.
_fileProvider
.
delete
(
handle
);
dispose
(
this
.
_searchProvider
.
get
(
handle
));
this
.
_searchProvider
.
delete
(
handle
);
}
$onFileSystemChange
(
handle
:
number
,
changes
:
IFileChangeDto
[]):
void
{
this
.
_
p
rovider
.
get
(
handle
).
$onFileSystemChange
(
changes
);
this
.
_
fileP
rovider
.
get
(
handle
).
$onFileSystemChange
(
changes
);
}
$reportFileChunk
(
handle
:
number
,
session
:
number
,
chunk
:
number
[]):
void
{
this
.
_
p
rovider
.
get
(
handle
).
reportFileChunk
(
session
,
chunk
);
this
.
_
fileP
rovider
.
get
(
handle
).
reportFileChunk
(
session
,
chunk
);
}
// --- search
$handleFindMatch
(
handle
:
number
,
session
,
data
:
UriComponents
|
[
UriComponents
,
ILineMatch
]):
void
{
this
.
_
p
rovider
.
get
(
handle
).
handleFindMatch
(
session
,
data
);
this
.
_
searchP
rovider
.
get
(
handle
).
handleFindMatch
(
session
,
data
);
}
}
...
...
@@ -71,40 +79,22 @@ class FileReadOperation {
}
}
class
SearchOperation
{
private
static
_idPool
=
0
;
constructor
(
readonly
progress
:
(
match
:
IFileMatch
)
=>
any
,
readonly
id
:
number
=
++
SearchOperation
.
_idPool
,
readonly
matches
=
new
Map
<
string
,
IFileMatch
>
()
)
{
//
}
}
class
RemoteFileSystemProvider
implements
IFileSystemProvider
,
ISearchResultProvider
{
class
RemoteFileSystemProvider
implements
IFileSystemProvider
{
private
readonly
_onDidChange
=
new
Emitter
<
IFileChange
[]
>
();
private
readonly
_registrations
:
IDisposable
[];
private
readonly
_reads
=
new
Map
<
number
,
FileReadOperation
>
();
private
readonly
_searches
=
new
Map
<
number
,
SearchOperation
>
();
readonly
onDidChange
:
Event
<
IFileChange
[]
>
=
this
.
_onDidChange
.
event
;
constructor
(
fileService
:
IFileService
,
searchService
:
ISearchService
,
private
readonly
_scheme
:
string
,
scheme
:
string
,
private
readonly
_handle
:
number
,
private
readonly
_proxy
:
ExtHostFileSystemShape
)
{
this
.
_registrations
=
[
fileService
.
registerProvider
(
_scheme
,
this
),
searchService
.
registerSearchResultProvider
(
this
),
];
this
.
_registrations
=
[
fileService
.
registerProvider
(
scheme
,
this
)];
}
dispose
():
void
{
...
...
@@ -159,8 +149,39 @@ class RemoteFileSystemProvider implements IFileSystemProvider, ISearchResultProv
rmdir
(
resource
:
URI
):
TPromise
<
void
,
any
>
{
return
this
.
_proxy
.
$rmdir
(
this
.
_handle
,
resource
);
}
}
// --- search
class
SearchOperation
{
private
static
_idPool
=
0
;
constructor
(
readonly
progress
:
(
match
:
IFileMatch
)
=>
any
,
readonly
id
:
number
=
++
SearchOperation
.
_idPool
,
readonly
matches
=
new
Map
<
string
,
IFileMatch
>
()
)
{
//
}
}
class
RemoteSearchProvider
implements
ISearchResultProvider
{
private
readonly
_registrations
:
IDisposable
[];
private
readonly
_searches
=
new
Map
<
number
,
SearchOperation
>
();
constructor
(
searchService
:
ISearchService
,
private
readonly
_scheme
:
string
,
private
readonly
_handle
:
number
,
private
readonly
_proxy
:
ExtHostFileSystemShape
)
{
this
.
_registrations
=
[
searchService
.
registerSearchResultProvider
(
this
)];
}
dispose
():
void
{
dispose
(
this
.
_registrations
);
}
search
(
query
:
ISearchQuery
):
PPromise
<
ISearchComplete
,
ISearchProgressItem
>
{
...
...
src/vs/workbench/api/node/extHost.api.impl.ts
浏览文件 @
73e34886
...
...
@@ -517,8 +517,11 @@ export function createApiFactory(
registerTaskProvider
:
(
type
:
string
,
provider
:
vscode
.
TaskProvider
)
=>
{
return
extHostTask
.
registerTaskProvider
(
extension
,
provider
);
},
registerFileSystemProvider
:
proposedApiFunction
(
extension
,
(
authority
,
provider
)
=>
{
return
extHostFileSystem
.
registerFileSystemProvider
(
authority
,
provider
);
registerFileSystemProvider
:
proposedApiFunction
(
extension
,
(
scheme
,
provider
)
=>
{
return
extHostFileSystem
.
registerFileSystemProvider
(
scheme
,
provider
);
}),
registerSearchProvider
:
proposedApiFunction
(
extension
,
(
scheme
,
provider
)
=>
{
return
extHostFileSystem
.
registerSearchProvider
(
scheme
,
provider
);
})
};
...
...
src/vs/workbench/api/node/extHost.protocol.ts
浏览文件 @
73e34886
...
...
@@ -380,7 +380,8 @@ export interface IFileChangeDto {
export
interface
MainThreadFileSystemShape
extends
IDisposable
{
$registerFileSystemProvider
(
handle
:
number
,
scheme
:
string
):
void
;
$unregisterFileSystemProvider
(
handle
:
number
):
void
;
$registerSearchProvider
(
handle
:
number
,
scheme
:
string
):
void
;
$unregisterProvider
(
handle
:
number
):
void
;
$onFileSystemChange
(
handle
:
number
,
resource
:
IFileChangeDto
[]):
void
;
$reportFileChunk
(
handle
:
number
,
session
:
number
,
chunk
:
number
[]
|
null
):
void
;
...
...
src/vs/workbench/api/node/extHostFileSystem.ts
浏览文件 @
73e34886
...
...
@@ -58,7 +58,8 @@ class FsLinkProvider implements vscode.DocumentLinkProvider {
export
class
ExtHostFileSystem
implements
ExtHostFileSystemShape
{
private
readonly
_proxy
:
MainThreadFileSystemShape
;
private
readonly
_provider
=
new
Map
<
number
,
vscode
.
FileSystemProvider
>
();
private
readonly
_fsProvider
=
new
Map
<
number
,
vscode
.
FileSystemProvider
>
();
private
readonly
_searchProvider
=
new
Map
<
number
,
vscode
.
SearchProvider
>
();
private
readonly
_linkProvider
=
new
FsLinkProvider
();
private
_handlePool
:
number
=
0
;
...
...
@@ -71,7 +72,7 @@ export class ExtHostFileSystem implements ExtHostFileSystemShape {
registerFileSystemProvider
(
scheme
:
string
,
provider
:
vscode
.
FileSystemProvider
)
{
const
handle
=
this
.
_handlePool
++
;
this
.
_linkProvider
.
add
(
scheme
);
this
.
_
p
rovider
.
set
(
handle
,
provider
);
this
.
_
fsP
rovider
.
set
(
handle
,
provider
);
this
.
_proxy
.
$registerFileSystemProvider
(
handle
,
scheme
);
let
reg
:
IDisposable
;
if
(
provider
.
onDidChange
)
{
...
...
@@ -83,17 +84,29 @@ export class ExtHostFileSystem implements ExtHostFileSystemShape {
reg
.
dispose
();
}
this
.
_linkProvider
.
delete
(
scheme
);
this
.
_provider
.
delete
(
handle
);
this
.
_proxy
.
$unregisterFileSystemProvider
(
handle
);
this
.
_fsProvider
.
delete
(
handle
);
this
.
_proxy
.
$unregisterProvider
(
handle
);
}
};
}
registerSearchProvider
(
scheme
:
string
,
provider
:
vscode
.
SearchProvider
)
{
const
handle
=
this
.
_handlePool
++
;
this
.
_searchProvider
.
set
(
handle
,
provider
);
this
.
_proxy
.
$registerSearchProvider
(
handle
,
scheme
);
return
{
dispose
:
()
=>
{
this
.
_searchProvider
.
delete
(
handle
);
this
.
_proxy
.
$unregisterProvider
(
handle
);
}
};
}
$utimes
(
handle
:
number
,
resource
:
UriComponents
,
mtime
:
number
,
atime
:
number
):
TPromise
<
IStat
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
utimes
(
URI
.
revive
(
resource
),
mtime
,
atime
));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
utimes
(
URI
.
revive
(
resource
),
mtime
,
atime
));
}
$stat
(
handle
:
number
,
resource
:
UriComponents
):
TPromise
<
IStat
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
stat
(
URI
.
revive
(
resource
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
stat
(
URI
.
revive
(
resource
)));
}
$read
(
handle
:
number
,
session
:
number
,
offset
:
number
,
count
:
number
,
resource
:
UriComponents
):
TPromise
<
number
>
{
const
progress
=
{
...
...
@@ -101,29 +114,29 @@ export class ExtHostFileSystem implements ExtHostFileSystemShape {
this
.
_proxy
.
$reportFileChunk
(
handle
,
session
,
[].
slice
.
call
(
chunk
));
}
};
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
read
(
URI
.
revive
(
resource
),
offset
,
count
,
progress
));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
read
(
URI
.
revive
(
resource
),
offset
,
count
,
progress
));
}
$write
(
handle
:
number
,
resource
:
UriComponents
,
content
:
number
[]):
TPromise
<
void
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
write
(
URI
.
revive
(
resource
),
Buffer
.
from
(
content
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
write
(
URI
.
revive
(
resource
),
Buffer
.
from
(
content
)));
}
$unlink
(
handle
:
number
,
resource
:
UriComponents
):
TPromise
<
void
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
unlink
(
URI
.
revive
(
resource
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
unlink
(
URI
.
revive
(
resource
)));
}
$move
(
handle
:
number
,
resource
:
UriComponents
,
target
:
UriComponents
):
TPromise
<
IStat
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
move
(
URI
.
revive
(
resource
),
URI
.
revive
(
target
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
move
(
URI
.
revive
(
resource
),
URI
.
revive
(
target
)));
}
$mkdir
(
handle
:
number
,
resource
:
UriComponents
):
TPromise
<
IStat
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
mkdir
(
URI
.
revive
(
resource
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
mkdir
(
URI
.
revive
(
resource
)));
}
$readdir
(
handle
:
number
,
resource
:
UriComponents
):
TPromise
<
[
UriComponents
,
IStat
][],
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
readdir
(
URI
.
revive
(
resource
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
readdir
(
URI
.
revive
(
resource
)));
}
$rmdir
(
handle
:
number
,
resource
:
UriComponents
):
TPromise
<
void
,
any
>
{
return
asWinJsPromise
(
token
=>
this
.
_
p
rovider
.
get
(
handle
).
rmdir
(
URI
.
revive
(
resource
)));
return
asWinJsPromise
(
token
=>
this
.
_
fsP
rovider
.
get
(
handle
).
rmdir
(
URI
.
revive
(
resource
)));
}
$findFiles
(
handle
:
number
,
session
:
number
,
query
:
string
):
TPromise
<
void
>
{
const
provider
=
this
.
_
p
rovider
.
get
(
handle
);
if
(
!
provider
.
findFile
s
)
{
const
provider
=
this
.
_
searchP
rovider
.
get
(
handle
);
if
(
!
provider
.
provideFileSearchResult
s
)
{
return
TPromise
.
as
(
undefined
);
}
const
progress
=
{
...
...
@@ -131,10 +144,10 @@ export class ExtHostFileSystem implements ExtHostFileSystemShape {
this
.
_proxy
.
$handleFindMatch
(
handle
,
session
,
uri
);
}
};
return
asWinJsPromise
(
token
=>
provider
.
findFile
s
(
query
,
progress
,
token
));
return
asWinJsPromise
(
token
=>
provider
.
provideFileSearchResult
s
(
query
,
progress
,
token
));
}
$provideTextSearchResults
(
handle
:
number
,
session
:
number
,
pattern
:
IPatternInfo
,
options
:
{
includes
:
string
[],
excludes
:
string
[]
}):
TPromise
<
void
>
{
const
provider
=
this
.
_
p
rovider
.
get
(
handle
);
const
provider
=
this
.
_
searchP
rovider
.
get
(
handle
);
if
(
!
provider
.
provideTextSearchResults
)
{
return
TPromise
.
as
(
undefined
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录