Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
f4025754
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f4025754
编写于
10月 24, 2019
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
cleanup git delete tag command
上级
23a4df36
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
17 addition
and
60 deletion
+17
-60
extensions/git/package.json
extensions/git/package.json
+0
-5
extensions/git/package.nls.json
extensions/git/package.nls.json
+0
-1
extensions/git/src/api/git.d.ts
extensions/git/src/api/git.d.ts
+0
-5
extensions/git/src/commands.ts
extensions/git/src/commands.ts
+15
-27
extensions/git/src/git.ts
extensions/git/src/git.ts
+1
-16
extensions/git/src/repository.ts
extensions/git/src/repository.ts
+1
-6
未找到文件。
extensions/git/package.json
浏览文件 @
f4025754
...
...
@@ -272,11 +272,6 @@
"title"
:
"%command.deleteTag%"
,
"category"
:
"Git"
},
{
"command"
:
"git.getTags"
,
"title"
:
"%command.getTags%"
,
"category"
:
"Git"
},
{
"command"
:
"git.fetch"
,
"title"
:
"%command.fetch%"
,
...
...
extensions/git/package.nls.json
浏览文件 @
f4025754
...
...
@@ -38,7 +38,6 @@
"command.merge"
:
"Merge Branch..."
,
"command.createTag"
:
"Create Tag"
,
"command.deleteTag"
:
"Delete Tag"
,
"command.getTags"
:
"Get Tags"
,
"command.fetch"
:
"Fetch"
,
"command.fetchPrune"
:
"Fetch (Prune)"
,
"command.fetchAll"
:
"Fetch From All Remotes"
,
...
...
extensions/git/src/api/git.d.ts
浏览文件 @
f4025754
...
...
@@ -37,11 +37,6 @@ export interface Branch extends Ref {
readonly
behind
?:
number
;
}
export
interface
Tag
extends
Ref
{
readonly
name
:
string
;
readonly
message
?:
string
;
}
export
interface
Commit
{
readonly
hash
:
string
;
readonly
message
:
string
;
...
...
extensions/git/src/commands.ts
浏览文件 @
f4025754
...
...
@@ -15,7 +15,7 @@ import { lstat, Stats } from 'fs';
import
*
as
os
from
'
os
'
;
import
TelemetryReporter
from
'
vscode-extension-telemetry
'
;
import
*
as
nls
from
'
vscode-nls
'
;
import
{
Ref
,
RefType
,
Branch
,
GitErrorCodes
,
Status
,
Tag
}
from
'
./api/git
'
;
import
{
Ref
,
RefType
,
Branch
,
GitErrorCodes
,
Status
}
from
'
./api/git
'
;
const
localize
=
nls
.
loadMessageBundle
();
...
...
@@ -38,25 +38,6 @@ class CheckoutItem implements QuickPickItem {
}
}
class
TagItem
implements
QuickPickItem
{
get
label
():
string
{
return
(
this
.
tag
.
name
||
''
).
substr
(
0
,
20
);
}
get
name
():
string
{
return
(
this
.
tag
.
name
||
''
);
}
get
description
():
string
{
return
(
this
.
tag
.
message
||
''
);
}
constructor
(
protected
tag
:
Tag
)
{
}
async
run
(
repository
:
Repository
):
Promise
<
void
>
{
const
name
=
this
.
tag
.
name
||
''
;
if
(
!
name
)
{
return
;
}
await
repository
.
deleteTag
(
name
);
}
}
class
CheckoutTagItem
extends
CheckoutItem
{
get
description
():
string
{
...
...
@@ -232,9 +213,10 @@ function createCheckoutItems(repository: Repository): CheckoutItem[] {
return
[...
heads
,
...
tags
,
...
remoteHeads
];
}
async
function
createTagItems
(
repository
:
Repository
):
Promise
<
TagItem
[]
>
{
const
tags
=
await
repository
.
getTags
();
return
tags
.
map
(
tag
=>
new
TagItem
(
tag
))
||
[];
class
TagItem
implements
QuickPickItem
{
get
label
():
string
{
return
this
.
ref
.
name
??
''
;
}
get
description
():
string
{
return
this
.
ref
.
commit
?.
substr
(
0
,
8
)
??
''
;
}
constructor
(
readonly
ref
:
Ref
)
{
}
}
enum
PushType
{
...
...
@@ -1731,16 +1713,22 @@ export class CommandCenter {
@
command
(
'
git.deleteTag
'
,
{
repository
:
true
})
async
deleteTag
(
repository
:
Repository
):
Promise
<
void
>
{
const
picks
=
await
createTagItems
(
repository
);
if
(
!
picks
)
{
const
picks
=
repository
.
refs
.
filter
(
ref
=>
ref
.
type
===
RefType
.
Tag
)
.
map
(
ref
=>
new
TagItem
(
ref
));
if
(
picks
.
length
===
0
)
{
window
.
showWarningMessage
(
localize
(
'
no tags
'
,
"
This repository has no tags.
"
));
return
;
}
const
placeHolder
=
localize
(
'
select a tag to delete
'
,
'
Select a tag to delete
'
);
const
choice
=
await
window
.
showQuickPick
<
TagItem
>
(
picks
,
{
placeHolder
});
const
choice
=
await
window
.
showQuickPick
(
picks
,
{
placeHolder
});
if
(
!
choice
)
{
return
;
}
await
repository
.
deleteTag
(
choice
.
name
);
await
repository
.
deleteTag
(
choice
.
label
);
}
@
command
(
'
git.fetch
'
,
{
repository
:
true
})
...
...
extensions/git/src/git.ts
浏览文件 @
f4025754
...
...
@@ -15,7 +15,7 @@ import { assign, groupBy, denodeify, IDisposable, toDisposable, dispose, mkdirp,
import
{
CancellationToken
,
Progress
}
from
'
vscode
'
;
import
{
URI
}
from
'
vscode-uri
'
;
import
{
detectEncoding
}
from
'
./encoding
'
;
import
{
Ref
,
RefType
,
Branch
,
Remote
,
GitErrorCodes
,
LogOptions
,
Change
,
Status
,
Tag
}
from
'
./api/git
'
;
import
{
Ref
,
RefType
,
Branch
,
Remote
,
GitErrorCodes
,
LogOptions
,
Change
,
Status
}
from
'
./api/git
'
;
import
*
as
byline
from
'
byline
'
;
import
{
StringDecoder
}
from
'
string_decoder
'
;
...
...
@@ -1332,21 +1332,6 @@ export class Repository {
await
this
.
run
(
args
);
}
async
getTags
():
Promise
<
Tag
[]
>
{
let
args
=
[
'
tag
'
,
'
-n1
'
];
const
result
=
await
this
.
run
(
args
);
return
result
.
stdout
.
trim
().
split
(
'
\n
'
)
.
map
(
line
=>
line
.
trim
().
split
(
'
\
0
'
))
.
map
(([
line
])
=>
{
const
name
=
line
.
split
(
'
'
)[
0
];
return
{
name
:
name
,
message
:
line
.
replace
(
name
,
''
).
trim
()
||
''
,
type
:
RefType
.
Tag
}
as
Tag
;
});
}
async
clean
(
paths
:
string
[]):
Promise
<
void
>
{
const
pathsByGroup
=
groupBy
(
paths
,
p
=>
path
.
dirname
(
p
));
const
groups
=
Object
.
keys
(
pathsByGroup
).
map
(
k
=>
pathsByGroup
[
k
]);
...
...
extensions/git/src/repository.ts
浏览文件 @
f4025754
...
...
@@ -13,7 +13,7 @@ import * as path from 'path';
import
*
as
nls
from
'
vscode-nls
'
;
import
*
as
fs
from
'
fs
'
;
import
{
StatusBarCommands
}
from
'
./statusbar
'
;
import
{
Branch
,
Ref
,
Remote
,
RefType
,
GitErrorCodes
,
Status
,
LogOptions
,
Change
,
Tag
}
from
'
./api/git
'
;
import
{
Branch
,
Ref
,
Remote
,
RefType
,
GitErrorCodes
,
Status
,
LogOptions
,
Change
}
from
'
./api/git
'
;
import
{
IFileWatcher
,
watch
}
from
'
./watch
'
;
const
timeout
=
(
millis
:
number
)
=>
new
Promise
(
c
=>
setTimeout
(
c
,
millis
));
...
...
@@ -293,7 +293,6 @@ export const enum Operation {
Ignore
=
'
Ignore
'
,
Tag
=
'
Tag
'
,
DeleteTag
=
'
DeleteTag
'
,
GetTags
=
'
GetTags
'
,
Stash
=
'
Stash
'
,
CheckIgnore
=
'
CheckIgnore
'
,
GetObjectDetails
=
'
GetObjectDetails
'
,
...
...
@@ -1027,10 +1026,6 @@ export class Repository implements Disposable {
await
this
.
run
(
Operation
.
DeleteTag
,
()
=>
this
.
repository
.
deleteTag
(
name
));
}
async
getTags
():
Promise
<
Tag
[]
>
{
return
await
this
.
run
(
Operation
.
GetTags
,
()
=>
this
.
repository
.
getTags
());
}
async
checkout
(
treeish
:
string
):
Promise
<
void
>
{
await
this
.
run
(
Operation
.
Checkout
,
()
=>
this
.
repository
.
checkout
(
treeish
,
[]));
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录