Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
71701f98
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,发现更多精彩内容 >>
提交
71701f98
编写于
12月 15, 2017
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'repo-rank' of
https://github.com/keegancsmith/vscode
into keegancsmith-repo-rank
上级
05c9c533
b4d51dcc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
29 addition
and
2 deletion
+29
-2
extensions/git/src/model.ts
extensions/git/src/model.ts
+29
-2
未找到文件。
extensions/git/src/model.ts
浏览文件 @
71701f98
...
...
@@ -27,7 +27,7 @@ class RepositoryPick implements QuickPickItem {
.
join
(
'
'
);
}
constructor
(
public
readonly
repository
:
Repository
)
{
}
constructor
(
public
readonly
repository
:
Repository
,
public
readonly
index
:
number
)
{
}
}
export
interface
ModelChangeEvent
{
...
...
@@ -256,7 +256,34 @@ export class Model {
throw
new
Error
(
localize
(
'
no repositories
'
,
"
There are no available repositories
"
));
}
const
picks
=
this
.
openRepositories
.
map
(
e
=>
new
RepositoryPick
(
e
.
repository
));
const
picks
=
this
.
openRepositories
.
map
((
e
,
index
)
=>
new
RepositoryPick
(
e
.
repository
,
index
));
// Sort picks such that repositories containing the active text editor
// appear first.
const
active
=
window
.
activeTextEditor
;
if
(
active
&&
active
.
document
.
fileName
)
{
const
hasActiveEditor
=
(
root
:
string
)
=>
{
const
relative
=
path
.
relative
(
root
,
active
.
document
.
fileName
);
return
!!
relative
&&
!
relative
.
startsWith
(
'
..
'
)
&&
!
path
.
isAbsolute
(
relative
);
};
picks
.
sort
((
a
,
b
)
=>
{
const
aHas
=
hasActiveEditor
(
a
.
repository
.
root
);
const
bHas
=
hasActiveEditor
(
b
.
repository
.
root
);
if
(
aHas
!==
bHas
)
{
return
aHas
?
-
1
:
1
;
}
if
(
aHas
&&
a
.
repository
.
root
.
length
!==
b
.
repository
.
root
.
length
)
{
// Both a and b contain the active editor document, so one
// is an ancestor of the other. We prefer to return the
// child (likely a submodule) since the active editor will
// be part of that repo. Child is the longer path.
return
b
.
repository
.
root
.
length
-
a
.
repository
.
root
.
length
;
}
// Otherwise everything else is equal, so keeps the positions stable
return
a
.
index
-
b
.
index
;
});
}
const
placeHolder
=
localize
(
'
pick repo
'
,
"
Choose a repository
"
);
const
pick
=
await
window
.
showQuickPick
(
picks
,
{
placeHolder
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录