Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
e8693114
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,发现更多精彩内容 >>
提交
e8693114
编写于
11月 30, 2017
作者:
C
Christof Marti
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Catch up with recent change for extensions (fixes #38726)
上级
27bf1f54
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
14 deletion
+19
-14
src/vs/workbench/parts/extensions/electron-browser/extensionsUtils.ts
...ench/parts/extensions/electron-browser/extensionsUtils.ts
+4
-4
src/vs/workbench/parts/welcome/page/electron-browser/welcomePage.ts
...kbench/parts/welcome/page/electron-browser/welcomePage.ts
+15
-10
未找到文件。
src/vs/workbench/parts/extensions/electron-browser/extensionsUtils.ts
浏览文件 @
e8693114
...
...
@@ -53,9 +53,9 @@ export class KeymapExtensions implements IWorkbenchContribution {
private
checkForOtherKeymaps
(
extensionIdentifier
:
IExtensionIdentifier
):
TPromise
<
void
>
{
return
this
.
instantiationService
.
invokeFunction
(
getInstalledExtensions
).
then
(
extensions
=>
{
const
keymaps
=
extensions
.
filter
(
extension
=>
isKeymapExtension
(
this
.
tipsService
,
extension
));
const
extension
=
arrays
.
first
(
keymaps
,
extension
=>
extension
.
identifier
.
id
===
extensionIdentifier
.
id
);
const
extension
=
arrays
.
first
(
keymaps
,
extension
=>
stripVersion
(
extension
.
identifier
.
id
)
===
extensionIdentifier
.
id
);
if
(
extension
&&
extension
.
globallyEnabled
)
{
const
otherKeymaps
=
keymaps
.
filter
(
extension
=>
extension
.
identifier
.
id
!==
extensionIdentifier
.
id
&&
extension
.
globallyEnabled
);
const
otherKeymaps
=
keymaps
.
filter
(
extension
=>
stripVersion
(
extension
.
identifier
.
id
)
!==
extensionIdentifier
.
id
&&
extension
.
globallyEnabled
);
if
(
otherKeymaps
.
length
)
{
return
this
.
promptForDisablingOtherKeymaps
(
extension
,
otherKeymaps
);
}
...
...
@@ -143,7 +143,7 @@ export function getInstalledExtensions(accessor: ServicesAccessor): TPromise<IEx
.
then
(
disabledExtensions
=>
{
return
extensions
.
map
(
extension
=>
{
return
{
identifier
:
{
id
:
adoptToGalleryExtensionId
(
extension
.
identifier
.
id
),
uuid
:
extension
.
identifier
.
uuid
},
identifier
:
{
id
:
adoptToGalleryExtensionId
(
stripVersion
(
extension
.
identifier
.
id
)
),
uuid
:
extension
.
identifier
.
uuid
},
local
:
extension
,
globallyEnabled
:
disabledExtensions
.
every
(
disabled
=>
!
areSameExtensions
(
disabled
,
extension
.
identifier
))
};
...
...
@@ -154,7 +154,7 @@ export function getInstalledExtensions(accessor: ServicesAccessor): TPromise<IEx
export
function
isKeymapExtension
(
tipsService
:
IExtensionTipsService
,
extension
:
IExtensionStatus
):
boolean
{
const
cats
=
extension
.
local
.
manifest
.
categories
;
return
cats
&&
cats
.
indexOf
(
'
Keymaps
'
)
!==
-
1
||
tipsService
.
getKeymapRecommendations
().
indexOf
(
extension
.
identifier
.
id
)
!==
-
1
;
return
cats
&&
cats
.
indexOf
(
'
Keymaps
'
)
!==
-
1
||
tipsService
.
getKeymapRecommendations
().
indexOf
(
stripVersion
(
extension
.
identifier
.
id
)
)
!==
-
1
;
}
function
stripVersion
(
id
:
string
):
string
{
...
...
src/vs/workbench/parts/welcome/page/electron-browser/welcomePage.ts
浏览文件 @
e8693114
...
...
@@ -38,6 +38,7 @@ import { IExtensionsWorkbenchService } from 'vs/workbench/parts/extensions/commo
import
{
IStorageService
}
from
'
vs/platform/storage/common/storage
'
;
import
{
IWorkspaceIdentifier
,
getWorkspaceLabel
,
ISingleFolderWorkspaceIdentifier
,
isSingleFolderWorkspaceIdentifier
}
from
'
vs/platform/workspaces/common/workspaces
'
;
import
{
IEditorInputFactory
,
EditorInput
}
from
'
vs/workbench/common/editor
'
;
import
{
getIdAndVersionFromLocalExtensionId
}
from
'
vs/platform/extensionManagement/node/extensionManagementUtil
'
;
used
();
...
...
@@ -341,7 +342,7 @@ class WelcomePage {
this
.
updateInstalledExtensions
(
container
,
installedExtensions
);
this
.
disposables
.
push
(
this
.
instantiationService
.
invokeFunction
(
onExtensionChanged
)(
ids
=>
{
for
(
const
id
of
ids
)
{
if
(
container
.
querySelector
(
`.installExtension[data-extension="
${
id
}
"], .enabledExtension[data-extension="
${
id
}
"]`
))
{
if
(
container
.
querySelector
(
`.installExtension[data-extension="
${
stripVersion
(
id
.
id
)}
"], .enabledExtension[data-extension="
${
stripVersion
(
id
.
id
)
}
"]`
))
{
const
installedExtensions
=
this
.
instantiationService
.
invokeFunction
(
getInstalledExtensions
);
this
.
updateInstalledExtensions
(
container
,
installedExtensions
);
break
;
...
...
@@ -398,7 +399,7 @@ class WelcomePage {
extensionId
:
extensionSuggestion
.
id
,
});
this
.
instantiationService
.
invokeFunction
(
getInstalledExtensions
).
then
(
extensions
=>
{
const
installedExtension
=
arrays
.
first
(
extensions
,
extension
=>
extension
.
identifier
.
id
===
extensionSuggestion
.
id
);
const
installedExtension
=
arrays
.
first
(
extensions
,
extension
=>
stripVersion
(
extension
.
identifier
.
id
)
===
extensionSuggestion
.
id
);
if
(
installedExtension
&&
installedExtension
.
globallyEnabled
)
{
/* __GDPR__FRAGMENT__
"WelcomePageInstalled-1" : {
...
...
@@ -415,18 +416,18 @@ class WelcomePage {
this
.
messageService
.
show
(
Severity
.
Info
,
strings
.
alreadyInstalled
.
replace
(
'
{0}
'
,
extensionSuggestion
.
name
));
return
;
}
const
foundAndInstalled
=
installedExtension
?
TPromise
.
as
(
true
)
:
this
.
extensionGalleryService
.
query
({
names
:
[
extensionSuggestion
.
id
],
source
:
telemetryFrom
})
const
foundAndInstalled
=
installedExtension
?
TPromise
.
as
(
installedExtension
.
identifier
)
:
this
.
extensionGalleryService
.
query
({
names
:
[
extensionSuggestion
.
id
],
source
:
telemetryFrom
})
.
then
(
result
=>
{
const
[
extension
]
=
result
.
firstPage
;
if
(
!
extension
)
{
return
false
;
return
null
;
}
return
this
.
extensionManagementService
.
installFromGallery
(
extension
)
.
then
(()
=>
{
// TODO: Do this as part of the install to avoid multiple events.
return
this
.
extensionEnablementService
.
setEnablement
(
{
id
:
extensionSuggestion
.
id
}
,
EnablementState
.
Disabled
);
return
this
.
extensionEnablementService
.
setEnablement
(
extension
.
identifier
,
EnablementState
.
Disabled
);
}).
then
(()
=>
{
return
true
;
return
extension
.
identifier
;
});
});
this
.
messageService
.
show
(
Severity
.
Info
,
{
...
...
@@ -444,10 +445,10 @@ class WelcomePage {
.
map
(
extension
=>
{
return
this
.
extensionEnablementService
.
setEnablement
(
extension
.
identifier
,
EnablementState
.
Disabled
);
})
:
[]).
then
(()
=>
{
return
foundAndInstalled
.
then
(
found
=>
{
return
foundAndInstalled
.
then
(
found
Extension
=>
{
messageDelay
.
cancel
();
if
(
found
)
{
return
this
.
extensionEnablementService
.
setEnablement
(
{
id
:
extensionSuggestion
.
id
}
,
EnablementState
.
Enabled
)
if
(
found
Extension
)
{
return
this
.
extensionEnablementService
.
setEnablement
(
foundExtension
,
EnablementState
.
Enabled
)
.
then
(()
=>
{
/* __GDPR__FRAGMENT__
"WelcomePageInstalled-2" : {
...
...
@@ -558,7 +559,7 @@ class WelcomePage {
elements
[
i
].
classList
.
remove
(
'
installed
'
);
}
extensions
.
filter
(
ext
=>
ext
.
globallyEnabled
)
.
map
(
ext
=>
ext
.
identifier
)
.
map
(
ext
=>
stripVersion
(
ext
.
identifier
.
id
)
)
.
forEach
(
id
=>
{
const
install
=
container
.
querySelectorAll
(
`.installExtension[data-extension="
${
id
}
"]`
);
for
(
let
i
=
0
;
i
<
install
.
length
;
i
++
)
{
...
...
@@ -577,6 +578,10 @@ class WelcomePage {
}
}
function
stripVersion
(
id
:
string
):
string
{
return
getIdAndVersionFromLocalExtensionId
(
id
).
id
;
}
export
class
WelcomeInputFactory
implements
IEditorInputFactory
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录