Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
a24b3629
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,发现更多精彩内容 >>
提交
a24b3629
编写于
7月 17, 2020
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
💄
上级
c4dae68b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
31 addition
and
26 deletion
+31
-26
src/vs/workbench/services/extensionManagement/common/webExtensionsScannerService.ts
...extensionManagement/common/webExtensionsScannerService.ts
+31
-26
未找到文件。
src/vs/workbench/services/extensionManagement/common/webExtensionsScannerService.ts
浏览文件 @
a24b3629
...
...
@@ -20,6 +20,7 @@ import { CancellationToken } from 'vs/base/common/cancellation';
import
{
IGalleryExtension
}
from
'
vs/platform/extensionManagement/common/extensionManagement
'
;
import
{
groupByExtension
,
areSameExtensions
,
getGalleryExtensionId
}
from
'
vs/platform/extensionManagement/common/extensionManagementUtil
'
;
import
{
IConfigurationService
}
from
'
vs/platform/configuration/common/configuration
'
;
import
{
IStaticExtension
}
from
'
vs/workbench/workbench.web.api
'
;
interface
IUserExtension
{
identifier
:
IExtensionIdentifier
;
...
...
@@ -47,10 +48,10 @@ export class WebExtensionsScannerService implements IWebExtensionsScannerService
declare
readonly
_serviceBrand
:
undefined
;
private
readonly
systemExtensionsPromise
:
Promise
<
IScannedExtension
[]
>
;
private
readonly
staticExtensionsPromise
:
Promise
<
IScannedExtension
[]
>
;
private
readonly
extensionsResource
:
URI
|
undefined
;
private
readonly
userExtensionsResourceLimiter
:
Queue
<
IUserExtension
[]
>
;
private
readonly
systemExtensionsPromise
:
Promise
<
IScannedExtension
[]
>
=
Promise
.
resolve
([])
;
private
readonly
staticExtensionsPromise
:
Promise
<
IScannedExtension
[]
>
=
Promise
.
resolve
([])
;
private
readonly
extensionsResource
:
URI
|
undefined
=
undefined
;
private
readonly
userExtensionsResourceLimiter
:
Queue
<
IUserExtension
[]
>
=
new
Queue
<
IUserExtension
[]
>
()
;
constructor
(
@
IWorkbenchEnvironmentService
private
readonly
environmentService
:
IWorkbenchEnvironmentService
,
...
...
@@ -60,41 +61,45 @@ export class WebExtensionsScannerService implements IWebExtensionsScannerService
@
ILogService
private
readonly
logService
:
ILogService
,
@
IConfigurationService
private
readonly
configurationService
:
IConfigurationService
,
)
{
this
.
extensionsResource
=
isWeb
?
joinPath
(
environmentService
.
userRoamingDataHome
,
'
extensions.json
'
)
:
undefined
;
this
.
userExtensionsResourceLimiter
=
new
Queue
<
IUserExtension
[]
>
();
this
.
systemExtensionsPromise
=
isWeb
?
this
.
builtinExtensionsScannerService
.
scanBuiltinExtensions
()
:
Promise
.
resolve
([]);
this
.
staticExtensionsPromise
=
this
.
readStaticExtensions
();
if
(
isWeb
)
{
this
.
extensionsResource
=
joinPath
(
environmentService
.
userRoamingDataHome
,
'
extensions.json
'
);
this
.
systemExtensionsPromise
=
this
.
builtinExtensionsScannerService
.
scanBuiltinExtensions
();
this
.
staticExtensionsPromise
=
this
.
readStaticExtensions
();
}
}
private
async
readStaticExtensions
():
Promise
<
IScannedExtension
[]
>
{
const
staticExtensions
=
this
.
environmentService
.
options
&&
Array
.
isArray
(
this
.
environmentService
.
options
.
staticExtensions
)
?
this
.
environmentService
.
options
.
staticExtensions
:
[];
const
defaultStaticExtensions
=
staticExtensions
.
map
<
IScannedExtension
>
(
data
=>
({
identifier
:
{
id
:
getGalleryExtensionId
(
data
.
packageJSON
.
publisher
,
data
.
packageJSON
.
name
)
},
location
:
data
.
extensionLocation
,
const
defaultUserWebExtensions
=
await
this
.
readDefaultUserWebExtensions
();
return
[...
staticExtensions
,
...
defaultUserWebExtensions
].
map
<
IScannedExtension
>
(
e
=>
({
identifier
:
{
id
:
getGalleryExtensionId
(
e
.
packageJSON
.
publisher
,
e
.
packageJSON
.
name
)
},
location
:
e
.
extensionLocation
,
type
:
ExtensionType
.
User
,
packageJSON
:
data
.
packageJSON
,
packageJSON
:
e
.
packageJSON
,
}));
const
userStaticExtensions
=
isWeb
?
await
this
.
readStaticExtensionsFromConfiguration
()
:
[];
return
[...
defaultStaticExtensions
,
...
userStaticExtensions
];
}
private
async
readStaticExtensionsFromConfiguration
():
Promise
<
IScannedExtension
[]
>
{
const
result
:
IScannedExtension
[]
=
[];
for
(
const
webExtension
of
this
.
configurationService
.
getValue
<
{
location
:
string
}[]
>
(
'
_extensions.defaultUserWebExtensions
'
)
||
[])
{
private
async
readDefaultUserWebExtensions
():
Promise
<
IStaticExtension
[]
>
{
const
result
:
IStaticExtension
[]
=
[];
const
defaultUserWebExtensions
=
this
.
configurationService
.
getValue
<
{
location
:
string
}[]
>
(
'
_extensions.defaultUserWebExtensions
'
)
||
[];
for
(
const
webExtension
of
defaultUserWebExtensions
)
{
const
extensionLocation
=
URI
.
parse
(
webExtension
.
location
);
const
manifestLocation
=
joinPath
(
extensionLocation
,
'
package.json
'
);
const
context
=
await
this
.
requestService
.
request
({
type
:
'
GET
'
,
url
:
manifestLocation
.
toString
(
true
)
},
CancellationToken
.
None
);
if
(
!
isSuccess
(
context
))
{
console
.
error
(
'
Unable to load
'
+
manifestLocation
);
this
.
logService
.
warn
(
'
Skipped default user web extension as there is an error while fetching manifest
'
,
manifestLocation
);
continue
;
}
const
content
=
await
asText
(
context
);
if
(
content
)
{
const
packageJSON
=
JSON
.
parse
(
content
);
result
.
push
({
identifier
:
{
id
:
getGalleryExtensionId
(
packageJSON
.
publisher
,
packageJSON
.
name
)
},
packageJSON
,
location
:
extensionLocation
,
type
:
ExtensionType
.
User
,
});
if
(
!
content
)
{
this
.
logService
.
warn
(
'
Skipped default user web extension as there is manifest is not found
'
,
manifestLocation
);
continue
;
}
const
packageJSON
=
JSON
.
parse
(
content
);
result
.
push
({
packageJSON
,
extensionLocation
,
});
}
return
result
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录