Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
4e358b99
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,发现更多精彩内容 >>
提交
4e358b99
编写于
5月 24, 2019
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Remove disabled extensions ASAP (fixes microsoft/vscode-remote-release#431)
上级
a7fccbbd
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
10 addition
and
32 deletion
+10
-32
src/vs/workbench/services/extensions/common/abstractExtensionService.ts
...ch/services/extensions/common/abstractExtensionService.ts
+10
-32
未找到文件。
src/vs/workbench/services/extensions/common/abstractExtensionService.ts
浏览文件 @
4e358b99
...
...
@@ -844,9 +844,13 @@ export abstract class AbstractExtensionService extends CommonExtensionService im
const
extensionHost
=
this
.
_extensionHostProcessManagers
[
0
];
let
localExtensions
=
await
this
.
_extensionScanner
.
scannedExtensions
;
// enable or disable proposed API per extension
this
.
_checkEnableProposedApi
(
localExtensions
);
// remove disabled extensions
localExtensions
=
localExtensions
.
filter
(
extension
=>
this
.
_isEnabled
(
extension
));
if
(
remoteAuthority
)
{
let
resolvedAuthority
:
ResolvedAuthority
;
...
...
@@ -898,6 +902,9 @@ export abstract class AbstractExtensionService extends CommonExtensionService im
// enable or disable proposed API per extension
this
.
_checkEnableProposedApi
(
remoteEnv
.
extensions
);
// remove disabled extensions
remoteEnv
.
extensions
=
remoteEnv
.
extensions
.
filter
(
extension
=>
this
.
_isEnabled
(
extension
));
// remove UI extensions from the remote extensions
remoteEnv
.
extensions
=
remoteEnv
.
extensions
.
filter
(
extension
=>
!
isUIExtension
(
extension
,
this
.
_productService
,
this
.
_configurationService
));
...
...
@@ -909,19 +916,10 @@ export abstract class AbstractExtensionService extends CommonExtensionService im
remoteEnv
.
extensions
.
forEach
(
extension
=>
isRemoteExtension
.
add
(
ExtensionIdentifier
.
toKey
(
extension
.
identifier
)));
localExtensions
=
localExtensions
.
filter
(
extension
=>
!
isRemoteExtension
.
has
(
ExtensionIdentifier
.
toKey
(
extension
.
identifier
)));
// compute enabled extensions
const
enabledExtensions
=
await
this
.
_getRuntimeExtensions
((
<
IExtensionDescription
[]
>
[]).
concat
(
remoteEnv
.
extensions
).
concat
(
localExtensions
));
// remove disabled extensions
const
isEnabled
=
new
Set
<
string
>
();
enabledExtensions
.
forEach
(
extension
=>
isEnabled
.
add
(
ExtensionIdentifier
.
toKey
(
extension
.
identifier
)));
remoteEnv
.
extensions
=
remoteEnv
.
extensions
.
filter
(
extension
=>
isEnabled
.
has
(
ExtensionIdentifier
.
toKey
(
extension
.
identifier
)));
localExtensions
=
localExtensions
.
filter
(
extension
=>
isEnabled
.
has
(
ExtensionIdentifier
.
toKey
(
extension
.
identifier
)));
// save for remote extension's init data
this
.
_remoteExtensionsEnvironmentData
.
set
(
remoteAuthority
,
remoteEnv
);
this
.
_handleExtensionPoints
(
enabledExtensions
);
this
.
_handleExtensionPoints
(
(
<
IExtensionDescription
[]
>
[]).
concat
(
remoteEnv
.
extensions
).
concat
(
localExtensions
)
);
extensionHost
.
start
(
localExtensions
.
map
(
extension
=>
extension
.
identifier
));
}
else
{
...
...
@@ -930,10 +928,8 @@ export abstract class AbstractExtensionService extends CommonExtensionService im
}
private
async
_startLocalExtensionHost
(
extensionHost
:
ExtensionHostProcessManager
,
localExtensions
:
IExtensionDescription
[]):
Promise
<
void
>
{
const
enabledExtensions
=
await
this
.
_getRuntimeExtensions
(
localExtensions
);
this
.
_handleExtensionPoints
(
enabledExtensions
);
extensionHost
.
start
(
enabledExtensions
.
map
(
extension
=>
extension
.
identifier
).
filter
(
id
=>
this
.
_registry
.
containsExtension
(
id
)));
this
.
_handleExtensionPoints
(
localExtensions
);
extensionHost
.
start
(
localExtensions
.
map
(
extension
=>
extension
.
identifier
).
filter
(
id
=>
this
.
_registry
.
containsExtension
(
id
)));
}
private
_handleExtensionPoints
(
allExtensions
:
IExtensionDescription
[]):
void
{
...
...
@@ -974,24 +970,6 @@ export abstract class AbstractExtensionService extends CommonExtensionService im
return
this
.
_extensionEnablementService
.
isEnabled
(
toExtension
(
extension
));
}
private
async
_getRuntimeExtensions
(
allExtensions
:
IExtensionDescription
[]):
Promise
<
IExtensionDescription
[]
>
{
const
runtimeExtensions
:
IExtensionDescription
[]
=
[];
for
(
const
extension
of
allExtensions
)
{
if
(
this
.
_isEnabled
(
extension
))
{
runtimeExtensions
.
push
(
extension
);
}
}
this
.
_telemetryService
.
publicLog
(
'
extensionsScanned
'
,
{
totalCount
:
runtimeExtensions
.
length
,
disabledCount
:
allExtensions
.
length
-
runtimeExtensions
.
length
});
return
runtimeExtensions
;
}
public
abstract
_onExtensionHostExit
(
code
:
number
):
void
;
protected
abstract
_createLocalExtHostProcessWorker
(
autoStart
:
boolean
,
extensions
:
Promise
<
IExtensionDescription
[]
>
):
IExtensionHostStarter
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录