Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
bec63af7
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,体验更适合开发者的 AI 搜索 >>
提交
bec63af7
编写于
6月 01, 2017
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
startup profiler listens on lifecycle event, #27852
上级
1d61c56f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
24 addition
and
7 deletion
+24
-7
src/vs/base/common/event.ts
src/vs/base/common/event.ts
+10
-1
src/vs/workbench/electron-browser/shell.ts
src/vs/workbench/electron-browser/shell.ts
+4
-4
src/vs/workbench/parts/performance/electron-browser/performance.contribution.ts
.../performance/electron-browser/performance.contribution.ts
+10
-2
未找到文件。
src/vs/base/common/event.ts
浏览文件 @
bec63af7
...
...
@@ -257,6 +257,15 @@ export function fromPromise(promise: TPromise<any>): Event<void> {
return
emitter
.
event
;
}
export
function
toPromise
<
T
>
(
event
:
Event
<
T
>
):
TPromise
<
T
>
{
return
new
TPromise
(
complete
=>
{
const
sub
=
event
(
e
=>
{
sub
.
dispose
();
complete
(
e
);
});
});
}
export
function
delayed
<
T
>
(
promise
:
TPromise
<
Event
<
T
>>
):
Event
<
T
>
{
let
toCancel
:
TPromise
<
any
>
=
null
;
let
listener
:
IDisposable
=
null
;
...
...
@@ -511,4 +520,4 @@ export function echo<T>(event: Event<T>, nextTick = false, buffer: T[] = []): Ev
});
return
emitter
.
event
;
}
\ No newline at end of file
}
src/vs/workbench/electron-browser/shell.ts
浏览文件 @
bec63af7
...
...
@@ -179,6 +179,10 @@ export class WorkbenchShell {
// start cached data manager
instantiationService
.
createInstance
(
NodeCachedDataManager
);
// Set lifecycle phase to `Runnning` so that other contributions
// can now do something
this
.
lifecycleService
.
phase
=
LifecyclePhase
.
Running
;
}
});
...
...
@@ -235,10 +239,6 @@ export class WorkbenchShell {
if
((
platform
.
isLinux
||
platform
.
isMacintosh
)
&&
process
.
getuid
()
===
0
)
{
this
.
messageService
.
show
(
Severity
.
Warning
,
nls
.
localize
(
'
runningAsRoot
'
,
"
It is recommended not to run Code as 'root'.
"
));
}
// Set lifecycle phase to `Runnning` so that other contributions
// can now do something
this
.
lifecycleService
.
phase
=
LifecyclePhase
.
Running
;
}
private
initServiceCollection
(
container
:
HTMLElement
):
[
IInstantiationService
,
ServiceCollection
]
{
...
...
src/vs/workbench/parts/performance/electron-browser/performance.contribution.ts
浏览文件 @
bec63af7
...
...
@@ -10,6 +10,7 @@ import { IEnvironmentService } from 'vs/platform/environment/common/environment'
import
{
IExtensionService
}
from
'
vs/platform/extensions/common/extensions
'
;
import
{
IInstantiationService
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
IMessageService
}
from
'
vs/platform/message/common/message
'
;
import
{
ILifecycleService
,
LifecyclePhase
}
from
'
vs/platform/lifecycle/common/lifecycle
'
;
import
{
IStorageService
,
StorageScope
}
from
'
vs/platform/storage/common/storage
'
;
import
{
ITimerService
}
from
'
vs/workbench/services/timer/common/timerService
'
;
import
{
IWindowsService
}
from
'
vs/platform/windows/common/windows
'
;
...
...
@@ -20,6 +21,7 @@ import { ReportPerformanceIssueAction } from 'vs/workbench/electron-browser/acti
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
{
join
}
from
'
path
'
;
import
{
localize
}
from
'
vs/nls
'
;
import
{
toPromise
,
filterEvent
}
from
'
vs/base/common/event
'
;
import
{
platform
,
Platform
}
from
'
vs/base/common/platform
'
;
import
{
readdir
,
stat
}
from
'
vs/base/node/pfs
'
;
import
{
release
}
from
'
os
'
;
...
...
@@ -149,10 +151,16 @@ class StartupProfiler implements IWorkbenchContribution {
@
IMessageService
private
readonly
_messageService
:
IMessageService
,
@
IEnvironmentService
private
readonly
_environmentService
:
IEnvironmentService
,
@
IInstantiationService
private
readonly
_instantiationService
:
IInstantiationService
,
@
ILifecycleService
lifecycleService
:
ILifecycleService
,
@
IExtensionService
extensionService
:
IExtensionService
,
)
{
extensionService
.
onReady
().
then
(()
=>
this
.
_stopProfiling
());
// wait for everything to be ready
TPromise
.
join
<
any
>
([
extensionService
.
onReady
(),
toPromise
(
filterEvent
(
lifecycleService
.
onDidChangePhase
,
phase
=>
phase
===
LifecyclePhase
.
Running
)),
]).
then
(()
=>
{
this
.
_stopProfiling
();
});
}
getId
():
string
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录