Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
d5880b1a
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,发现更多精彩内容 >>
提交
d5880b1a
编写于
10月 17, 2017
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
deco - decorate ignored files
上级
68797abd
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
94 addition
and
5 deletion
+94
-5
extensions/git/src/decorationProvider.ts
extensions/git/src/decorationProvider.ts
+54
-2
extensions/git/src/repository.ts
extensions/git/src/repository.ts
+36
-0
src/vs/workbench/services/decorations/browser/decorationsService.ts
...kbench/services/decorations/browser/decorationsService.ts
+4
-3
未找到文件。
extensions/git/src/decorationProvider.ts
浏览文件 @
d5880b1a
...
...
@@ -8,6 +8,57 @@
import
{
window
,
Uri
,
Disposable
,
Event
,
EventEmitter
,
DecorationData
,
DecorationProvider
}
from
'
vscode
'
;
import
{
Repository
,
GitResourceGroup
}
from
'
./repository
'
;
import
{
Model
}
from
'
./model
'
;
import
{
debounce
}
from
'
./decorators
'
;
class
GitIgnoreDecorationProvider
implements
DecorationProvider
{
private
readonly
_onDidChangeDecorations
=
new
EventEmitter
<
Uri
[]
>
();
readonly
onDidChangeDecorations
:
Event
<
Uri
[]
>
=
this
.
_onDidChangeDecorations
.
event
;
private
checkIgnoreQueue
=
new
Map
<
string
,
{
resolve
:
(
status
:
boolean
)
=>
void
,
reject
:
(
err
:
any
)
=>
void
}
>
();
private
disposables
:
Disposable
[]
=
[];
constructor
(
private
repository
:
Repository
)
{
this
.
disposables
.
push
(
window
.
registerDecorationProvider
(
this
,
'
.gitignore
'
)
//todo@joh -> events when the ignore status actually changes, not when the file changes
);
}
dispose
():
void
{
this
.
disposables
.
forEach
(
d
=>
d
.
dispose
());
this
.
checkIgnoreQueue
.
clear
();
}
provideDecoration
(
uri
:
Uri
):
Promise
<
DecorationData
|
undefined
>
{
return
new
Promise
<
boolean
>
((
resolve
,
reject
)
=>
{
this
.
checkIgnoreQueue
.
set
(
uri
.
fsPath
,
{
resolve
,
reject
});
this
.
checkIgnoreSoon
();
}).
then
(
ignored
=>
{
if
(
ignored
)
{
return
<
DecorationData
>
{
priority
:
3
,
opacity
:
0.75
};
}
});
}
@
debounce
(
500
)
private
checkIgnoreSoon
():
void
{
const
queue
=
new
Map
(
this
.
checkIgnoreQueue
.
entries
());
this
.
checkIgnoreQueue
.
clear
();
this
.
repository
.
checkIgnore
([...
queue
.
keys
()]).
then
(
ignoreSet
=>
{
for
(
const
[
key
,
value
]
of
queue
.
entries
())
{
value
.
resolve
(
ignoreSet
.
has
(
key
));
}
},
err
=>
{
for
(
const
[,
value
]
of
queue
.
entries
())
{
value
.
reject
(
err
);
}
});
}
}
class
GitDecorationProvider
implements
DecorationProvider
{
...
...
@@ -65,7 +116,7 @@ class GitDecorationProvider implements DecorationProvider {
export
class
GitDecorations
{
private
disposables
:
Disposable
[]
=
[];
private
providers
=
new
Map
<
Repository
,
GitDecorationProvider
>
();
private
providers
=
new
Map
<
Repository
,
Disposable
>
();
constructor
(
private
model
:
Model
)
{
this
.
disposables
.
push
(
...
...
@@ -77,7 +128,8 @@ export class GitDecorations {
private
onDidOpenRepository
(
repository
:
Repository
):
void
{
const
provider
=
new
GitDecorationProvider
(
repository
);
this
.
providers
.
set
(
repository
,
provider
);
const
ignoreProvider
=
new
GitIgnoreDecorationProvider
(
repository
);
this
.
providers
.
set
(
repository
,
Disposable
.
from
(
provider
,
ignoreProvider
));
}
private
onDidCloseRepository
(
repository
:
Repository
):
void
{
...
...
extensions/git/src/repository.ts
浏览文件 @
d5880b1a
...
...
@@ -646,6 +646,42 @@ export class Repository implements Disposable {
});
}
checkIgnore
(
filePaths
:
string
[]):
Promise
<
Set
<
string
>>
{
return
this
.
run
(
Operation
.
Ignore
,
()
=>
{
return
new
Promise
<
Set
<
string
>>
((
resolve
,
reject
)
=>
{
const
child
=
this
.
repository
.
stream
([
'
check-ignore
'
,
...
filePaths
]);
const
onExit
=
exitCode
=>
{
if
(
exitCode
===
1
)
{
// nothing ignored
resolve
(
new
Set
<
string
>
());
}
else
if
(
exitCode
===
0
)
{
// each line is something ignored
resolve
(
new
Set
<
string
>
(
data
.
split
(
'
\n
'
)));
}
else
{
reject
();
}
};
let
data
=
''
;
const
onStdoutData
=
(
raw
:
string
)
=>
{
data
+=
raw
;
};
child
.
stdout
.
setEncoding
(
'
utf8
'
);
child
.
stdout
.
on
(
'
data
'
,
onStdoutData
);
// const stderrData: string[] = [];
// child.stderr.setEncoding('utf8');
// child.stderr.on('data', raw => stderrData.push(raw as string));
child
.
on
(
'
error
'
,
reject
);
child
.
on
(
'
exit
'
,
onExit
);
});
});
}
private
async
run
<
T
>
(
operation
:
Operation
,
runOperation
:
()
=>
Promise
<
T
>
=
()
=>
Promise
.
resolve
<
any
>
(
null
)):
Promise
<
T
>
{
if
(
this
.
state
!==
RepositoryState
.
Idle
)
{
throw
new
Error
(
'
Repository not initialized
'
);
...
...
src/vs/workbench/services/decorations/browser/decorationsService.ts
浏览文件 @
d5880b1a
...
...
@@ -249,15 +249,16 @@ class DecorationProviderWrapper {
return
;
}
if
(
item
===
undefined
&&
!
includeChildren
)
{
// unknown
, a leaf node
-> trigger request
if
(
item
===
undefined
)
{
// unknown -> trigger request
item
=
this
.
_fetchData
(
uri
);
}
if
(
item
)
{
//
leaf node
//
found something
callback
(
item
,
false
);
}
if
(
includeChildren
)
{
// (resolved) children
const
childTree
=
this
.
data
.
findSuperstr
(
key
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录