Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
a736955e
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,发现更多精彩内容 >>
提交
a736955e
编写于
8月 08, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
scm: SourceControl.selected and event
上级
f0d05f55
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
83 addition
and
1 deletion
+83
-1
src/vs/vscode.proposed.d.ts
src/vs/vscode.proposed.d.ts
+17
-0
src/vs/workbench/api/electron-browser/mainThreadSCM.ts
src/vs/workbench/api/electron-browser/mainThreadSCM.ts
+12
-1
src/vs/workbench/api/node/extHost.protocol.ts
src/vs/workbench/api/node/extHost.protocol.ts
+1
-0
src/vs/workbench/api/node/extHostSCM.ts
src/vs/workbench/api/node/extHostSCM.ts
+53
-0
未找到文件。
src/vs/vscode.proposed.d.ts
浏览文件 @
a736955e
...
...
@@ -523,6 +523,23 @@ declare module 'vscode' {
//#endregion
//#region Joao: SCM selected provider
export
interface
SourceControl
{
/**
* Whether the source control is selected.
*/
readonly
selected
:
boolean
;
/**
* An event signaling when the selection state changes.
*/
readonly
onDidChangeSelection
:
Event
<
boolean
>
;
}
//#endregion
//#region Comments
/**
* Comments provider related APIs are still in early stages, they may be changed significantly during our API experiments.
...
...
src/vs/workbench/api/electron-browser/mainThreadSCM.ts
浏览文件 @
a736955e
...
...
@@ -7,7 +7,7 @@
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
URI
,
{
UriComponents
}
from
'
vs/base/common/uri
'
;
import
{
Event
,
Emitter
}
from
'
vs/base/common/event
'
;
import
{
Event
,
Emitter
,
debounceEvent
}
from
'
vs/base/common/event
'
;
import
{
assign
}
from
'
vs/base/common/objects
'
;
import
{
IDisposable
,
dispose
}
from
'
vs/base/common/lifecycle
'
;
import
{
ISCMService
,
ISCMRepository
,
ISCMProvider
,
ISCMResource
,
ISCMResourceGroup
,
ISCMResourceDecorations
,
IInputValidation
}
from
'
vs/workbench/services/scm/common/scm
'
;
...
...
@@ -270,6 +270,9 @@ export class MainThreadSCM implements MainThreadSCMShape {
@
ISCMService
private
scmService
:
ISCMService
)
{
this
.
_proxy
=
extHostContext
.
getProxy
(
ExtHostContext
.
ExtHostSCM
);
debounceEvent
(
scmService
.
onDidChangeSelectedRepositories
,
(
_
,
e
)
=>
e
,
100
)
(
this
.
onDidChangeSelectedRepositories
,
this
,
this
.
_disposables
);
}
dispose
():
void
{
...
...
@@ -417,4 +420,12 @@ export class MainThreadSCM implements MainThreadSCMShape {
repository
.
input
.
validateInput
=
()
=>
TPromise
.
as
(
undefined
);
}
}
private
onDidChangeSelectedRepositories
(
repositories
:
ISCMRepository
[]):
void
{
const
handles
=
repositories
.
filter
(
r
=>
r
.
provider
instanceof
MainThreadSCMProvider
)
.
map
(
r
=>
(
r
.
provider
as
MainThreadSCMProvider
).
handle
);
this
.
_proxy
.
$setSelectedSourceControls
(
handles
);
}
}
src/vs/workbench/api/node/extHost.protocol.ts
浏览文件 @
a736955e
...
...
@@ -882,6 +882,7 @@ export interface ExtHostSCMShape {
$onInputBoxValueChange
(
sourceControlHandle
:
number
,
value
:
string
):
TPromise
<
void
>
;
$executeResourceCommand
(
sourceControlHandle
:
number
,
groupHandle
:
number
,
handle
:
number
):
TPromise
<
void
>
;
$validateInput
(
sourceControlHandle
:
number
,
value
:
string
,
cursorPosition
:
number
):
TPromise
<
[
string
,
number
]
|
undefined
>
;
$setSelectedSourceControls
(
selectedSourceControlHandles
:
number
[]):
TPromise
<
void
>
;
}
export
interface
ExtHostTaskShape
{
...
...
src/vs/workbench/api/node/extHostSCM.ts
浏览文件 @
a736955e
...
...
@@ -395,6 +395,15 @@ class ExtHostSourceControl implements vscode.SourceControl {
this
.
_proxy
.
$updateSourceControl
(
this
.
handle
,
{
statusBarCommands
:
internal
});
}
private
_selected
:
boolean
=
false
;
get
selected
():
boolean
{
return
this
.
_selected
;
}
private
_onDidChangeSelection
=
new
Emitter
<
boolean
>
();
readonly
onDidChangeSelection
=
this
.
_onDidChangeSelection
.
event
;
private
handle
:
number
=
ExtHostSourceControl
.
_handlePool
++
;
constructor
(
...
...
@@ -454,6 +463,11 @@ class ExtHostSourceControl implements vscode.SourceControl {
return
this
.
_groups
.
get
(
handle
);
}
setSelectionState
(
selected
:
boolean
):
void
{
this
.
_selected
=
selected
;
this
.
_onDidChangeSelection
.
fire
(
selected
);
}
dispose
():
void
{
this
.
_groups
.
forEach
(
group
=>
group
.
dispose
());
this
.
_proxy
.
$unregisterSourceControl
(
this
.
handle
);
...
...
@@ -471,6 +485,8 @@ export class ExtHostSCM implements ExtHostSCMShape {
private
_onDidChangeActiveProvider
=
new
Emitter
<
vscode
.
SourceControl
>
();
get
onDidChangeActiveProvider
():
Event
<
vscode
.
SourceControl
>
{
return
this
.
_onDidChangeActiveProvider
.
event
;
}
private
_selectedSourceControlHandles
=
new
Set
<
number
>
();
constructor
(
mainContext
:
IMainContext
,
private
_commands
:
ExtHostCommands
,
...
...
@@ -607,4 +623,41 @@ export class ExtHostSCM implements ExtHostSCMShape {
return
TPromise
.
as
<
[
string
,
number
]
>
([
result
.
message
,
result
.
type
]);
});
}
$setSelectedSourceControls
(
selectedSourceControlHandles
:
number
[]):
TPromise
<
void
>
{
this
.
logService
.
trace
(
'
ExtHostSCM#$setSelectedSourceControls
'
,
selectedSourceControlHandles
);
const
set
=
new
Set
<
number
>
();
for
(
const
handle
of
selectedSourceControlHandles
)
{
set
.
add
(
handle
);
}
set
.
forEach
(
handle
=>
{
if
(
!
this
.
_selectedSourceControlHandles
.
has
(
handle
))
{
const
sourceControl
=
this
.
_sourceControls
.
get
(
handle
);
if
(
!
sourceControl
)
{
return
;
}
sourceControl
.
setSelectionState
(
true
);
}
});
this
.
_selectedSourceControlHandles
.
forEach
(
handle
=>
{
if
(
!
set
.
has
(
handle
))
{
const
sourceControl
=
this
.
_sourceControls
.
get
(
handle
);
if
(
!
sourceControl
)
{
return
;
}
sourceControl
.
setSelectionState
(
false
);
}
});
this
.
_selectedSourceControlHandles
=
set
;
return
TPromise
.
as
(
null
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录