Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
0c22d9c0
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,发现更多精彩内容 >>
提交
0c22d9c0
编写于
4月 17, 2019
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
special treatment for language pack extensions
上级
ef4a8062
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
28 addition
and
11 deletion
+28
-11
src/vs/workbench/contrib/extensions/electron-browser/extensionsActions.ts
.../contrib/extensions/electron-browser/extensionsActions.ts
+20
-9
src/vs/workbench/contrib/extensions/electron-browser/extensionsList.ts
...nch/contrib/extensions/electron-browser/extensionsList.ts
+2
-1
src/vs/workbench/contrib/extensions/electron-browser/extensionsViews.ts
...ch/contrib/extensions/electron-browser/extensionsViews.ts
+6
-1
未找到文件。
src/vs/workbench/contrib/extensions/electron-browser/extensionsActions.ts
浏览文件 @
0c22d9c0
...
...
@@ -17,7 +17,7 @@ import { IExtension, ExtensionState, IExtensionsWorkbenchService, VIEWLET_ID, IE
import
{
ExtensionsConfigurationInitialContent
}
from
'
vs/workbench/contrib/extensions/common/extensionsFileTemplate
'
;
import
{
IExtensionEnablementService
,
IExtensionTipsService
,
EnablementState
,
ExtensionsLabel
,
IExtensionRecommendation
,
IGalleryExtension
,
IExtensionsConfigContent
,
IExtensionGalleryService
,
INSTALL_ERROR_MALICIOUS
,
INSTALL_ERROR_INCOMPATIBLE
,
IGalleryExtensionVersion
,
ILocalExtension
,
IExtensionManagementServerService
,
IExtensionManagementServer
}
from
'
vs/platform/extensionManagement/common/extensionManagement
'
;
import
{
areSameExtensions
}
from
'
vs/platform/extensionManagement/common/extensionManagementUtil
'
;
import
{
ExtensionType
,
ExtensionIdentifier
,
IExtensionDescription
,
IExtensionManifest
}
from
'
vs/platform/extensions/common/extensions
'
;
import
{
ExtensionType
,
ExtensionIdentifier
,
IExtensionDescription
,
IExtensionManifest
,
isLanguagePackExtension
}
from
'
vs/platform/extensions/common/extensions
'
;
import
{
IInstantiationService
,
ServicesAccessor
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
ShowViewletAction
}
from
'
vs/workbench/browser/viewlet
'
;
import
{
IViewletService
}
from
'
vs/workbench/services/viewlet/browser/viewlet
'
;
...
...
@@ -172,16 +172,21 @@ export class InstallAction extends ExtensionAction {
}
update
():
void
{
if
(
!
this
.
extension
||
this
.
extension
.
type
===
ExtensionType
.
System
)
{
this
.
enabled
=
false
;
this
.
class
=
InstallAction
.
Class
;
this
.
label
=
InstallAction
.
INSTALL_LABEL
;
this
.
enabled
=
false
;
this
.
class
=
InstallAction
.
Class
;
this
.
label
=
InstallAction
.
INSTALL_LABEL
;
if
(
!
this
.
extension
||
this
.
extension
.
type
===
ExtensionType
.
System
||
this
.
extension
.
state
===
ExtensionState
.
Installed
)
{
return
;
}
this
.
enabled
=
this
.
extensionsWorkbenchService
.
canInstall
(
this
.
extension
)
&&
!
this
.
extensionsWorkbenchService
.
local
.
some
(
e
=>
areSameExtensions
(
e
.
identifier
,
this
.
extension
.
identifier
));
this
.
class
=
this
.
extension
.
state
===
ExtensionState
.
Installing
?
InstallAction
.
InstallingClass
:
InstallAction
.
Class
;
this
.
updateLabel
();
const
local
=
this
.
extensionsWorkbenchService
.
local
.
filter
(
e
=>
areSameExtensions
(
e
.
identifier
,
this
.
extension
.
identifier
))[
0
];
if
(
local
&&
!
(
local
.
local
&&
isLanguagePackExtension
(
local
.
local
.
manifest
)))
{
return
;
}
if
(
this
.
extensionsWorkbenchService
.
canInstall
(
this
.
extension
))
{
this
.
enabled
=
true
;
this
.
class
=
this
.
extension
.
state
===
ExtensionState
.
Installing
?
InstallAction
.
InstallingClass
:
InstallAction
.
Class
;
this
.
updateLabel
();
}
}
private
updateLabel
():
void
{
...
...
@@ -2563,6 +2568,9 @@ export class DisabledLabelAction extends ExtensionAction {
this
.
class
=
`
${
DisabledLabelAction
.
Class
}
hide`
;
this
.
label
=
''
;
this
.
enabled
=
false
;
if
(
this
.
extension
&&
this
.
extension
.
local
&&
isLanguagePackExtension
(
this
.
extension
.
local
.
manifest
))
{
return
;
}
if
(
this
.
warningAction
.
enabled
)
{
this
.
enabled
=
true
;
this
.
class
=
DisabledLabelAction
.
Class
;
...
...
@@ -2622,6 +2630,9 @@ export class SystemDisabledWarningAction extends ExtensionAction {
this
.
enabled
=
false
;
this
.
class
=
`
${
SystemDisabledWarningAction
.
Class
}
hide`
;
this
.
tooltip
=
''
;
if
(
this
.
extension
&&
this
.
extension
.
local
&&
isLanguagePackExtension
(
this
.
extension
.
local
.
manifest
))
{
return
;
}
if
(
this
.
extension
&&
this
.
extension
.
local
&&
this
.
extension
.
server
&&
this
.
_runningExtensions
&&
this
.
workbenchEnvironmentService
.
configuration
.
remoteAuthority
&&
this
.
extensionManagementServerService
.
remoteExtensionManagementServer
)
{
const
runningExtension
=
this
.
_runningExtensions
.
filter
(
e
=>
areSameExtensions
({
id
:
e
.
identifier
.
value
},
this
.
extension
.
identifier
))[
0
];
const
runningExtensionServer
=
runningExtension
?
this
.
extensionManagementServerService
.
getExtensionManagementServer
(
runningExtension
.
extensionLocation
)
:
null
;
...
...
src/vs/workbench/contrib/extensions/electron-browser/extensionsList.ts
浏览文件 @
0c22d9c0
...
...
@@ -19,6 +19,7 @@ import { Label, RatingsWidget, InstallCountWidget, RecommendationWidget, RemoteB
import
{
IExtensionService
}
from
'
vs/workbench/services/extensions/common/extensions
'
;
import
{
IExtensionManagementServerService
}
from
'
vs/platform/extensionManagement/common/extensionManagement
'
;
import
{
INotificationService
}
from
'
vs/platform/notification/common/notification
'
;
import
{
isLanguagePackExtension
}
from
'
vs/platform/extensions/common/extensions
'
;
export
interface
IExtensionsViewState
{
onFocus
:
Event
<
IExtension
>
;
...
...
@@ -151,7 +152,7 @@ export class Renderer implements IPagedRenderer<IExtension, ITemplateData> {
const
updateEnablement
=
async
()
=>
{
const
runningExtensions
=
await
this
.
extensionService
.
getExtensions
();
if
(
extension
.
local
)
{
if
(
extension
.
local
&&
!
isLanguagePackExtension
(
extension
.
local
.
manifest
)
)
{
const
runningExtension
=
runningExtensions
.
filter
(
e
=>
areSameExtensions
({
id
:
e
.
identifier
.
value
},
extension
.
identifier
))[
0
];
const
isSameExtensionRunning
=
runningExtension
&&
extension
.
server
===
this
.
extensionManagementServerService
.
getExtensionManagementServer
(
runningExtension
.
extensionLocation
);
toggleClass
(
data
.
root
,
'
disabled
'
,
!
isSameExtensionRunning
);
...
...
src/vs/workbench/contrib/extensions/electron-browser/extensionsViews.ts
浏览文件 @
0c22d9c0
...
...
@@ -41,7 +41,7 @@ import { IListContextMenuEvent } from 'vs/base/browser/ui/list/list';
import
{
createErrorWithActions
}
from
'
vs/base/common/errorsWithActions
'
;
import
{
CancellationToken
}
from
'
vs/base/common/cancellation
'
;
import
{
IAction
}
from
'
vs/base/common/actions
'
;
import
{
ExtensionType
,
ExtensionIdentifier
,
IExtensionDescription
}
from
'
vs/platform/extensions/common/extensions
'
;
import
{
ExtensionType
,
ExtensionIdentifier
,
IExtensionDescription
,
isLanguagePackExtension
}
from
'
vs/platform/extensions/common/extensions
'
;
import
{
IWorkbenchThemeService
}
from
'
vs/workbench/services/themes/common/workbenchThemeService
'
;
import
product
from
'
vs/platform/product/node/product
'
;
import
{
CancelablePromise
,
createCancelablePromise
}
from
'
vs/base/common/async
'
;
...
...
@@ -343,6 +343,11 @@ export class ExtensionsListView extends ViewletPanel {
if
((
isE1Running
&&
isE2Running
)
||
(
!
isE1Running
&&
!
isE2Running
))
{
return
e1
.
displayName
.
localeCompare
(
e2
.
displayName
);
}
const
isE1LanguagePackExtension
=
e1
.
local
&&
isLanguagePackExtension
(
e1
.
local
.
manifest
);
const
isE2LanguagePackExtension
=
e2
.
local
&&
isLanguagePackExtension
(
e2
.
local
.
manifest
);
if
((
isE1Running
&&
isE2LanguagePackExtension
)
||
(
isE2Running
&&
isE1LanguagePackExtension
))
{
return
e1
.
displayName
.
localeCompare
(
e2
.
displayName
);
}
return
isE1Running
?
-
1
:
1
;
});
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录