Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
徽霖
Vscode
提交
9ba36475
V
Vscode
项目概览
徽霖
/
Vscode
通知
9
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,发现更多精彩内容 >>
提交
9ba36475
编写于
3月 27, 2018
作者:
P
Pine Wu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Init folding provider on client ready
上级
e97f9d93
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
49 addition
and
39 deletion
+49
-39
extensions/css-language-features/client/src/cssMain.ts
extensions/css-language-features/client/src/cssMain.ts
+49
-39
未找到文件。
extensions/css-language-features/client/src/cssMain.ts
浏览文件 @
9ba36475
...
...
@@ -9,7 +9,7 @@ import * as nls from 'vscode-nls';
const
localize
=
nls
.
loadMessageBundle
();
import
{
languages
,
window
,
commands
,
ExtensionContext
,
Range
,
Position
,
TextDocument
,
CompletionItem
,
CompletionItemKind
,
TextEdit
,
SnippetString
,
FoldingRangeList
,
FoldingRange
,
FoldingContext
,
CancellationToken
}
from
'
vscode
'
;
import
{
LanguageClient
,
LanguageClientOptions
,
ServerOptions
,
TransportKind
}
from
'
vscode-languageclient
'
;
import
{
LanguageClient
,
LanguageClientOptions
,
ServerOptions
,
TransportKind
,
Disposable
}
from
'
vscode-languageclient
'
;
import
{
FoldingRangesRequest
,
FoldingRangeRequestParam
}
from
'
vscode-languageserver-protocol-foldingprovider
'
;
// this method is called when vs code is activated
...
...
@@ -68,48 +68,58 @@ export function activate(context: ExtensionContext) {
indentationRules
:
indentationRules
});
const
regionCompletionRegExpr
=
/^
(\s
*
)(\/(\*\s
*
(
#
\w
*
)?)?)?
$/
;
languages
.
registerCompletionItemProvider
(
documentSelector
,
{
provideCompletionItems
(
doc
,
pos
)
{
let
lineUntilPos
=
doc
.
getText
(
new
Range
(
new
Position
(
pos
.
line
,
0
),
pos
));
let
match
=
lineUntilPos
.
match
(
regionCompletionRegExpr
);
if
(
match
)
{
let
range
=
new
Range
(
new
Position
(
pos
.
line
,
match
[
1
].
length
),
pos
);
let
beginProposal
=
new
CompletionItem
(
'
#region
'
,
CompletionItemKind
.
Snippet
);
beginProposal
.
range
=
range
;
TextEdit
.
replace
(
range
,
'
/* #region */
'
);
beginProposal
.
insertText
=
new
SnippetString
(
'
/* #region $1*/
'
);
beginProposal
.
documentation
=
localize
(
'
folding.start
'
,
'
Folding Region Start
'
);
beginProposal
.
filterText
=
match
[
2
];
beginProposal
.
sortText
=
'
za
'
;
let
endProposal
=
new
CompletionItem
(
'
#endregion
'
,
CompletionItemKind
.
Snippet
);
endProposal
.
range
=
range
;
endProposal
.
insertText
=
'
/* #endregion */
'
;
endProposal
.
documentation
=
localize
(
'
folding.end
'
,
'
Folding Region End
'
);
endProposal
.
sortText
=
'
zb
'
;
endProposal
.
filterText
=
match
[
2
];
return
[
beginProposal
,
endProposal
];
}
return
null
;
}
client
.
onReady
().
then
(()
=>
{
context
.
subscriptions
.
push
(
initCompletionProvider
());
context
.
subscriptions
.
push
(
initFoldingProvider
());
});
languages
.
registerFoldingProvider
(
documentSelector
,
{
provideFoldingRanges
(
document
:
TextDocument
,
context
:
FoldingContext
,
token
:
CancellationToken
)
{
const
param
:
FoldingRangeRequestParam
=
{
textDocument
:
client
.
code2ProtocolConverter
.
asTextDocumentIdentifier
(
document
),
maxRanges
:
context
.
maxRanges
};
return
client
.
sendRequest
(
FoldingRangesRequest
.
type
,
param
,
token
).
then
(
res
=>
{
if
(
res
&&
Array
.
isArray
(
res
.
ranges
))
{
return
new
FoldingRangeList
(
res
.
ranges
.
map
(
r
=>
new
FoldingRange
(
r
.
startLine
,
r
.
endLine
,
r
.
type
)));
function
initCompletionProvider
():
Disposable
{
const
regionCompletionRegExpr
=
/^
(\s
*
)(\/(\*\s
*
(
#
\w
*
)?)?)?
$/
;
return
languages
.
registerCompletionItemProvider
(
documentSelector
,
{
provideCompletionItems
(
doc
,
pos
)
{
let
lineUntilPos
=
doc
.
getText
(
new
Range
(
new
Position
(
pos
.
line
,
0
),
pos
));
let
match
=
lineUntilPos
.
match
(
regionCompletionRegExpr
);
if
(
match
)
{
let
range
=
new
Range
(
new
Position
(
pos
.
line
,
match
[
1
].
length
),
pos
);
let
beginProposal
=
new
CompletionItem
(
'
#region
'
,
CompletionItemKind
.
Snippet
);
beginProposal
.
range
=
range
;
TextEdit
.
replace
(
range
,
'
/* #region */
'
);
beginProposal
.
insertText
=
new
SnippetString
(
'
/* #region $1*/
'
);
beginProposal
.
documentation
=
localize
(
'
folding.start
'
,
'
Folding Region Start
'
);
beginProposal
.
filterText
=
match
[
2
];
beginProposal
.
sortText
=
'
za
'
;
let
endProposal
=
new
CompletionItem
(
'
#endregion
'
,
CompletionItemKind
.
Snippet
);
endProposal
.
range
=
range
;
endProposal
.
insertText
=
'
/* #endregion */
'
;
endProposal
.
documentation
=
localize
(
'
folding.end
'
,
'
Folding Region End
'
);
endProposal
.
sortText
=
'
zb
'
;
endProposal
.
filterText
=
match
[
2
];
return
[
beginProposal
,
endProposal
];
}
return
null
;
},
error
=>
{
client
.
logFailedRequest
(
FoldingRangesRequest
.
type
,
error
);
return
null
;
});
}
});
}
});
}
function
initFoldingProvider
():
Disposable
{
return
languages
.
registerFoldingProvider
(
documentSelector
,
{
provideFoldingRanges
(
document
:
TextDocument
,
context
:
FoldingContext
,
token
:
CancellationToken
)
{
const
param
:
FoldingRangeRequestParam
=
{
textDocument
:
client
.
code2ProtocolConverter
.
asTextDocumentIdentifier
(
document
),
maxRanges
:
context
.
maxRanges
};
return
client
.
sendRequest
(
FoldingRangesRequest
.
type
,
param
,
token
).
then
(
res
=>
{
if
(
res
&&
Array
.
isArray
(
res
.
ranges
))
{
return
new
FoldingRangeList
(
res
.
ranges
.
map
(
r
=>
new
FoldingRange
(
r
.
startLine
,
r
.
endLine
,
r
.
type
)));
}
return
null
;
},
error
=>
{
client
.
logFailedRequest
(
FoldingRangesRequest
.
type
,
error
);
return
null
;
});
}
});
}
commands
.
registerCommand
(
'
_css.applyCodeAction
'
,
applyCodeAction
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录