Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
8af49e11
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,发现更多精彩内容 >>
提交
8af49e11
编写于
2月 09, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixes #7717
上级
cd9ecead
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
108 addition
and
26 deletion
+108
-26
src/vs/workbench/parts/scm/electron-browser/dirtydiffDecorator.ts
...orkbench/parts/scm/electron-browser/dirtydiffDecorator.ts
+108
-26
未找到文件。
src/vs/workbench/parts/scm/electron-browser/dirtydiffDecorator.ts
浏览文件 @
8af49e11
...
...
@@ -433,6 +433,76 @@ export class ShowNextChangeAction extends EditorAction {
}
registerEditorAction
(
ShowNextChangeAction
);
export
class
MoveToPreviousChangeAction
extends
EditorAction
{
constructor
()
{
super
({
id
:
'
workbench.action.editor.previousChange
'
,
label
:
nls
.
localize
(
'
move to previous change
'
,
"
Move to Previous Change
"
),
alias
:
'
Move to Previous Change
'
,
precondition
:
null
,
kbOpts
:
{
kbExpr
:
EditorContextKeys
.
textFocus
,
primary
:
KeyMod
.
Shift
|
KeyMod
.
Alt
|
KeyCode
.
F5
}
});
}
run
(
accessor
:
ServicesAccessor
,
editor
:
ICodeEditor
):
void
{
const
outerEditor
=
getOuterEditorFromDiffEditor
(
accessor
);
if
(
!
outerEditor
)
{
return
;
}
const
controller
=
DirtyDiffController
.
get
(
outerEditor
);
if
(
!
controller
||
!
controller
.
modelRegistry
)
{
return
;
}
const
lineNumber
=
outerEditor
.
getPosition
().
lineNumber
;
const
model
=
controller
.
modelRegistry
.
getModel
(
outerEditor
.
getModel
());
const
index
=
model
.
findPreviousClosestChange
(
lineNumber
,
false
);
const
change
=
model
.
changes
[
index
];
outerEditor
.
setPosition
(
new
Position
(
change
.
modifiedStartLineNumber
,
1
));
}
}
registerEditorAction
(
MoveToPreviousChangeAction
);
export
class
MoveToNextChangeAction
extends
EditorAction
{
constructor
()
{
super
({
id
:
'
workbench.action.editor.nextChange
'
,
label
:
nls
.
localize
(
'
move to next change
'
,
"
Move to Next Change
"
),
alias
:
'
Move to Next Change
'
,
precondition
:
null
,
kbOpts
:
{
kbExpr
:
EditorContextKeys
.
textFocus
,
primary
:
KeyMod
.
Alt
|
KeyCode
.
F5
}
});
}
run
(
accessor
:
ServicesAccessor
,
editor
:
ICodeEditor
):
void
{
const
outerEditor
=
getOuterEditorFromDiffEditor
(
accessor
);
if
(
!
outerEditor
)
{
return
;
}
const
controller
=
DirtyDiffController
.
get
(
outerEditor
);
if
(
!
controller
||
!
controller
.
modelRegistry
)
{
return
;
}
const
lineNumber
=
outerEditor
.
getPosition
().
lineNumber
;
const
model
=
controller
.
modelRegistry
.
getModel
(
outerEditor
.
getModel
());
const
index
=
model
.
findNextClosestChange
(
lineNumber
,
false
);
const
change
=
model
.
changes
[
index
];
outerEditor
.
setPosition
(
new
Position
(
change
.
modifiedStartLineNumber
,
1
));
}
}
registerEditorAction
(
MoveToNextChangeAction
);
KeybindingsRegistry
.
registerCommandAndKeybindingRule
({
id
:
'
closeDirtyDiff
'
,
weight
:
KeybindingsRegistry
.
WEIGHT
.
editorContrib
(
50
),
...
...
@@ -504,7 +574,7 @@ export class DirtyDiffController implements IEditorContribution {
}
if
(
typeof
lineNumber
===
'
number
'
||
this
.
currentIndex
===
-
1
)
{
this
.
currentIndex
=
this
.
findNextClosestChange
(
typeof
lineNumber
===
'
number
'
?
lineNumber
:
this
.
editor
.
getPosition
().
lineNumber
);
this
.
currentIndex
=
this
.
model
.
findNextClosestChange
(
typeof
lineNumber
===
'
number
'
?
lineNumber
:
this
.
editor
.
getPosition
().
lineNumber
);
}
else
{
this
.
currentIndex
=
rot
(
this
.
currentIndex
+
1
,
this
.
model
.
changes
.
length
);
}
...
...
@@ -518,7 +588,7 @@ export class DirtyDiffController implements IEditorContribution {
}
if
(
typeof
lineNumber
===
'
number
'
||
this
.
currentIndex
===
-
1
)
{
this
.
currentIndex
=
this
.
findPreviousClosestChange
(
typeof
lineNumber
===
'
number
'
?
lineNumber
:
this
.
editor
.
getPosition
().
lineNumber
);
this
.
currentIndex
=
this
.
model
.
findPreviousClosestChange
(
typeof
lineNumber
===
'
number
'
?
lineNumber
:
this
.
editor
.
getPosition
().
lineNumber
);
}
else
{
this
.
currentIndex
=
rot
(
this
.
currentIndex
-
1
,
this
.
model
.
changes
.
length
);
}
...
...
@@ -678,30 +748,6 @@ export class DirtyDiffController implements IEditorContribution {
}
}
private
findNextClosestChange
(
lineNumber
:
number
):
number
{
for
(
let
i
=
0
;
i
<
this
.
model
.
changes
.
length
;
i
++
)
{
const
change
=
this
.
model
.
changes
[
i
];
if
(
lineIntersectsChange
(
lineNumber
,
change
))
{
return
i
;
}
}
return
0
;
}
private
findPreviousClosestChange
(
lineNumber
:
number
):
number
{
for
(
let
i
=
this
.
model
.
changes
.
length
-
1
;
i
>=
0
;
i
--
)
{
const
change
=
this
.
model
.
changes
[
i
];
if
(
change
.
modifiedStartLineNumber
<=
lineNumber
)
{
return
i
;
}
}
return
0
;
}
dispose
():
void
{
return
;
}
...
...
@@ -981,6 +1027,42 @@ export class DirtyDiffModel {
return
null
;
}
findNextClosestChange
(
lineNumber
:
number
,
inclusive
=
true
):
number
{
for
(
let
i
=
0
;
i
<
this
.
changes
.
length
;
i
++
)
{
const
change
=
this
.
changes
[
i
];
if
(
inclusive
)
{
if
(
getModifiedEndLineNumber
(
change
)
>=
lineNumber
)
{
return
i
;
}
}
else
{
if
(
change
.
modifiedStartLineNumber
>
lineNumber
)
{
return
i
;
}
}
}
return
0
;
}
findPreviousClosestChange
(
lineNumber
:
number
,
inclusive
=
true
):
number
{
for
(
let
i
=
this
.
changes
.
length
-
1
;
i
>=
0
;
i
--
)
{
const
change
=
this
.
changes
[
i
];
if
(
inclusive
)
{
if
(
change
.
modifiedStartLineNumber
<=
lineNumber
)
{
return
i
;
}
}
else
{
if
(
getModifiedEndLineNumber
(
change
)
<
lineNumber
)
{
return
i
;
}
}
}
return
this
.
changes
.
length
-
1
;
}
dispose
():
void
{
this
.
disposables
=
dispose
(
this
.
disposables
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录