Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
6c504e7e
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,发现更多精彩内容 >>
提交
6c504e7e
编写于
9月 13, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
💄
上级
406f710b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
26 addition
and
16 deletion
+26
-16
extensions/git/package.json
extensions/git/package.json
+4
-4
extensions/git/package.nls.json
extensions/git/package.nls.json
+3
-3
extensions/git/src/commands.ts
extensions/git/src/commands.ts
+19
-9
未找到文件。
extensions/git/package.json
浏览文件 @
6c504e7e
...
...
@@ -936,14 +936,14 @@
"usesOnlineServices"
]
},
"git.
createBranchNameConvention.regexp
"
:
{
"git.
branchValidationRegex
"
:
{
"type"
:
"string"
,
"description"
:
"%config.
createBranchNameConvention.regexp
%"
,
"description"
:
"%config.
branchValidationRegex
%"
,
"default"
:
""
},
"git.
createB
ranchWhitespaceChar"
:
{
"git.
b
ranchWhitespaceChar"
:
{
"type"
:
"string"
,
"description"
:
"%config.
createB
ranchWhitespaceChar%"
,
"description"
:
"%config.
b
ranchWhitespaceChar%"
,
"default"
:
"-"
},
"git.confirmSync"
:
{
...
...
extensions/git/package.nls.json
浏览文件 @
6c504e7e
...
...
@@ -72,8 +72,8 @@
"config.checkoutType.local"
:
"Show only local branches."
,
"config.checkoutType.tags"
:
"Show only tags."
,
"config.checkoutType.remote"
:
"Show only remote branches."
,
"config.
createBranchNameConvention.regexp"
:
"The regex that is used to match create branch against convention
."
,
"config.
createBranchWhitespaceChar"
:
"The char to replace whitespace in branch name when creating branch
."
,
"config.
branchValidationRegex"
:
"A regular expression to validate new branch names
."
,
"config.
branchWhitespaceChar"
:
"The character to replace whitespace in new branch names
."
,
"config.ignoreLegacyWarning"
:
"Ignores the legacy Git warning."
,
"config.ignoreMissingGitWarning"
:
"Ignores the warning when Git is missing."
,
"config.ignoreLimitWarning"
:
"Ignores the warning when there are too many changes in a repository."
,
...
...
@@ -102,4 +102,4 @@
"colors.ignored"
:
"Color for ignored resources."
,
"colors.conflict"
:
"Color for resources with conflicts."
,
"colors.submodule"
:
"Color for submodule resources."
}
}
\ No newline at end of file
extensions/git/src/commands.ts
浏览文件 @
6c504e7e
...
...
@@ -1261,32 +1261,42 @@ export class CommandCenter {
await
choice
.
run
(
repository
);
}
private
removeBranchNameWhitespace
(
name
:
string
)
{
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
return
name
.
replace
(
/^
\.
|
\/\.
|
\.\.
|~|
\^
|:|
\/
$|
\.
lock$|
\.
lock
\/
|
\\
|
\*
|
\s
|^
\s
*$|
\.
|
\[
|
\]
|$/g
,
config
.
createBranchWhitespaceChar
);
}
@
command
(
'
git.branch
'
,
{
repository
:
true
})
async
branch
(
repository
:
Repository
):
Promise
<
void
>
{
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
validateName
=
new
RegExp
(
config
.
createBranchNameConvention
.
regexp
);
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
;
}
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
(
this
.
removeBranchNameWhitespac
e
(
name
)))
{
if
(
validateName
.
test
(
sanitiz
e
(
name
)))
{
return
null
;
}
return
`
${
localize
(
'
branch name format invalid
'
,
"
Have to be in the format
"
)}
:
${
config
.
createBranchNameConvention
.
regexp
}
`
;
return
localize
(
'
branch name format invalid
'
,
"
Branch name needs to match regex: {0}
"
,
branchValidationRegex
);
}
});
if
(
!
result
)
{
const
name
=
sanitize
(
result
||
''
);
if
(
!
name
)
{
return
;
}
const
name
=
this
.
removeBranchNameWhitespace
(
result
);
await
repository
.
branch
(
name
,
true
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录