Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
c5afb674
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,发现更多精彩内容 >>
提交
c5afb674
编写于
9月 24, 2018
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
debt - move runWhenIdle into browser-layer because it's a browser thing
上级
d47474c5
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
137 addition
and
120 deletion
+137
-120
src/vs/base/browser/browser.ts
src/vs/base/browser/browser.ts
+38
-0
src/vs/base/common/async.ts
src/vs/base/common/async.ts
+1
-34
src/vs/workbench/browser/contributions.ts
src/vs/workbench/browser/contributions.ts
+93
-0
src/vs/workbench/common/contributions.ts
src/vs/workbench/common/contributions.ts
+1
-84
src/vs/workbench/electron-browser/shell.ts
src/vs/workbench/electron-browser/shell.ts
+1
-2
src/vs/workbench/workbench.main.ts
src/vs/workbench/workbench.main.ts
+3
-0
未找到文件。
src/vs/base/browser/browser.ts
浏览文件 @
c5afb674
...
...
@@ -167,3 +167,41 @@ export function hasClipboardSupport() {
return
true
;
}
//#region -- run on idle tricks ------------
export
interface
IdleDeadline
{
readonly
didTimeout
:
boolean
;
timeRemaining
():
DOMHighResTimeStamp
;
}
/**
* Execute the callback the next time the browser is idle
*/
export
let
runWhenIdle
:
(
callback
:
(
idle
:
IdleDeadline
)
=>
void
,
timeout
?:
number
)
=>
IDisposable
;
declare
module
self
{
export
function
requestIdleCallback
(
callback
:
(
args
:
IdleDeadline
)
=>
void
,
options
?:
{
timeout
:
number
}):
number
;
export
function
cancelIdleCallback
(
handle
:
number
):
void
;
}
(
function
()
{
if
(
typeof
self
===
'
undefined
'
||
!
self
.
requestIdleCallback
||
!
self
.
cancelIdleCallback
)
{
let
warned
=
false
;
runWhenIdle
=
(
runner
,
timeout
?)
=>
{
if
(
!
warned
)
{
console
.
warn
(
'
requestIdleCallback not available. using fallback
'
);
warned
=
true
;
}
let
handle
=
setTimeout
(()
=>
runner
({
didTimeout
:
true
,
timeRemaining
()
{
return
Number
.
MAX_VALUE
;
}
}),
timeout
);
return
{
dispose
()
{
clearTimeout
(
handle
);
}
};
};
}
else
{
runWhenIdle
=
(
runner
,
timeout
?)
=>
{
let
handle
=
self
.
requestIdleCallback
(
runner
,
typeof
timeout
===
'
number
'
?
{
timeout
}
:
undefined
);
return
{
dispose
()
{
self
.
cancelIdleCallback
(
handle
);
}
};
};
}
})();
//#endregion
src/vs/base/common/async.ts
浏览文件 @
c5afb674
...
...
@@ -8,7 +8,7 @@
import
{
CancellationToken
,
CancellationTokenSource
}
from
'
vs/base/common/cancellation
'
;
import
*
as
errors
from
'
vs/base/common/errors
'
;
import
{
Emitter
,
Event
}
from
'
vs/base/common/event
'
;
import
{
Disposable
,
IDisposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
Disposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
import
{
ErrorCallback
,
TPromise
,
ValueCallback
}
from
'
vs/base/common/winjs.base
'
;
...
...
@@ -692,36 +692,3 @@ export function ninvoke<T>(thisArg: any, fn: Function, ...args: any[]): TPromise
export
function
ninvoke
(
thisArg
:
any
,
fn
:
Function
,
...
args
:
any
[]):
any
{
return
new
TPromise
((
c
,
e
)
=>
fn
.
call
(
thisArg
,
...
args
,
(
err
:
any
,
result
:
any
)
=>
err
?
e
(
err
)
:
c
(
result
)));
}
export
interface
IdleDeadline
{
readonly
didTimeout
:
boolean
;
timeRemaining
():
DOMHighResTimeStamp
;
}
/**
* Execute the callback the next time the browser is idle
*/
export
let
runWhenIdle
:
(
callback
:
(
idle
:
IdleDeadline
)
=>
void
,
timeout
?:
number
)
=>
IDisposable
;
declare
module
self
{
export
function
requestIdleCallback
(
callback
:
(
args
:
IdleDeadline
)
=>
void
,
options
?:
{
timeout
:
number
}):
number
;
export
function
cancelIdleCallback
(
handle
:
number
):
void
;
}
(
function
()
{
if
(
typeof
self
===
'
undefined
'
||
!
self
.
requestIdleCallback
||
!
self
.
cancelIdleCallback
)
{
let
warned
=
false
;
runWhenIdle
=
(
runner
,
timeout
?)
=>
{
if
(
!
warned
)
{
console
.
warn
(
'
requestIdleCallback not available. using fallback
'
);
warned
=
true
;
}
let
handle
=
setTimeout
(()
=>
runner
({
didTimeout
:
true
,
timeRemaining
()
{
return
Number
.
MAX_VALUE
;
}
}),
timeout
);
return
{
dispose
()
{
clearTimeout
(
handle
);
}
};
};
}
else
{
runWhenIdle
=
(
runner
,
timeout
?)
=>
{
let
handle
=
self
.
requestIdleCallback
(
runner
,
typeof
timeout
===
'
number
'
?
{
timeout
}
:
undefined
);
return
{
dispose
()
{
self
.
cancelIdleCallback
(
handle
);
}
};
};
}
})();
src/vs/workbench/browser/contributions.ts
0 → 100644
浏览文件 @
c5afb674
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
{
Registry
}
from
'
vs/platform/registry/common/platform
'
;
import
{
IInstantiationService
,
IConstructorSignature0
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
ILifecycleService
,
LifecyclePhase
}
from
'
vs/platform/lifecycle/common/lifecycle
'
;
import
{
runWhenIdle
,
IdleDeadline
}
from
'
vs/base/browser/browser
'
;
import
{
IWorkbenchContributionsRegistry
,
IWorkbenchContribution
,
IWorkbenchContributionSignature
,
Extensions
}
from
'
vs/workbench/common/contributions
'
;
class
WorkbenchContributionsRegistry
implements
IWorkbenchContributionsRegistry
{
private
instantiationService
:
IInstantiationService
;
private
lifecycleService
:
ILifecycleService
;
private
toBeInstantiated
:
Map
<
LifecyclePhase
,
IConstructorSignature0
<
IWorkbenchContribution
>
[]
>
=
new
Map
<
LifecyclePhase
,
IConstructorSignature0
<
IWorkbenchContribution
>
[]
>
();
registerWorkbenchContribution
(
ctor
:
IWorkbenchContributionSignature
,
phase
:
LifecyclePhase
=
LifecyclePhase
.
Starting
):
void
{
// Instantiate directly if we are already matching the provided phase
if
(
this
.
instantiationService
&&
this
.
lifecycleService
&&
this
.
lifecycleService
.
phase
>=
phase
)
{
this
.
instantiationService
.
createInstance
(
ctor
);
}
// Otherwise keep contributions by lifecycle phase
else
{
let
toBeInstantiated
=
this
.
toBeInstantiated
.
get
(
phase
);
if
(
!
toBeInstantiated
)
{
toBeInstantiated
=
[];
this
.
toBeInstantiated
.
set
(
phase
,
toBeInstantiated
);
}
toBeInstantiated
.
push
(
ctor
);
}
}
start
(
instantiationService
:
IInstantiationService
,
lifecycleService
:
ILifecycleService
):
void
{
this
.
instantiationService
=
instantiationService
;
this
.
lifecycleService
=
lifecycleService
;
[
LifecyclePhase
.
Starting
,
LifecyclePhase
.
Restoring
,
LifecyclePhase
.
Running
,
LifecyclePhase
.
Eventually
].
forEach
(
phase
=>
{
this
.
instantiateByPhase
(
instantiationService
,
lifecycleService
,
phase
);
});
}
private
instantiateByPhase
(
instantiationService
:
IInstantiationService
,
lifecycleService
:
ILifecycleService
,
phase
:
LifecyclePhase
):
void
{
// Instantiate contributions directly when phase is already reached
if
(
lifecycleService
.
phase
>=
phase
)
{
this
.
doInstantiateByPhase
(
instantiationService
,
phase
);
}
// Otherwise wait for phase to be reached
else
{
lifecycleService
.
when
(
phase
).
then
(()
=>
{
this
.
doInstantiateByPhase
(
instantiationService
,
phase
);
});
}
}
private
doInstantiateByPhase
(
instantiationService
:
IInstantiationService
,
phase
:
LifecyclePhase
):
void
{
const
toBeInstantiated
=
this
.
toBeInstantiated
.
get
(
phase
);
if
(
!
toBeInstantiated
)
{
return
;
}
if
(
phase
!==
LifecyclePhase
.
Eventually
)
{
// instantiate every synchronously and blocking
for
(
const
ctor
of
toBeInstantiated
)
{
instantiationService
.
createInstance
(
ctor
);
}
}
else
{
// for the Eventually-phase we instantiate contributions
// only when idle. this might take a few idle-busy-cycles
// but will finish within one second
let
i
=
0
;
const
instantiateSome
=
(
idle
:
IdleDeadline
)
=>
{
while
(
i
<
toBeInstantiated
.
length
)
{
const
ctor
=
toBeInstantiated
[
i
++
];
instantiationService
.
createInstance
(
ctor
);
if
(
idle
.
timeRemaining
()
<
1
)
{
// time is up -> reschedule
runWhenIdle
(
instantiateSome
,
1000
);
break
;
}
}
};
runWhenIdle
(
instantiateSome
,
1000
);
}
}
}
Registry
.
add
(
Extensions
.
Workbench
,
new
WorkbenchContributionsRegistry
());
src/vs/workbench/common/contributions.ts
浏览文件 @
c5afb674
...
...
@@ -4,10 +4,9 @@
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
{
Registry
}
from
'
vs/platform/registry/common/platform
'
;
import
{
IInstantiationService
,
IConstructorSignature0
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
ILifecycleService
,
LifecyclePhase
}
from
'
vs/platform/lifecycle/common/lifecycle
'
;
import
{
runWhenIdle
,
IdleDeadline
}
from
'
vs/base/common/async
'
;
// --- Workbench Contribution Registry
...
...
@@ -39,85 +38,3 @@ export interface IWorkbenchContributionsRegistry {
*/
start
(
instantiationService
:
IInstantiationService
,
lifecycleService
:
ILifecycleService
):
void
;
}
export
class
WorkbenchContributionsRegistry
implements
IWorkbenchContributionsRegistry
{
private
instantiationService
:
IInstantiationService
;
private
lifecycleService
:
ILifecycleService
;
private
toBeInstantiated
:
Map
<
LifecyclePhase
,
IConstructorSignature0
<
IWorkbenchContribution
>
[]
>
=
new
Map
<
LifecyclePhase
,
IConstructorSignature0
<
IWorkbenchContribution
>
[]
>
();
registerWorkbenchContribution
(
ctor
:
IWorkbenchContributionSignature
,
phase
:
LifecyclePhase
=
LifecyclePhase
.
Starting
):
void
{
// Instantiate directly if we are already matching the provided phase
if
(
this
.
instantiationService
&&
this
.
lifecycleService
&&
this
.
lifecycleService
.
phase
>=
phase
)
{
this
.
instantiationService
.
createInstance
(
ctor
);
}
// Otherwise keep contributions by lifecycle phase
else
{
let
toBeInstantiated
=
this
.
toBeInstantiated
.
get
(
phase
);
if
(
!
toBeInstantiated
)
{
toBeInstantiated
=
[];
this
.
toBeInstantiated
.
set
(
phase
,
toBeInstantiated
);
}
toBeInstantiated
.
push
(
ctor
);
}
}
start
(
instantiationService
:
IInstantiationService
,
lifecycleService
:
ILifecycleService
):
void
{
this
.
instantiationService
=
instantiationService
;
this
.
lifecycleService
=
lifecycleService
;
[
LifecyclePhase
.
Starting
,
LifecyclePhase
.
Restoring
,
LifecyclePhase
.
Running
,
LifecyclePhase
.
Eventually
].
forEach
(
phase
=>
{
this
.
instantiateByPhase
(
instantiationService
,
lifecycleService
,
phase
);
});
}
private
instantiateByPhase
(
instantiationService
:
IInstantiationService
,
lifecycleService
:
ILifecycleService
,
phase
:
LifecyclePhase
):
void
{
// Instantiate contributions directly when phase is already reached
if
(
lifecycleService
.
phase
>=
phase
)
{
this
.
doInstantiateByPhase
(
instantiationService
,
phase
);
}
// Otherwise wait for phase to be reached
else
{
lifecycleService
.
when
(
phase
).
then
(()
=>
{
this
.
doInstantiateByPhase
(
instantiationService
,
phase
);
});
}
}
private
doInstantiateByPhase
(
instantiationService
:
IInstantiationService
,
phase
:
LifecyclePhase
):
void
{
const
toBeInstantiated
=
this
.
toBeInstantiated
.
get
(
phase
);
if
(
!
toBeInstantiated
)
{
return
;
}
if
(
phase
!==
LifecyclePhase
.
Eventually
)
{
// instantiate every synchronously and blocking
for
(
const
ctor
of
toBeInstantiated
)
{
instantiationService
.
createInstance
(
ctor
);
}
}
else
{
// for the Eventually-phase we instantiate contributions
// only when idle. this might take a few idle-busy-cycles
// but will finish within one second
let
i
=
0
;
const
instantiateSome
=
(
idle
:
IdleDeadline
)
=>
{
while
(
i
<
toBeInstantiated
.
length
)
{
const
ctor
=
toBeInstantiated
[
i
++
];
instantiationService
.
createInstance
(
ctor
);
if
(
idle
.
timeRemaining
()
<
1
)
{
// time is up -> reschedule
runWhenIdle
(
instantiateSome
,
1000
);
break
;
}
}
};
runWhenIdle
(
instantiateSome
,
1000
);
}
}
}
Registry
.
add
(
Extensions
.
Workbench
,
new
WorkbenchContributionsRegistry
());
src/vs/workbench/electron-browser/shell.ts
浏览文件 @
c5afb674
...
...
@@ -98,7 +98,6 @@ import { ExtensionManagementServerService } from 'vs/workbench/services/extensio
import
{
DefaultURITransformer
}
from
'
vs/base/common/uriIpc
'
;
import
{
ExtensionGalleryService
}
from
'
vs/platform/extensionManagement/node/extensionGalleryService
'
;
import
{
ILabelService
}
from
'
vs/platform/label/common/label
'
;
import
{
runWhenIdle
}
from
'
vs/base/common/async
'
;
import
{
IDownloadService
}
from
'
vs/platform/download/common/download
'
;
import
{
DownloadService
}
from
'
vs/platform/download/node/downloadService
'
;
...
...
@@ -208,7 +207,7 @@ export class WorkbenchShell extends Disposable {
this
.
logStartupTelemetry
(
startupInfos
);
// Set lifecycle phase to `Runnning For A Bit` after a short delay
let
eventuallPhaseTimeoutHandle
=
runWhenIdle
(()
=>
{
let
eventuallPhaseTimeoutHandle
=
browser
.
runWhenIdle
(()
=>
{
eventuallPhaseTimeoutHandle
=
void
0
;
this
.
lifecycleService
.
phase
=
LifecyclePhase
.
Eventually
;
},
5000
);
...
...
src/vs/workbench/workbench.main.ts
浏览文件 @
c5afb674
...
...
@@ -9,6 +9,9 @@
import
'
vs/base/common/strings
'
;
import
'
vs/base/common/errors
'
;
// contributions logic
import
'
vs/workbench/browser/contributions
'
;
// Configuration
import
'
vs/workbench/services/configuration/common/configurationExtensionPoint
'
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录