Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
79cf4e92
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,发现更多精彩内容 >>
提交
79cf4e92
编写于
3月 03, 2021
作者:
L
Ladislau Szomoru
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use Promise instead of event
上级
14fd07d5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
19 deletion
+9
-19
src/vs/workbench/services/extensionManagement/browser/extensionEnablementService.ts
...extensionManagement/browser/extensionEnablementService.ts
+9
-19
未找到文件。
src/vs/workbench/services/extensionManagement/browser/extensionEnablementService.ts
浏览文件 @
79cf4e92
...
...
@@ -25,7 +25,7 @@ import { ILifecycleService, LifecyclePhase } from 'vs/workbench/services/lifecyc
import
{
INotificationService
,
Severity
}
from
'
vs/platform/notification/common/notification
'
;
import
{
IHostService
}
from
'
vs/workbench/services/host/browser/host
'
;
import
{
IExtensionBisectService
}
from
'
vs/workbench/services/extensionManagement/browser/extensionBisect
'
;
import
{
WorkspaceTrustStateChangeEvent
,
IWorkspaceTrustService
,
WorkspaceTrustState
}
from
'
vs/platform/workspace/common/workspaceTrust
'
;
import
{
IWorkspaceTrustService
,
WorkspaceTrustState
}
from
'
vs/platform/workspace/common/workspaceTrust
'
;
import
{
Promises
}
from
'
vs/base/common/async
'
;
const
SOURCE
=
'
IWorkbenchExtensionEnablementService
'
;
...
...
@@ -53,7 +53,7 @@ export class ExtensionEnablementService extends Disposable implements IWorkbench
@
IUserDataSyncAccountService
private
readonly
userDataSyncAccountService
:
IUserDataSyncAccountService
,
@
ILifecycleService
private
readonly
lifecycleService
:
ILifecycleService
,
@
INotificationService
private
readonly
notificationService
:
INotificationService
,
@
IHostService
private
readonly
hostService
:
IHostService
,
@
IHostService
readonly
hostService
:
IHostService
,
@
IExtensionBisectService
private
readonly
extensionBisectService
:
IExtensionBisectService
,
@
IWorkspaceTrustService
private
readonly
workspaceTrustService
:
IWorkspaceTrustService
)
{
...
...
@@ -62,13 +62,18 @@ export class ExtensionEnablementService extends Disposable implements IWorkbench
this
.
_register
(
this
.
globalExtensionEnablementService
.
onDidChangeEnablement
(({
extensions
,
source
})
=>
this
.
onDidChangeExtensions
(
extensions
,
source
)));
this
.
_register
(
extensionManagementService
.
onDidInstallExtension
(
this
.
_onDidInstallExtension
,
this
));
this
.
_register
(
extensionManagementService
.
onDidUninstallExtension
(
this
.
_onDidUninstallExtension
,
this
));
this
.
_register
(
this
.
workspaceTrustService
.
onDidChangeTrustState
(
this
.
_onDidChangeTrustState
,
this
));
// Trusted extensions notification
// TODO: Confirm that this is the right lifecycle phase
this
.
lifecycleService
.
when
(
LifecyclePhase
.
Eventually
).
then
(()
=>
{
if
(
this
.
extensionsDisabledByTrustRequirement
.
length
>
0
)
{
this
.
workspaceTrustService
.
requireWorkspaceTrust
({
modal
:
false
});
this
.
workspaceTrustService
.
requireWorkspaceTrust
({
modal
:
false
})
.
then
(
trustState
=>
{
if
(
trustState
===
WorkspaceTrustState
.
Trusted
)
{
this
.
_onEnablementChanged
.
fire
(
this
.
extensionsDisabledByTrustRequirement
);
this
.
extensionsDisabledByTrustRequirement
=
[];
}
});
}
});
...
...
@@ -436,21 +441,6 @@ export class ExtensionEnablementService extends Disposable implements IWorkbench
}
}
private
async
_onDidChangeTrustState
(
state
:
WorkspaceTrustStateChangeEvent
):
Promise
<
void
>
{
if
(
state
.
previousTrustState
===
WorkspaceTrustState
.
Trusted
&&
(
state
.
currentTrustState
===
WorkspaceTrustState
.
Untrusted
||
state
.
currentTrustState
===
WorkspaceTrustState
.
Unknown
))
{
// Reload window
this
.
hostService
.
reload
();
return
;
}
if
(
state
.
currentTrustState
===
WorkspaceTrustState
.
Trusted
)
{
// Enable extensions
this
.
_onEnablementChanged
.
fire
(
this
.
extensionsDisabledByTrustRequirement
);
this
.
extensionsDisabledByTrustRequirement
=
[];
}
}
private
_onDidInstallExtension
({
local
,
error
}:
DidInstallExtensionEvent
):
void
{
if
(
local
&&
!
error
&&
this
.
_isDisabledByTrustRequirement
(
local
))
{
this
.
workspaceTrustService
.
requireWorkspaceTrust
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录