Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
4ae550eb
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,发现更多精彩内容 >>
提交
4ae550eb
编写于
2月 23, 2017
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use completion item to trigger jsdoc item
上级
d967515b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
2 addition
and
35 deletion
+2
-35
extensions/typescript/src/features/jsDocCompletionProvider.ts
...nsions/typescript/src/features/jsDocCompletionProvider.ts
+1
-34
extensions/typescript/src/typescriptMain.ts
extensions/typescript/src/typescriptMain.ts
+1
-1
未找到文件。
extensions/typescript/src/features/jsDocCompletionProvider.ts
浏览文件 @
4ae550eb
...
...
@@ -35,25 +35,6 @@ export default class JsDocCompletionHelper implements CompletionItemProvider {
constructor
(
private
client
:
ITypescriptServiceClient
,
)
{
window
.
onDidChangeTextEditorSelection
(
e
=>
{
if
(
e
.
textEditor
.
document
.
languageId
!==
'
typescript
'
&&
e
.
textEditor
.
document
.
languageId
!==
'
typescriptreact
'
&&
e
.
textEditor
.
document
.
languageId
!==
'
javascript
'
&&
e
.
textEditor
.
document
.
languageId
!==
'
javascriptreact
'
)
{
return
;
}
const
selection
=
e
.
selections
[
0
];
if
(
!
selection
.
start
.
isEqual
(
selection
.
end
))
{
return
;
}
if
(
this
.
shouldAutoShowJsDocSuggestion
(
e
.
textEditor
.
document
,
selection
.
start
))
{
return
commands
.
executeCommand
(
'
editor.action.triggerSuggest
'
);
}
return
;
});
commands
.
registerCommand
(
tryCompleteJsDocCommand
,
(
file
:
Uri
,
position
:
Position
)
=>
this
.
tryCompleteJsDoc
(
file
,
position
));
...
...
@@ -69,7 +50,7 @@ export default class JsDocCompletionHelper implements CompletionItemProvider {
// or could be the opening of a comment
const
line
=
document
.
lineAt
(
position
.
line
).
text
;
const
prefix
=
line
.
slice
(
0
,
position
.
character
);
if
(
prefix
.
match
(
/
\/\*
+
\s
*$/
)
||
prefix
.
match
(
/^
\s
*
\/?\*
*
\s
*$/
))
{
if
(
prefix
.
match
(
/
^
\s
*$|
\/\*\*\s
*$|^
\s
*
\/\*\*
+
\s
*$/
))
{
return
[
new
JsDocCompletionItem
(
document
.
uri
,
position
)];
}
return
[];
...
...
@@ -79,20 +60,6 @@ export default class JsDocCompletionHelper implements CompletionItemProvider {
return
item
;
}
private
shouldAutoShowJsDocSuggestion
(
document
:
TextDocument
,
position
:
Position
):
boolean
{
const
line
=
document
.
lineAt
(
position
.
line
).
text
;
// Ensure line starts with '/**' then cursor
const
prefix
=
line
.
slice
(
0
,
position
.
character
).
match
(
/^
\s
*
(\/\*\*
+
)
$/
);
if
(
prefix
===
null
)
{
return
false
;
}
// Ensure there is no content after the cursor besides the end of the comment
const
suffix
=
line
.
slice
(
position
.
character
).
match
(
/^
\s
*
\*
+
\/
$/
);
return
suffix
!==
null
;
}
/**
* Try to insert a jsdoc comment, using a template provide by typescript
* if possible, otherwise falling back to a default comment format.
...
...
extensions/typescript/src/typescriptMain.ts
浏览文件 @
4ae550eb
...
...
@@ -104,7 +104,7 @@ export function activate(context: ExtensionContext): void {
}));
context
.
subscriptions
.
push
(
languages
.
registerCompletionItemProvider
(
selector
,
new
JsDocCompletionHelper
(
client
)));
languages
.
registerCompletionItemProvider
(
selector
,
new
JsDocCompletionHelper
(
client
)
,
'
*
'
));
const
goToProjectConfig
=
(
isTypeScript
:
boolean
)
=>
{
const
editor
=
window
.
activeTextEditor
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录