Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
ad6660d0
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,发现更多精彩内容 >>
提交
ad6660d0
编写于
9月 21, 2018
作者:
G
Guy Waldman
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add command to create branch from specific ref
上级
7ff8bda7
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
63 addition
and
45 deletion
+63
-45
extensions/git/package.json
extensions/git/package.json
+5
-0
extensions/git/package.nls.json
extensions/git/package.nls.json
+1
-0
extensions/git/src/commands.ts
extensions/git/src/commands.ts
+57
-45
未找到文件。
extensions/git/package.json
浏览文件 @
ad6660d0
...
...
@@ -240,6 +240,11 @@
"title"
:
"%command.branch%"
,
"category"
:
"Git"
},
{
"command"
:
"git.branchFrom"
,
"title"
:
"%command.branchFrom%"
,
"category"
:
"Git"
},
{
"command"
:
"git.deleteBranch"
,
"title"
:
"%command.deleteBranch%"
,
...
...
extensions/git/package.nls.json
浏览文件 @
ad6660d0
...
...
@@ -32,6 +32,7 @@
"command.undoCommit"
:
"Undo Last Commit"
,
"command.checkout"
:
"Checkout to..."
,
"command.branch"
:
"Create Branch..."
,
"command.branchFrom"
:
"Create Branch From..."
,
"command.deleteBranch"
:
"Delete Branch..."
,
"command.renameBranch"
:
"Rename Branch..."
,
"command.merge"
:
"Merge Branch..."
,
...
...
extensions/git/src/commands.ts
浏览文件 @
ad6660d0
...
...
@@ -154,6 +154,47 @@ async function categorizeResourceByResolution(resources: Resource[]): Promise<{
return
{
merge
,
resolved
,
unresolved
,
deletionConflicts
};
}
function
repositoryRefsToItems
(
repository
:
Repository
):
Array
<
CheckoutItem
>
{
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
checkoutType
=
config
.
get
<
string
>
(
'
checkoutType
'
)
||
'
all
'
;
const
includeTags
=
checkoutType
===
'
all
'
||
checkoutType
===
'
tags
'
;
const
includeRemotes
=
checkoutType
===
'
all
'
||
checkoutType
===
'
remote
'
;
const
heads
=
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
Head
)
.
map
(
ref
=>
new
CheckoutItem
(
ref
));
const
tags
=
(
includeTags
?
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
Tag
)
:
[])
.
map
(
ref
=>
new
CheckoutTagItem
(
ref
));
const
remoteHeads
=
(
includeRemotes
?
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
RemoteHead
)
:
[])
.
map
(
ref
=>
new
CheckoutRemoteHeadItem
(
ref
));
return
[...
heads
,
...
tags
,
...
remoteHeads
];
}
async
function
inputNameForBranch
():
Promise
<
string
>
{
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
branchWhitespaceChar
=
config
.
get
<
string
>
(
'
branchWhitespaceChar
'
)
!
;
const
branchValidationRegex
=
config
.
get
<
string
>
(
'
branchValidationRegex
'
)
!
;
const
sanitize
=
(
name
:
string
)
=>
name
?
name
.
trim
().
replace
(
/^
\.
|
\/\.
|
\.\.
|~|
\^
|:|
\/
$|
\.
lock$|
\.
lock
\/
|
\\
|
\*
|
\s
|^
\s
*$|
\.
$|
\[
|
\]
$/g
,
branchWhitespaceChar
)
:
name
;
const
result
=
await
window
.
showInputBox
({
placeHolder
:
localize
(
'
branch name
'
,
"
Branch name
"
),
prompt
:
localize
(
'
provide branch name
'
,
"
Please provide a branch name
"
),
ignoreFocusOut
:
true
,
validateInput
:
(
name
:
string
)
=>
{
const
validateName
=
new
RegExp
(
branchValidationRegex
);
if
(
validateName
.
test
(
sanitize
(
name
)))
{
return
null
;
}
return
localize
(
'
branch name format invalid
'
,
"
Branch name needs to match regex: {0}
"
,
branchValidationRegex
);
}
});
return
sanitize
(
result
||
''
);
}
enum
PushType
{
Push
,
PushTo
,
...
...
@@ -1352,24 +1393,9 @@ export class CommandCenter {
await
repository
.
checkout
(
treeish
);
return
true
;
}
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
checkoutType
=
config
.
get
<
string
>
(
'
checkoutType
'
)
||
'
all
'
;
const
includeTags
=
checkoutType
===
'
all
'
||
checkoutType
===
'
tags
'
;
const
includeRemotes
=
checkoutType
===
'
all
'
||
checkoutType
===
'
remote
'
;
const
createBranch
=
new
CreateBranchItem
(
this
);
const
heads
=
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
Head
)
.
map
(
ref
=>
new
CheckoutItem
(
ref
));
const
tags
=
(
includeTags
?
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
Tag
)
:
[])
.
map
(
ref
=>
new
CheckoutTagItem
(
ref
));
const
remoteHeads
=
(
includeRemotes
?
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
RemoteHead
)
:
[])
.
map
(
ref
=>
new
CheckoutRemoteHeadItem
(
ref
));
const
picks
=
[
createBranch
,
...
heads
,
...
tags
,
...
remoteHeads
];
const
picks
=
[
createBranch
,
...
repositoryRefsToItems
(
repository
)];
const
placeHolder
=
localize
(
'
select a ref to checkout
'
,
'
Select a ref to checkout
'
);
const
choice
=
await
window
.
showQuickPick
(
picks
,
{
placeHolder
});
...
...
@@ -1382,41 +1408,27 @@ export class CommandCenter {
}
@
command
(
'
git.branch
'
,
{
repository
:
true
})
async
branch
(
repository
:
Repository
):
Promise
<
void
>
{
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
branchValidationRegex
=
config
.
get
<
string
>
(
'
branchValidationRegex
'
)
!
;
const
branchWhitespaceChar
=
config
.
get
<
string
>
(
'
branchWhitespaceChar
'
)
!
;
const
validateName
=
new
RegExp
(
branchValidationRegex
);
const
sanitize
=
(
name
:
string
)
=>
{
name
=
name
.
trim
();
if
(
!
name
)
{
return
name
;
}
async
branch
(
repository
:
Repository
,
ref
?:
string
):
Promise
<
void
>
{
const
name
=
await
inputNameForBranch
();
return
name
.
replace
(
/^
\.
|
\/\.
|
\.\.
|~|
\^
|:|
\/
$|
\.
lock$|
\.
lock
\/
|
\\
|
\*
|
\s
|^
\s
*$|
\.
$|
\[
|
\]
$/g
,
branchWhitespaceChar
);
};
const
result
=
await
window
.
showInputBox
({
placeHolder
:
localize
(
'
branch name
'
,
"
Branch name
"
),
prompt
:
localize
(
'
provide branch name
'
,
"
Please provide a branch name
"
),
ignoreFocusOut
:
true
,
validateInput
:
(
name
:
string
)
=>
{
if
(
validateName
.
test
(
sanitize
(
name
)))
{
return
null
;
}
if
(
!
name
)
{
return
;
}
return
localize
(
'
branch name format invalid
'
,
"
Branch name needs to match regex: {0}
"
,
branchValidationRegex
);
}
});
await
repository
.
branch
(
name
,
true
,
ref
);
}
const
name
=
sanitize
(
result
||
''
);
@
command
(
'
git.branchFrom
'
,
{
repository
:
true
})
async
createBranchFrom
(
repository
:
Repository
):
Promise
<
void
>
{
const
refs
=
repositoryRefsToItems
(
repository
);
const
placeHolder
=
localize
(
'
select a ref to create a new branch from
'
,
'
Select a ref to create a new branch from
'
);
const
choice
=
await
window
.
showQuickPick
(
refs
,
{
placeHolder
});
if
(
!
nam
e
)
{
if
(
!
choic
e
)
{
return
;
}
await
repository
.
branch
(
name
,
true
);
await
this
.
branch
(
repository
,
choice
.
label
);
}
@
command
(
'
git.deleteBranch
'
,
{
repository
:
true
})
...
...
@@ -1937,7 +1949,7 @@ export class CommandCenter {
return
Promise
.
resolve
();
}
return
Promise
.
resolve
(
method
.
apply
(
this
,
[
repository
,
...
args
]));
return
Promise
.
resolve
(
method
.
apply
(
this
,
[
repository
,
...
args
.
slice
(
1
)
]));
});
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录