Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
93cbbc5c
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,发现更多精彩内容 >>
提交
93cbbc5c
编写于
3月 04, 2020
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
es6 - less custom Iterator use
上级
8ea295e6
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
32 addition
and
39 deletion
+32
-39
src/vs/base/common/map.ts
src/vs/base/common/map.ts
+1
-1
src/vs/base/test/common/map.test.ts
src/vs/base/test/common/map.test.ts
+0
-1
src/vs/editor/common/services/editorSimpleWorker.ts
src/vs/editor/common/services/editorSimpleWorker.ts
+30
-32
src/vs/editor/test/common/services/editorSimpleWorker.test.ts
...vs/editor/test/common/services/editorSimpleWorker.test.ts
+1
-5
未找到文件。
src/vs/base/common/map.ts
浏览文件 @
93cbbc5c
...
...
@@ -5,7 +5,7 @@
import
{
URI
}
from
'
vs/base/common/uri
'
;
import
{
CharCode
}
from
'
vs/base/common/charCode
'
;
import
{
Iterator
,
IteratorResult
,
FIN
}
from
'
./iterator
'
;
import
{
FIN
}
from
'
./iterator
'
;
/**
* @deprecated ES6: use `[...SetOrMap.values()]`
...
...
src/vs/base/test/common/map.test.ts
浏览文件 @
93cbbc5c
...
...
@@ -6,7 +6,6 @@
import
{
ResourceMap
,
TernarySearchTree
,
PathIterator
,
StringIterator
,
LinkedMap
,
Touch
,
LRUCache
,
mapToSerializable
,
serializableToMap
}
from
'
vs/base/common/map
'
;
import
*
as
assert
from
'
assert
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
import
{
IteratorResult
}
from
'
vs/base/common/iterator
'
;
suite
(
'
Map
'
,
()
=>
{
...
...
src/vs/editor/common/services/editorSimpleWorker.ts
浏览文件 @
93cbbc5c
...
...
@@ -5,7 +5,6 @@
import
{
mergeSort
}
from
'
vs/base/common/arrays
'
;
import
{
stringDiff
}
from
'
vs/base/common/diff/diff
'
;
import
{
FIN
,
Iterator
,
IteratorResult
}
from
'
vs/base/common/iterator
'
;
import
{
IDisposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
globals
}
from
'
vs/base/common/platform
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
...
...
@@ -65,7 +64,7 @@ export interface ICommonModel extends ILinkComputerTarget, IMirrorModel {
getLineCount
():
number
;
getLineContent
(
lineNumber
:
number
):
string
;
getLineWords
(
lineNumber
:
number
,
wordDefinition
:
RegExp
):
IWordAtPosition
[];
createWordIterator
(
wordDefinition
:
RegExp
):
Iterator
<
string
>
;
words
(
wordDefinition
:
RegExp
):
Iterable
<
string
>
;
getWordUntilPosition
(
position
:
IPosition
,
wordDefinition
:
RegExp
):
IWordAtPosition
;
getValueInRange
(
range
:
IRange
):
string
;
getWordAtPosition
(
position
:
IPosition
,
wordDefinition
:
RegExp
):
Range
|
null
;
...
...
@@ -153,36 +152,37 @@ class MirrorModel extends BaseMirrorModel implements ICommonModel {
};
}
public
createWordIterator
(
wordDefinition
:
RegExp
):
Iterator
<
string
>
{
let
obj
:
{
done
:
false
;
value
:
string
;
};
public
words
(
wordDefinition
:
RegExp
):
Iterable
<
string
>
{
const
lines
=
this
.
_lines
;
const
wordenize
=
this
.
_wordenize
.
bind
(
this
);
let
lineNumber
=
0
;
let
lineText
:
string
;
let
lineText
=
''
;
let
wordRangesIdx
=
0
;
let
wordRanges
:
IWordRange
[]
=
[];
let
next
=
():
IteratorResult
<
string
>
=>
{
if
(
wordRangesIdx
<
wordRanges
.
length
)
{
const
value
=
lineText
.
substring
(
wordRanges
[
wordRangesIdx
].
start
,
wordRanges
[
wordRangesIdx
].
end
);
wordRangesIdx
+=
1
;
if
(
!
obj
)
{
obj
=
{
done
:
false
,
value
:
value
};
}
else
{
obj
.
value
=
value
;
}
return
obj
;
}
else
if
(
lineNumber
>=
this
.
_lines
.
length
)
{
return
FIN
;
}
else
{
lineText
=
this
.
_lines
[
lineNumber
];
wordRanges
=
this
.
_wordenize
(
lineText
,
wordDefinition
);
wordRangesIdx
=
0
;
lineNumber
+=
1
;
return
next
();
return
{
*
[
Symbol
.
iterator
]()
{
while
(
true
)
{
if
(
wordRangesIdx
<
wordRanges
.
length
)
{
const
value
=
lineText
.
substring
(
wordRanges
[
wordRangesIdx
].
start
,
wordRanges
[
wordRangesIdx
].
end
);
wordRangesIdx
+=
1
;
yield
value
;
}
else
{
if
(
lineNumber
<
lines
.
length
)
{
lineText
=
lines
[
lineNumber
];
wordRanges
=
wordenize
(
lineText
,
wordDefinition
);
wordRangesIdx
=
0
;
lineNumber
+=
1
;
}
else
{
break
;
}
}
}
}
};
return
{
next
};
}
public
getLineWords
(
lineNumber
:
number
,
wordDefinition
:
RegExp
):
IWordAtPosition
[]
{
...
...
@@ -545,12 +545,7 @@ export class EditorSimpleWorker implements IRequestHandler, IDisposable {
seen
.
add
(
model
.
getValueInRange
(
wordAt
));
}
for
(
let
iter
=
model
.
createWordIterator
(
wordDefRegExp
),
e
=
iter
.
next
();
!
e
.
done
&&
seen
.
size
<=
EditorSimpleWorker
.
_suggestionsLimit
;
e
=
iter
.
next
()
)
{
const
word
=
e
.
value
;
for
(
let
word
of
model
.
words
(
wordDefRegExp
))
{
if
(
seen
.
has
(
word
))
{
continue
;
}
...
...
@@ -559,6 +554,9 @@ export class EditorSimpleWorker implements IRequestHandler, IDisposable {
continue
;
}
words
.
push
(
word
);
if
(
seen
.
size
>
EditorSimpleWorker
.
_suggestionsLimit
)
{
break
;
}
}
return
words
;
}
...
...
src/vs/editor/test/common/services/editorSimpleWorker.test.ts
浏览文件 @
93cbbc5c
...
...
@@ -184,11 +184,7 @@ suite('EditorSimpleWorker', () => {
'
and now we are done
'
]);
let
words
:
string
[]
=
[];
for
(
let
iter
=
model
.
createWordIterator
(
/
[
a-z
]
+/img
),
e
=
iter
.
next
();
!
e
.
done
;
e
=
iter
.
next
())
{
words
.
push
(
e
.
value
);
}
let
words
:
string
[]
=
[...
model
.
words
(
/
[
a-z
]
+/img
)];
assert
.
deepEqual
(
words
,
[
'
one
'
,
'
line
'
,
'
two
'
,
'
line
'
,
'
past
'
,
'
empty
'
,
'
single
'
,
'
and
'
,
'
now
'
,
'
we
'
,
'
are
'
,
'
done
'
]);
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录