Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
81c6d626
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,发现更多精彩内容 >>
提交
81c6d626
编写于
10月 03, 2018
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
perf - don't compute config-context keys eagerly but on demand
上级
46c97fe4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
64 addition
and
71 deletion
+64
-71
src/vs/platform/contextkey/browser/contextKeyService.ts
src/vs/platform/contextkey/browser/contextKeyService.ts
+64
-71
未找到文件。
src/vs/platform/contextkey/browser/contextKeyService.ts
浏览文件 @
81c6d626
...
...
@@ -7,8 +7,9 @@ import { IDisposable, dispose } from 'vs/base/common/lifecycle';
import
{
CommandsRegistry
}
from
'
vs/platform/commands/common/commands
'
;
import
{
KeybindingResolver
}
from
'
vs/platform/keybinding/common/keybindingResolver
'
;
import
{
IContextKey
,
IContext
,
IContextKeyServiceTarget
,
IContextKeyService
,
SET_CONTEXT_COMMAND_ID
,
ContextKeyExpr
,
IContextKeyChangeEvent
,
IReadableSet
}
from
'
vs/platform/contextkey/common/contextkey
'
;
import
{
IConfigurationService
,
IConfigurationChangeEvent
,
ConfigurationTarget
}
from
'
vs/platform/configuration/common/configuration
'
;
import
{
IConfigurationService
,
ConfigurationTarget
}
from
'
vs/platform/configuration/common/configuration
'
;
import
{
Event
,
Emitter
,
debounceEvent
}
from
'
vs/base/common/event
'
;
import
{
keys
}
from
'
vs/base/common/map
'
;
const
KEYBINDING_CONTEXT_ATTR
=
'
data-keybinding-context
'
;
...
...
@@ -61,87 +62,79 @@ export class Context implements IContext {
class
ConfigAwareContextValuesContainer
extends
Context
{
private
readonly
_emitter
:
Emitter
<
string
|
string
[]
>
;
private
readonly
_subscription
:
IDisposable
;
private
readonly
_configurationService
:
IConfigurationService
;
private
static
_keyPrefix
=
'
config.
'
;
constructor
(
id
:
number
,
configurationService
:
IConfigurationService
,
emitter
:
Emitter
<
string
|
string
[]
>
)
{
private
readonly
_values
=
new
Map
<
string
,
any
>
();
private
readonly
_listener
:
IDisposable
;
constructor
(
id
:
number
,
private
readonly
_configurationService
:
IConfigurationService
,
emitter
:
Emitter
<
string
|
string
[]
>
)
{
super
(
id
,
null
);
this
.
_emitter
=
emitter
;
this
.
_configurationService
=
configurationService
;
this
.
_subscription
=
configurationService
.
onDidChangeConfiguration
(
this
.
_onConfigurationUpdated
,
this
);
this
.
_initFromConfiguration
();
this
.
_listener
=
this
.
_configurationService
.
onDidChangeConfiguration
(
event
=>
{
if
(
event
.
source
===
ConfigurationTarget
.
DEFAULT
)
{
// new setting, reset everything
const
allKeys
=
keys
(
this
.
_values
);
this
.
_values
.
clear
();
emitter
.
fire
(
allKeys
);
}
else
{
const
changedKeys
:
string
[]
=
[];
for
(
const
configKey
of
event
.
affectedKeys
)
{
const
contextKey
=
`config.
${
configKey
}
`
;
if
(
this
.
_values
.
has
(
contextKey
))
{
this
.
_values
.
delete
(
contextKey
);
changedKeys
.
push
(
contextKey
);
}
}
emitter
.
fire
(
changedKeys
);
}
});
}
public
dispose
()
{
this
.
_
subscription
.
dispose
();
dispose
():
void
{
this
.
_
listener
.
dispose
();
}
private
_onConfigurationUpdated
(
event
:
IConfigurationChangeEvent
):
void
{
if
(
event
.
source
===
ConfigurationTarget
.
DEFAULT
)
{
// new setting, rebuild everything
this
.
_initFromConfiguration
();
}
else
{
// update those that we know
for
(
const
configKey
of
event
.
affectedKeys
)
{
const
contextKey
=
`config.
${
configKey
}
`
;
if
(
contextKey
in
this
.
_value
)
{
this
.
_value
[
contextKey
]
=
this
.
_configurationService
.
getValue
(
configKey
);
this
.
_emitter
.
fire
(
contextKey
);
}
}
getValue
(
key
:
string
):
any
{
if
(
key
.
indexOf
(
ConfigAwareContextValuesContainer
.
_keyPrefix
)
!==
0
)
{
return
super
.
getValue
(
key
);
}
}
private
_initFromConfiguration
()
{
const
prefix
=
'
config.
'
;
const
config
=
this
.
_configurationService
.
getValue
();
const
configKeys
:
{
[
key
:
string
]:
boolean
}
=
Object
.
create
(
null
);
const
configKeysChanged
:
string
[]
=
[];
// add new value from config
const
walk
=
(
obj
:
any
,
keys
:
string
[])
=>
{
for
(
let
key
in
obj
)
{
if
(
Object
.
prototype
.
hasOwnProperty
.
call
(
obj
,
key
))
{
keys
.
push
(
key
);
let
value
=
obj
[
key
];
switch
(
typeof
value
)
{
case
'
boolean
'
:
case
'
string
'
:
case
'
number
'
:
const
configKey
=
keys
.
join
(
'
.
'
);
const
oldValue
=
this
.
_value
[
configKey
];
this
.
_value
[
configKey
]
=
value
;
if
(
oldValue
!==
value
)
{
configKeysChanged
.
push
(
configKey
);
configKeys
[
configKey
]
=
true
;
}
else
{
configKeys
[
configKey
]
=
false
;
}
break
;
case
'
object
'
:
walk
(
value
,
keys
);
break
;
}
keys
.
pop
();
}
}
};
walk
(
config
,
[
'
config
'
]);
// remove unused keys
for
(
let
key
in
this
.
_value
)
{
if
(
key
.
indexOf
(
prefix
)
===
0
&&
configKeys
[
key
]
===
undefined
)
{
delete
this
.
_value
[
key
];
configKeys
[
key
]
=
true
;
configKeysChanged
.
push
(
key
);
}
if
(
this
.
_values
.
has
(
key
))
{
return
this
.
_values
.
get
(
key
);
}
const
configKey
=
key
.
substr
(
ConfigAwareContextValuesContainer
.
_keyPrefix
.
length
);
const
configValue
=
this
.
_configurationService
.
getValue
(
configKey
);
let
value
:
any
=
undefined
;
switch
(
typeof
configValue
)
{
case
'
number
'
:
case
'
boolean
'
:
case
'
string
'
:
value
=
configValue
;
break
;
}
// send events
this
.
_emitter
.
fire
(
configKeysChanged
);
this
.
_values
.
set
(
key
,
value
);
return
value
;
}
setValue
(
key
:
string
,
value
:
any
):
boolean
{
return
super
.
setValue
(
key
,
value
);
}
removeValue
(
key
:
string
):
boolean
{
return
super
.
removeValue
(
key
);
}
collectAllValues
():
{
[
key
:
string
]:
any
;
}
{
const
result
:
{
[
key
:
string
]:
any
}
=
Object
.
create
(
null
);
this
.
_values
.
forEach
((
value
,
index
)
=>
result
[
index
]
=
value
);
return
{
...
result
,
...
super
.
collectAllValues
()
};
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录