Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
055553ab
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,发现更多精彩内容 >>
提交
055553ab
编写于
3月 18, 2020
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
quick access - wrap up anything provider
上级
d339e9b4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
24 addition
and
19 deletion
+24
-19
src/vs/workbench/contrib/search/browser/anythingQuickAccess.ts
...s/workbench/contrib/search/browser/anythingQuickAccess.ts
+16
-15
src/vs/workbench/contrib/search/browser/symbolsQuickAccess.ts
...vs/workbench/contrib/search/browser/symbolsQuickAccess.ts
+8
-4
未找到文件。
src/vs/workbench/contrib/search/browser/anythingQuickAccess.ts
浏览文件 @
055553ab
...
...
@@ -50,7 +50,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
private
static
readonly
MAX_RESULTS
=
512
;
private
s
corerCache
:
ScorerCache
=
Object
.
create
(
null
);
private
s
tatic
readonly
TYPING_SEARCH_DELAY
=
200
;
// this delay accommodates for the user typing a word and then stops typing to start searching
private
readonly
pickState
=
new
class
{
scorerCache
:
ScorerCache
=
Object
.
create
(
null
);
...
...
@@ -167,7 +167,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
// Sort top 512 items by score
const
sortedAnythingPicks
=
top
(
[...
filePicks
,
...
symbolPicks
],
(
anyPickA
,
anyPickB
)
=>
compareItemsByScore
(
anyPickA
,
anyPickB
,
query
,
true
,
quickPickItemScorerAccessor
,
this
.
scorerCache
),
(
anyPickA
,
anyPickB
)
=>
compareItemsByScore
(
anyPickA
,
anyPickB
,
query
,
true
,
quickPickItemScorerAccessor
,
this
.
pickState
.
scorerCache
),
AnythingQuickAccessProvider
.
MAX_RESULTS
);
...
...
@@ -177,7 +177,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
continue
;
// preserve any highlights we got already (e.g. symbols)
}
const
{
labelMatch
,
descriptionMatch
}
=
scoreItem
(
anythingPick
,
query
,
true
,
quickPickItemScorerAccessor
,
this
.
scorerCache
);
const
{
labelMatch
,
descriptionMatch
}
=
scoreItem
(
anythingPick
,
query
,
true
,
quickPickItemScorerAccessor
,
this
.
pickState
.
scorerCache
);
anythingPick
.
highlights
=
{
label
:
labelMatch
,
...
...
@@ -216,7 +216,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
const
editorHistoryPick
=
this
.
createAnythingPick
(
editor
,
range
);
const
{
score
,
labelMatch
,
descriptionMatch
}
=
scoreItem
(
editorHistoryPick
,
query
,
false
,
editorHistoryScorerAccessor
,
this
.
scorerCache
);
const
{
score
,
labelMatch
,
descriptionMatch
}
=
scoreItem
(
editorHistoryPick
,
query
,
false
,
editorHistoryScorerAccessor
,
this
.
pickState
.
scorerCache
);
if
(
!
score
)
{
continue
;
// exclude editors not matching query
}
...
...
@@ -229,7 +229,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
editorHistoryPicks
.
push
(
editorHistoryPick
);
}
return
editorHistoryPicks
.
sort
((
editorA
,
editorB
)
=>
compareItemsByScore
(
editorA
,
editorB
,
query
,
false
,
editorHistoryScorerAccessor
,
this
.
scorerCache
,
()
=>
-
1
));
return
editorHistoryPicks
.
sort
((
editorA
,
editorB
)
=>
compareItemsByScore
(
editorA
,
editorB
,
query
,
false
,
editorHistoryScorerAccessor
,
this
.
pickState
.
scorerCache
,
()
=>
-
1
));
}
//#endregion
...
...
@@ -237,9 +237,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
//#region File Search
private
static
readonly
FILE_QUERY_DELAY
=
200
;
// this delay accommodates for the user typing a word and then stops typing to start searching
private
fileQueryDelayer
=
this
.
_register
(
new
ThrottledDelayer
<
IFileMatch
[]
>
(
AnythingQuickAccessProvider
.
FILE_QUERY_DELAY
));
private
fileQueryDelayer
=
this
.
_register
(
new
ThrottledDelayer
<
IFileMatch
[]
>
(
AnythingQuickAccessProvider
.
TYPING_SEARCH_DELAY
));
private
fileQueryBuilder
=
this
.
instantiationService
.
createInstance
(
QueryBuilder
);
...
...
@@ -274,7 +272,13 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
if
(
this
.
pickState
.
fileQueryCache
?.
isLoaded
)
{
fileMatches
=
await
this
.
doFileSearch
(
query
,
token
);
}
else
{
fileMatches
=
await
this
.
fileQueryDelayer
.
trigger
(()
=>
this
.
doFileSearch
(
query
,
token
));
fileMatches
=
await
this
.
fileQueryDelayer
.
trigger
(
async
()
=>
{
if
(
token
.
isCancellationRequested
)
{
return
[];
}
return
this
.
doFileSearch
(
query
,
token
);
});
}
}
...
...
@@ -289,10 +293,6 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
}
private
async
doFileSearch
(
query
:
IPreparedQuery
,
token
:
CancellationToken
):
Promise
<
IFileMatch
[]
>
{
if
(
token
.
isCancellationRequested
)
{
return
[];
}
const
{
results
}
=
await
this
.
searchService
.
fileSearch
(
this
.
fileQueryBuilder
.
file
(
this
.
contextService
.
getWorkspace
().
folders
,
...
...
@@ -308,7 +308,7 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
private
getFileQueryOptions
(
input
:
{
filePattern
?:
string
,
cacheKey
?:
string
,
maxResults
?:
number
}):
IFileQueryBuilderOptions
{
const
fileQueryOptions
:
IFileQueryBuilderOptions
=
{
_reason
:
'
openFileHandler
'
,
_reason
:
'
openFileHandler
'
,
// used for telemetry - do not change
extraFileResources
:
this
.
instantiationService
.
invokeFunction
(
getOutOfWorkspaceEditorResources
),
filePattern
:
input
.
filePattern
||
''
,
cacheKey
:
input
.
cacheKey
,
...
...
@@ -367,7 +367,8 @@ export class AnythingQuickAccessProvider extends PickerQuickAccessProvider<IAnyt
}
// Delegate to the existing symbols quick access
return
this
.
symbolsQuickAccess
.
getSymbolPicks
(
query
.
value
,
token
,
{
skipLocal
:
true
,
skipSorting
:
true
});
// but skip local results and also do not sort
return
this
.
symbolsQuickAccess
.
getSymbolPicks
(
query
.
value
,
{
skipLocal
:
true
,
skipSorting
:
true
,
delay
:
AnythingQuickAccessProvider
.
TYPING_SEARCH_DELAY
},
token
);
}
//#endregion
...
...
src/vs/workbench/contrib/search/browser/symbolsQuickAccess.ts
浏览文件 @
055553ab
...
...
@@ -61,16 +61,20 @@ export class SymbolsQuickAccessProvider extends PickerQuickAccessProvider<ISymbo
}
protected
getPicks
(
filter
:
string
,
disposables
:
DisposableStore
,
token
:
CancellationToken
):
Promise
<
Array
<
ISymbolQuickPickItem
>>
{
return
this
.
getSymbolPicks
(
filter
,
undefined
,
token
);
}
async
getSymbolPicks
(
filter
:
string
,
options
:
{
skipLocal
:
boolean
,
skipSorting
:
boolean
,
delay
:
number
}
|
undefined
,
token
:
CancellationToken
):
Promise
<
Array
<
ISymbolQuickPickItem
>>
{
return
this
.
delayer
.
trigger
(
async
()
=>
{
if
(
token
.
isCancellationRequested
)
{
return
[];
}
return
this
.
getSymbolPicks
(
filter
,
token
);
});
return
this
.
doGetSymbolPicks
(
filter
,
options
,
token
);
}
,
options
?.
delay
);
}
async
getSymbolPicks
(
filter
:
string
,
token
:
CancellationToken
,
options
?:
{
skipLocal
:
boolean
,
skipSorting
:
boolean
}
):
Promise
<
Array
<
ISymbolQuickPickItem
>>
{
private
async
doGetSymbolPicks
(
filter
:
string
,
options
:
{
skipLocal
:
boolean
,
skipSorting
:
boolean
}
|
undefined
,
token
:
CancellationToken
):
Promise
<
Array
<
ISymbolQuickPickItem
>>
{
const
workspaceSymbols
=
await
getWorkspaceSymbols
(
filter
,
token
);
if
(
token
.
isCancellationRequested
)
{
return
[];
...
...
@@ -140,7 +144,7 @@ export class SymbolsQuickAccessProvider extends PickerQuickAccessProvider<ISymbo
symbolPicks
.
push
({
symbol
,
resource
:
symbol
.
location
.
u
ri
,
resource
:
symbol
U
ri
,
score
:
symbolScore
,
label
:
symbolLabelWithIcon
,
ariaLabel
:
localize
(
'
symbolAriaLabel
'
,
"
{0}, symbols picker
"
,
symbolLabel
),
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录