Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
ba9f4099
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ba9f4099
编写于
11月 07, 2018
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix #62335
上级
a6fe9800
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
34 addition
and
5 deletion
+34
-5
src/vs/workbench/parts/snippets/electron-browser/snippetCompletionProvider.ts
...ts/snippets/electron-browser/snippetCompletionProvider.ts
+15
-5
src/vs/workbench/parts/snippets/test/electron-browser/snippetsService.test.ts
...ts/snippets/test/electron-browser/snippetsService.test.ts
+19
-0
未找到文件。
src/vs/workbench/parts/snippets/electron-browser/snippetCompletionProvider.ts
浏览文件 @
ba9f4099
...
...
@@ -88,6 +88,8 @@ export class SnippetCompletionProvider implements CompletionItemProvider {
let
pos
=
{
lineNumber
:
position
.
lineNumber
,
column
:
1
};
let
lineOffsets
:
number
[]
=
[];
let
linePrefixLow
=
model
.
getLineContent
(
position
.
lineNumber
).
substr
(
0
,
position
.
column
-
1
).
toLowerCase
();
let
endsInWhitespace
=
linePrefixLow
.
match
(
/
\s
$/
);
while
(
pos
.
column
<
position
.
column
)
{
let
word
=
model
.
getWordAtPosition
(
pos
);
if
(
word
)
{
...
...
@@ -108,20 +110,28 @@ export class SnippetCompletionProvider implements CompletionItemProvider {
pos
.
column
+=
1
;
}
}
if
(
lineOffsets
.
length
===
0
)
{
// no interesting spans found -> pick all snippets
suggestions
=
snippets
.
map
(
snippet
=>
new
SnippetCompletion
(
snippet
,
Range
.
fromPositions
(
position
)));
}
else
{
let
consumed
=
new
Set
<
Snippet
>
();
let
availableSnippets
=
new
Set
<
Snippet
>
();
snippets
.
forEach
(
availableSnippets
.
add
,
availableSnippets
);
suggestions
=
[];
for
(
let
start
of
lineOffsets
)
{
for
(
const
snippet
of
snippets
)
{
if
(
!
consumed
.
has
(
snippet
)
&&
matches
(
linePrefixLow
,
start
,
snippet
.
prefixLow
,
0
))
{
availableSnippets
.
forEach
(
snippet
=>
{
if
(
matches
(
linePrefixLow
,
start
,
snippet
.
prefixLow
,
0
))
{
suggestions
.
push
(
new
SnippetCompletion
(
snippet
,
Range
.
fromPositions
(
position
.
delta
(
0
,
-
(
linePrefixLow
.
length
-
start
)),
position
)));
consumed
.
add
(
snippet
);
availableSnippets
.
delete
(
snippet
);
}
}
});
}
if
(
endsInWhitespace
)
{
// add remaing snippets when the current prefix ends in whitespace
availableSnippets
.
forEach
(
snippet
=>
{
suggestions
.
push
(
new
SnippetCompletion
(
snippet
,
Range
.
fromPositions
(
position
)));
});
}
}
...
...
src/vs/workbench/parts/snippets/test/electron-browser/snippetsService.test.ts
浏览文件 @
ba9f4099
...
...
@@ -352,4 +352,23 @@ suite('SnippetsService', function () {
toDispose
.
dispose
();
});
test
(
'
No snippets shown when triggering completions at whitespace on line that already has text #62335
'
,
async
function
()
{
snippetService
=
new
SimpleSnippetService
([
new
Snippet
(
[
'
fooLang
'
],
'
bug
'
,
'
bug
'
,
''
,
'
second
'
,
''
,
SnippetSource
.
User
)]);
const
provider
=
new
SnippetCompletionProvider
(
modeService
,
snippetService
);
let
model
=
TextModel
.
createFromString
(
'
a
'
,
undefined
,
modeService
.
getLanguageIdentifier
(
'
fooLang
'
));
let
result
=
await
provider
.
provideCompletionItems
(
model
,
new
Position
(
1
,
3
));
assert
.
equal
(
result
.
suggestions
.
length
,
1
);
});
});
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录