Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
fe6bd12a
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,发现更多精彩内容 >>
提交
fe6bd12a
编写于
2月 15, 2019
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Strict null check releaseNotesEditor
上级
26ff5f8b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
17 addition
and
13 deletion
+17
-13
src/vs/workbench/contrib/update/electron-browser/releaseNotesEditor.ts
...nch/contrib/update/electron-browser/releaseNotesEditor.ts
+15
-11
src/vs/workbench/contrib/webview/electron-browser/webviewEditorService.ts
.../contrib/webview/electron-browser/webviewEditorService.ts
+2
-2
未找到文件。
src/vs/workbench/contrib/update/electron-browser/releaseNotesEditor.ts
浏览文件 @
fe6bd12a
...
...
@@ -26,6 +26,7 @@ import { WebviewEditorInput } from 'vs/workbench/contrib/webview/electron-browse
import
{
KeybindingParser
}
from
'
vs/base/common/keybindingParser
'
;
import
{
CancellationToken
}
from
'
vs/base/common/cancellation
'
;
import
{
IExtensionService
}
from
'
vs/workbench/services/extensions/common/extensions
'
;
import
{
IEditorGroupsService
}
from
'
vs/workbench/services/editor/common/editorGroupsService
'
;
function
renderBody
(
body
:
string
,
...
...
@@ -60,6 +61,7 @@ export class ReleaseNotesManager {
@
IRequestService
private
readonly
_requestService
:
IRequestService
,
@
ITelemetryService
private
readonly
_telemetryService
:
ITelemetryService
,
@
IEditorService
private
readonly
_editorService
:
IEditorService
,
@
IEditorGroupsService
private
readonly
_editorGroupService
:
IEditorGroupsService
,
@
IWebviewEditorService
private
readonly
_webviewEditorService
:
IWebviewEditorService
,
@
IExtensionService
private
readonly
_extensionService
:
IExtensionService
)
{
...
...
@@ -87,7 +89,7 @@ export class ReleaseNotesManager {
if
(
this
.
_currentReleaseNotes
)
{
this
.
_currentReleaseNotes
.
setName
(
title
);
this
.
_currentReleaseNotes
.
html
=
html
;
this
.
_webviewEditorService
.
revealWebview
(
this
.
_currentReleaseNotes
,
activeControl
?
activeControl
.
group
:
undefined
,
false
);
this
.
_webviewEditorService
.
revealWebview
(
this
.
_currentReleaseNotes
,
activeControl
?
activeControl
.
group
:
this
.
_editorGroupService
.
activeGroup
,
false
);
}
else
{
this
.
_currentReleaseNotes
=
this
.
_webviewEditorService
.
createWebview
(
'
releaseNotes
'
,
...
...
@@ -129,7 +131,7 @@ export class ReleaseNotesManager {
return
unassigned
;
}
return
keybinding
.
getLabel
();
return
keybinding
.
getLabel
()
||
unassigned
;
};
const
kbstyle
=
(
match
:
string
,
kb
:
string
)
=>
{
...
...
@@ -145,7 +147,7 @@ export class ReleaseNotesManager {
return
unassigned
;
}
return
resolvedKeybindings
[
0
].
getLabel
();
return
resolvedKeybindings
[
0
].
getLabel
()
||
unassigned
;
};
return
text
...
...
@@ -157,7 +159,7 @@ export class ReleaseNotesManager {
this
.
_releaseNotesCache
[
version
]
=
this
.
_requestService
.
request
({
url
},
CancellationToken
.
None
)
.
then
(
asText
)
.
then
(
text
=>
{
if
(
!
/^#
\s
/
.
test
(
text
))
{
// release notes always starts with `#` followed by whitespace
if
(
!
text
||
!
/^#
\s
/
.
test
(
text
))
{
// release notes always starts with `#` followed by whitespace
return
Promise
.
reject
(
new
Error
(
'
Invalid release notes
'
));
}
...
...
@@ -178,7 +180,7 @@ export class ReleaseNotesManager {
private
async
renderBody
(
text
:
string
)
{
const
content
=
await
this
.
renderContent
(
text
);
const
colorMap
=
TokenizationRegistry
.
getColorMap
();
const
css
=
generateTokensCSSForColorMap
(
colorMap
)
;
const
css
=
colorMap
?
generateTokensCSSForColorMap
(
colorMap
)
:
''
;
const
body
=
renderBody
(
content
,
css
);
return
body
;
}
...
...
@@ -189,14 +191,16 @@ export class ReleaseNotesManager {
}
private
async
getRenderer
(
text
:
string
):
Promise
<
marked
.
Renderer
>
{
let
result
:
Promise
<
ITokenizationSupport
>
[]
=
[];
let
result
:
Promise
<
ITokenizationSupport
|
null
>
[]
=
[];
const
renderer
=
new
marked
.
Renderer
();
renderer
.
code
=
(
_code
,
lang
)
=>
{
const
modeId
=
this
.
_modeService
.
getModeIdForLanguageName
(
lang
);
result
.
push
(
this
.
_extensionService
.
whenInstalledExtensionsRegistered
().
then
(
_
=>
{
this
.
_modeService
.
triggerMode
(
modeId
);
return
TokenizationRegistry
.
getPromise
(
modeId
);
}));
if
(
modeId
)
{
result
.
push
(
this
.
_extensionService
.
whenInstalledExtensionsRegistered
().
then
<
ITokenizationSupport
|
null
>
(()
=>
{
this
.
_modeService
.
triggerMode
(
modeId
);
return
TokenizationRegistry
.
getPromise
(
modeId
);
}));
}
return
''
;
};
...
...
@@ -205,7 +209,7 @@ export class ReleaseNotesManager {
renderer
.
code
=
(
code
,
lang
)
=>
{
const
modeId
=
this
.
_modeService
.
getModeIdForLanguageName
(
lang
);
return
`<code>
${
tokenizeToString
(
code
,
TokenizationRegistry
.
get
(
modeId
)
)}
</code>`
;
return
`<code>
${
tokenizeToString
(
code
,
modeId
?
TokenizationRegistry
.
get
(
modeId
)
:
undefined
)}
</code>`
;
};
return
renderer
;
}
...
...
src/vs/workbench/contrib/webview/electron-browser/webviewEditorService.ts
浏览文件 @
fe6bd12a
...
...
@@ -28,7 +28,7 @@ export interface IWebviewEditorService {
title
:
string
,
showOptions
:
ICreateWebViewShowOptions
,
options
:
WebviewInputOptions
,
extensionLocation
:
URI
,
extensionLocation
:
URI
|
undefined
,
events
:
WebviewEvents
):
WebviewEditorInput
;
...
...
@@ -104,7 +104,7 @@ export class WebviewEditorService implements IWebviewEditorService {
title
:
string
,
showOptions
:
ICreateWebViewShowOptions
,
options
:
vscode
.
WebviewOptions
,
extensionLocation
:
URI
,
extensionLocation
:
URI
|
undefined
,
events
:
WebviewEvents
):
WebviewEditorInput
{
const
webviewInput
=
this
.
_instantiationService
.
createInstance
(
WebviewEditorInput
,
viewType
,
undefined
,
title
,
options
,
{},
events
,
extensionLocation
,
undefined
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录