Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
e019e248
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,发现更多精彩内容 >>
提交
e019e248
编写于
6月 07, 2017
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
filters - simplify findAllMatches
上级
5ca7c3da
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
18 addition
and
17 deletion
+18
-17
src/vs/base/common/filters.ts
src/vs/base/common/filters.ts
+17
-17
src/vs/base/test/common/filters.test.ts
src/vs/base/test/common/filters.test.ts
+1
-0
未找到文件。
src/vs/base/common/filters.ts
浏览文件 @
e019e248
...
...
@@ -546,15 +546,16 @@ export function fuzzyScore(pattern: string, word: string): [number, number[]] {
console
.
log
(
printTable
(
_scores
,
pattern
,
patternLen
,
word
,
wordLen
));
}
let
bucket
:
[
number
,
number
[]][]
=
[];
findAllMatches
(
patternLen
,
patternLen
,
patternStartPos
,
wordLen
,
0
,
[],
bucket
,
false
);
_bucket
.
length
=
0
;
_patternStartPos
=
patternStartPos
;
_findAllMatches
(
patternLen
,
wordLen
,
0
,
[],
false
);
if
(
bucket
.
length
===
0
)
{
if
(
_
bucket
.
length
===
0
)
{
return
undefined
;
}
let
topMatch
=
bucket
.
shift
();
for
(
const
match
of
bucket
)
{
let
topMatch
=
_
bucket
.
shift
();
for
(
const
match
of
_
bucket
)
{
if
(
!
topMatch
||
topMatch
[
0
]
<
match
[
0
])
{
topMatch
=
match
;
}
...
...
@@ -565,9 +566,12 @@ export function fuzzyScore(pattern: string, word: string): [number, number[]] {
return
topMatch
;
}
function
findAllMatches
(
patternLen
:
number
,
patternPos
:
number
,
patternStartPos
:
number
,
wordPos
:
number
,
total
:
number
,
matches
:
number
[],
bucket
:
[
number
,
number
[]][],
lastMatched
:
boolean
):
void
{
let
_bucket
:
[
number
,
number
[]][]
=
[];
let
_patternStartPos
:
number
=
0
;
if
(
bucket
.
length
>=
10
||
total
<
-
25
)
{
function
_findAllMatches
(
patternPos
:
number
,
wordPos
:
number
,
total
:
number
,
matches
:
number
[],
lastMatched
:
boolean
):
void
{
if
(
_bucket
.
length
>=
10
||
total
<
-
25
)
{
// stop when having already 10 results, or
// when a potential alignment as already 5 gaps
return
;
...
...
@@ -575,7 +579,7 @@ function findAllMatches(patternLen: number, patternPos: number, patternStartPos:
let
simpleMatchCount
=
0
;
while
(
patternPos
>
patternStartPos
&&
wordPos
>
0
)
{
while
(
patternPos
>
_
patternStartPos
&&
wordPos
>
0
)
{
let
score
=
_scores
[
patternPos
][
wordPos
];
let
arrow
=
_arrows
[
patternPos
][
wordPos
];
...
...
@@ -595,11 +599,12 @@ function findAllMatches(patternLen: number, patternPos: number, patternStartPos:
if
(
arrow
&
Arrow
.
Left
)
{
// left
findAllMatches
(
pattern
Len
,
patternPos
,
patternStart
Pos
,
_
findAllMatches
(
patternPos
,
wordPos
-
1
,
matches
.
length
!==
0
?
total
-
1
:
total
,
matches
.
slice
(
0
),
bucket
,
lastMatched
matches
.
slice
(
0
),
lastMatched
);
}
...
...
@@ -622,11 +627,6 @@ function findAllMatches(patternLen: number, patternPos: number, patternStartPos:
}
}
if
(
matches
.
length
!==
patternLen
-
patternStartPos
)
{
// doesn't cover whole pattern
return
undefined
;
}
if
(
_scores
[
1
][
matches
[
0
]
+
1
]
===
1
)
{
// first match is weak
return
undefined
;
...
...
@@ -634,7 +634,7 @@ function findAllMatches(patternLen: number, patternPos: number, patternStartPos:
total
-=
wordPos
>=
3
?
9
:
wordPos
*
3
;
// late start penalty
bucket
.
push
([
total
,
matches
]);
_
bucket
.
push
([
total
,
matches
]);
}
...
...
src/vs/base/test/common/filters.test.ts
浏览文件 @
e019e248
...
...
@@ -248,6 +248,7 @@ suite('Filters', () => {
assertMatches
(
'
ccm
'
,
'
cacmelCase
'
,
'
^ca^c^melCase
'
,
fuzzyScore
);
assertMatches
(
'
bti
'
,
'
the_black_knight
'
,
undefined
,
fuzzyScore
);
assertMatches
(
'
ccm
'
,
'
camelCase
'
,
undefined
,
fuzzyScore
);
assertMatches
(
'
cmcm
'
,
'
camelCase
'
,
undefined
,
fuzzyScore
);
assertMatches
(
'
BK
'
,
'
the_black_knight
'
,
'
the_^black_^knight
'
,
fuzzyScore
);
assertMatches
(
'
KeyboardLayout=
'
,
'
KeyboardLayout
'
,
undefined
,
fuzzyScore
);
assertMatches
(
'
LLL
'
,
'
SVisualLoggerLogsList
'
,
'
SVisual^Logger^Logs^List
'
,
fuzzyScore
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录