Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
3b76085a
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,发现更多精彩内容 >>
提交
3b76085a
编写于
9月 28, 2017
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixes #35216
上级
2295b67e
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
46 addition
and
17 deletion
+46
-17
extensions/git/src/autofetch.ts
extensions/git/src/autofetch.ts
+36
-14
extensions/git/src/contentProvider.ts
extensions/git/src/contentProvider.ts
+9
-2
extensions/git/src/repository.ts
extensions/git/src/repository.ts
+1
-1
未找到文件。
extensions/git/src/autofetch.ts
浏览文件 @
3b76085a
...
...
@@ -5,16 +5,23 @@
'
use strict
'
;
import
{
workspace
,
Disposable
}
from
'
vscode
'
;
import
{
workspace
,
Disposable
,
EventEmitter
}
from
'
vscode
'
;
import
{
GitErrorCodes
}
from
'
./git
'
;
import
{
Repository
}
from
'
./repository
'
;
import
{
throttle
}
from
'
./decorators
'
;
import
{
eventToPromise
,
filterEvent
}
from
'
./util
'
;
export
class
AutoFetcher
{
private
static
Period
=
3
*
60
*
1000
/* three minutes */
;
private
_onDidChange
=
new
EventEmitter
<
boolean
>
();
private
onDidChange
=
this
.
_onDidChange
.
event
;
private
_enabled
:
boolean
=
false
;
get
enabled
():
boolean
{
return
this
.
_enabled
;
}
set
enabled
(
enabled
:
boolean
)
{
this
.
_enabled
=
enabled
;
this
.
_onDidChange
.
fire
(
enabled
);
}
private
disposables
:
Disposable
[]
=
[];
private
timer
:
NodeJS
.
Timer
;
constructor
(
private
repository
:
Repository
)
{
workspace
.
onDidChangeConfiguration
(
this
.
onConfiguration
,
this
,
this
.
disposables
);
...
...
@@ -32,26 +39,41 @@ export class AutoFetcher {
}
enable
():
void
{
if
(
this
.
timer
)
{
if
(
this
.
enabled
)
{
return
;
}
this
.
fetch
()
;
this
.
timer
=
setInterval
(()
=>
this
.
fetch
(),
AutoFetcher
.
Period
);
this
.
enabled
=
true
;
this
.
run
(
);
}
disable
():
void
{
clearInterval
(
this
.
timer
)
;
this
.
enabled
=
false
;
}
@
throttle
private
async
fetch
():
Promise
<
void
>
{
try
{
await
this
.
repository
.
fetch
();
}
catch
(
err
)
{
if
(
err
.
gitErrorCode
===
GitErrorCodes
.
AuthenticationFailed
)
{
this
.
disable
();
private
async
run
():
Promise
<
void
>
{
while
(
this
.
enabled
)
{
await
this
.
repository
.
whenIdleAndFocused
();
if
(
!
this
.
enabled
)
{
return
;
}
try
{
await
this
.
repository
.
fetch
();
}
catch
(
err
)
{
if
(
err
.
gitErrorCode
===
GitErrorCodes
.
AuthenticationFailed
)
{
this
.
disable
();
}
}
if
(
!
this
.
enabled
)
{
return
;
}
const
timeout
=
new
Promise
(
c
=>
setTimeout
(
c
,
AutoFetcher
.
Period
));
const
whenDisabled
=
eventToPromise
(
filterEvent
(
this
.
onDidChange
,
enabled
=>
!
enabled
));
await
Promise
.
race
([
timeout
,
whenDisabled
]);
}
}
...
...
extensions/git/src/contentProvider.ts
浏览文件 @
3b76085a
...
...
@@ -6,9 +6,10 @@
'
use strict
'
;
import
{
workspace
,
Uri
,
Disposable
,
Event
,
EventEmitter
,
window
}
from
'
vscode
'
;
import
{
debounce
}
from
'
./decorators
'
;
import
{
debounce
,
throttle
}
from
'
./decorators
'
;
import
{
fromGitUri
}
from
'
./uri
'
;
import
{
Model
,
ModelChangeEvent
}
from
'
./model
'
;
import
{
filterEvent
,
eventToPromise
}
from
'
./util
'
;
interface
CacheRow
{
uri
:
Uri
;
...
...
@@ -50,7 +51,13 @@ export class GitContentProvider {
this
.
fireChangeEvents
();
}
private
fireChangeEvents
():
void
{
@
throttle
private
async
fireChangeEvents
():
Promise
<
void
>
{
if
(
!
window
.
state
.
focused
)
{
const
onDidFocusWindow
=
filterEvent
(
window
.
onDidChangeWindowState
,
e
=>
e
.
focused
);
await
eventToPromise
(
onDidFocusWindow
);
}
Object
.
keys
(
this
.
cache
).
forEach
(
key
=>
{
const
uri
=
this
.
cache
[
key
].
uri
;
const
fsPath
=
uri
.
fsPath
;
...
...
extensions/git/src/repository.ts
浏览文件 @
3b76085a
...
...
@@ -816,7 +816,7 @@ export class Repository implements Disposable {
await
timeout
(
5000
);
}
private
async
whenIdleAndFocused
():
Promise
<
void
>
{
async
whenIdleAndFocused
():
Promise
<
void
>
{
while
(
true
)
{
if
(
!
this
.
operations
.
isIdle
())
{
await
eventToPromise
(
this
.
onDidRunOperation
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录