Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
f004d866
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,发现更多精彩内容 >>
提交
f004d866
编写于
10月 09, 2018
作者:
O
Omkar Manjrekar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Added definition for addRemote
上级
9983f260
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
33 deletion
+32
-33
extensions/git/src/commands.ts
extensions/git/src/commands.ts
+32
-33
未找到文件。
extensions/git/src/commands.ts
浏览文件 @
f004d866
...
...
@@ -1711,49 +1711,48 @@ export class CommandCenter {
await
this
.
_push
(
repository
,
{
pushType
:
PushType
.
PushTo
,
forcePush
:
true
});
}
private
async
_remote
(
repository
:
Repository
,
rebase
:
boolean
):
Promise
<
void
>
{
const
HEAD
=
repository
.
HEAD
;
if
(
!
HEAD
||
!
HEAD
.
upstream
)
{
return
;
}
@
command
(
'
git.addRemote
'
,
{
repository
:
true
})
async
addRemote
(
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
();
const
remoteName
=
HEAD
.
remote
||
HEAD
.
upstream
.
remote
;
const
remote
=
repository
.
remotes
.
find
(
r
=>
r
.
name
===
remoteName
)
;
const
isReadonly
=
remote
&&
remote
.
isReadOnly
;
if
(
!
name
)
{
return
name
;
}
const
config
=
workspace
.
getConfiguration
(
'
git
'
);
const
shouldPrompt
=
!
isReadonly
&&
config
.
get
<
boolean
>
(
'
confirmSync
'
)
===
true
;
return
name
.
replace
(
/^
\.
|
\/\.
|
\.\.
|~|
\^
|:|
\/
$|
\.
lock$|
\.
lock
\/
|
\\
|
\*
|
\s
|^
\s
*$|
\.
$|
\[
|
\]
$/g
,
branchWhitespaceChar
);
}
;
if
(
shouldPrompt
)
{
const
message
=
localize
(
'
sync is unpredictable
'
,
"
This action will push and pull commits to and from '{0}/{1}'.
"
,
HEAD
.
upstream
.
remote
,
HEAD
.
upstream
.
name
);
const
yes
=
localize
(
'
ok
'
,
"
OK
"
);
const
neverAgain
=
localize
(
'
never again
'
,
"
OK, Don't Show Again
"
);
const
pick
=
await
window
.
showWarningMessage
(
message
,
{
modal
:
true
},
yes
,
neverAgain
);
const
result
=
await
window
.
showInputBox
({
placeHolder
:
localize
(
'
remote name
'
,
"
Remote name
"
),
prompt
:
localize
(
'
provide remote name
'
,
"
Please provide a remote name
"
),
ignoreFocusOut
:
true
,
validateInput
:
(
name
:
string
)
=>
{
if
(
validateName
.
test
(
sanitize
(
name
)))
{
return
null
;
}
if
(
pick
===
neverAgain
)
{
await
config
.
update
(
'
confirmSync
'
,
false
,
true
);
}
else
if
(
pick
!==
yes
)
{
return
;
return
localize
(
'
branch name format invalid
'
,
"
Branch name needs to match regex: {0}
"
,
branchValidationRegex
);
}
}
}
);
if
(
rebase
)
{
await
repository
.
syncRebase
(
HEAD
);
}
else
{
await
repository
.
sync
(
HEAD
)
;
const
name
=
sanitize
(
result
||
''
);
if
(
!
name
)
{
return
;
}
await
repository
.
branch
(
name
,
true
);
}
// @command('git.addRemote', { repository: true })
// async addRemote(repository: Repository): Promise<void> {
// await this._remote(repository, { pushType: PushType.PushTo });
// }
@
command
(
'
git.removeRemote
'
,
{
repository
:
true
})
async
removeRemote
(
repository
:
Repository
):
Promise
<
void
>
{
// @command('git.removeRemote', { repository: true })
// async removeRemote(repository: Repository): Promise<void> {
// await this._remote(repository, { pushType: PushType.PushTo, forcePush: true });
// }
}
private
async
_sync
(
repository
:
Repository
,
rebase
:
boolean
):
Promise
<
void
>
{
const
HEAD
=
repository
.
HEAD
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录