Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
de38bb2e
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,发现更多精彩内容 >>
提交
de38bb2e
编写于
8月 23, 2018
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Customise workspace extensions from config
上级
3663d1f0
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
23 addition
and
6 deletion
+23
-6
src/vs/platform/extensionManagement/common/extensionManagement.ts
...latform/extensionManagement/common/extensionManagement.ts
+1
-0
src/vs/platform/extensionManagement/common/extensionManagementUtil.ts
...orm/extensionManagement/common/extensionManagementUtil.ts
+16
-2
src/vs/platform/extensionManagement/common/multiExtensionManagement.ts
...rm/extensionManagement/common/multiExtensionManagement.ts
+6
-4
未找到文件。
src/vs/platform/extensionManagement/common/extensionManagement.ts
浏览文件 @
de38bb2e
...
...
@@ -122,6 +122,7 @@ export interface IExtensionManifest {
main
?:
string
;
icon
?:
string
;
categories
?:
string
[];
keywords
?:
string
[];
activationEvents
?:
string
[];
extensionDependencies
?:
string
[];
extensionPack
?:
string
[];
...
...
src/vs/platform/extensionManagement/common/extensionManagementUtil.ts
浏览文件 @
de38bb2e
...
...
@@ -6,6 +6,7 @@
'
use strict
'
;
import
{
ILocalExtension
,
IGalleryExtension
,
EXTENSION_IDENTIFIER_REGEX
,
IExtensionIdentifier
,
IReportedExtension
,
IExtensionManifest
}
from
'
vs/platform/extensionManagement/common/extensionManagement
'
;
import
{
IConfigurationService
}
from
'
vs/platform/configuration/common/configuration
'
;
export
function
areSameExtensions
(
a
:
IExtensionIdentifier
,
b
:
IExtensionIdentifier
):
boolean
{
if
(
a
.
uuid
&&
b
.
uuid
)
{
...
...
@@ -119,9 +120,22 @@ export function getMaliciousExtensionsSet(report: IReportedExtension[]): Set<str
return
result
;
}
export
function
isWorkspaceExtension
(
manifest
:
IExtensionManifest
):
boolean
{
export
function
isWorkspaceExtension
(
manifest
:
IExtensionManifest
,
configurationService
:
IConfigurationService
):
boolean
{
const
extensionId
=
getGalleryExtensionId
(
manifest
.
publisher
,
manifest
.
name
);
const
workspaceExtensions
=
configurationService
.
getValue
<
string
[]
>
(
'
_workbench.workspaceExtensions
'
)
||
[];
if
(
workspaceExtensions
.
length
)
{
if
(
workspaceExtensions
.
indexOf
(
extensionId
)
!==
-
1
)
{
return
true
;
}
if
(
workspaceExtensions
.
indexOf
(
`-
${
extensionId
}
`
)
!==
-
1
)
{
return
false
;
}
}
if
(
manifest
.
main
)
{
const
extensionId
=
getGalleryExtensionId
(
manifest
.
publisher
,
manifest
.
name
);
if
((
manifest
.
keywords
||
[]).
indexOf
(
'
capability_fs
'
)
!==
-
1
)
{
return
true
;
}
return
[
'
vscode.extension-editing
'
,
'
vscode.configuration-editing
'
,
...
...
src/vs/platform/extensionManagement/common/multiExtensionManagement.ts
浏览文件 @
de38bb2e
...
...
@@ -18,6 +18,7 @@ import { IWindowService } from 'vs/platform/windows/common/windows';
import
{
Action
}
from
'
vs/base/common/actions
'
;
import
{
ILogService
}
from
'
vs/platform/log/common/log
'
;
import
{
Disposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
IConfigurationService
}
from
'
vs/platform/configuration/common/configuration
'
;
export
class
MulitExtensionManagementService
extends
Disposable
implements
IExtensionManagementService
{
...
...
@@ -37,7 +38,8 @@ export class MulitExtensionManagementService extends Disposable implements IExte
@
INotificationService
private
notificationService
:
INotificationService
,
@
IWindowService
private
windowService
:
IWindowService
,
@
ILogService
private
logService
:
ILogService
,
@
IExtensionGalleryService
private
extensionGalleryService
:
IExtensionGalleryService
@
IExtensionGalleryService
private
extensionGalleryService
:
IExtensionGalleryService
,
@
IConfigurationService
private
configurationService
:
IConfigurationService
)
{
super
();
this
.
servers
=
this
.
extensionManagementServerService
.
extensionManagementServers
;
...
...
@@ -84,7 +86,7 @@ export class MulitExtensionManagementService extends Disposable implements IExte
.
then
(
extensionIdentifer
=>
this
.
localServer
.
extensionManagementService
.
getInstalled
(
LocalExtensionType
.
User
)
.
then
(
installed
=>
{
const
extension
=
installed
.
filter
(
i
=>
areSameExtensions
(
i
.
identifier
,
extensionIdentifer
))[
0
];
if
(
extension
&&
isWorkspaceExtension
(
extension
.
manifest
))
{
if
(
this
.
otherServers
.
length
&&
extension
&&
isWorkspaceExtension
(
extension
.
manifest
,
this
.
configurationService
))
{
return
TPromise
.
join
(
this
.
otherServers
.
map
(
server
=>
server
.
extensionManagementService
.
install
(
vsix
)))
.
then
(()
=>
extensionIdentifer
);
}
...
...
@@ -98,7 +100,7 @@ export class MulitExtensionManagementService extends Disposable implements IExte
}
return
this
.
extensionGalleryService
.
getManifest
(
gallery
)
.
then
(
manifest
=>
{
const
servers
=
isWorkspaceExtension
(
manifest
)
?
this
.
servers
:
[
this
.
localServer
];
const
servers
=
isWorkspaceExtension
(
manifest
,
this
.
configurationService
)
?
this
.
servers
:
[
this
.
localServer
];
return
TPromise
.
join
(
servers
.
map
(
server
=>
server
.
extensionManagementService
.
installFromGallery
(
gallery
)))
.
then
(()
=>
null
);
});
...
...
@@ -115,7 +117,7 @@ export class MulitExtensionManagementService extends Disposable implements IExte
private
async
syncExtensions
():
Promise
<
void
>
{
this
.
localServer
.
extensionManagementService
.
getInstalled
(
LocalExtensionType
.
User
)
.
then
(
async
localExtensions
=>
{
const
workspaceExtensions
=
localExtensions
.
filter
(
e
=>
isWorkspaceExtension
(
e
.
manifest
));
const
workspaceExtensions
=
localExtensions
.
filter
(
e
=>
isWorkspaceExtension
(
e
.
manifest
,
this
.
configurationService
));
const
extensionsToSync
:
Map
<
IExtensionManagementServer
,
ILocalExtension
[]
>
=
await
this
.
getExtensionsToSync
(
workspaceExtensions
);
if
(
extensionsToSync
.
size
>
0
)
{
const
handler
=
this
.
notificationService
.
notify
({
severity
:
Severity
.
Info
,
message
:
localize
(
'
synchronising
'
,
"
Synchronising workspace extensions...
"
)
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录