Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
dd20771c
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,体验更适合开发者的 AI 搜索 >>
提交
dd20771c
编写于
10月 15, 2020
作者:
M
meganrogge
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
added support for multiple positions
上级
c194f82e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
28 deletion
+25
-28
extensions/markdown-language-features/src/features/smartSelect.ts
...ns/markdown-language-features/src/features/smartSelect.ts
+25
-28
未找到文件。
extensions/markdown-language-features/src/features/smartSelect.ts
浏览文件 @
dd20771c
...
...
@@ -6,7 +6,6 @@
import
*
as
vscode
from
'
vscode
'
;
import
{
MarkdownEngine
}
from
'
../markdownEngine
'
;
import
{
TableOfContentsProvider
}
from
'
../tableOfContentsProvider
'
;
import
{
flatten
}
from
'
../util/arrays
'
;
export
default
class
MarkdownSmartSelect
implements
vscode
.
SelectionRangeProvider
{
...
...
@@ -15,14 +14,19 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
)
{
}
public
async
provideSelectionRanges
(
document
:
vscode
.
TextDocument
,
positions
:
vscode
.
Position
[],
_token
:
vscode
.
CancellationToken
):
Promise
<
vscode
.
SelectionRange
[]
>
{
let
ranges
=
await
Promise
.
all
([
await
this
.
getHeaderSelectionRanges
(
document
,
positions
),
await
this
.
getBlockSelectionRanges
(
document
,
positions
)
let
rangesForPositions
:
vscode
.
SelectionRange
[]
=
[];
positions
.
forEach
(
async
(
position
)
=>
{
let
ranges
:
vscode
.
SelectionRange
[]
=
await
Promise
.
all
([
await
this
.
getHeaderSelectionRanges
(
document
,
position
),
await
this
.
getBlockSelectionRanges
(
document
,
position
)
]);
let
result
=
flatten
(
ranges
);
let
result
:
vscode
.
SelectionRange
[]
=
ranges
.
filter
(
range
=>
range
);
if
(
result
.
length
===
2
)
{
// need to combine them to return only smallest child range
let
parent
=
result
[
0
];
let
child
=
result
[
1
];
let
childParent
=
child
.
parent
;
...
...
@@ -31,7 +35,7 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
if
(
parent
.
range
.
contains
(
childParent
.
range
))
{
let
revisedParent
=
new
vscode
.
SelectionRange
(
childParent
.
range
,
parent
);
if
(
revisedParent
.
range
.
contains
(
child
.
range
))
{
r
eturn
[
new
vscode
.
SelectionRange
(
child
.
range
,
revisedParent
)]
;
r
angesForPositions
.
push
(
new
vscode
.
SelectionRange
(
child
.
range
,
revisedParent
))
;
}
}
else
{
// they're one line off
...
...
@@ -41,23 +45,26 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
}
if
(
parent
.
range
.
contains
(
childParent
.
range
))
{
childParent
.
parent
=
parent
;
r
eturn
[
new
vscode
.
SelectionRange
(
child
.
range
,
childParent
)]
;
r
angesForPositions
.
push
(
new
vscode
.
SelectionRange
(
child
.
range
,
childParent
))
;
}
}
}
else
{
if
(
parent
.
range
.
contains
(
child
.
range
))
{
r
eturn
[
new
vscode
.
SelectionRange
(
child
.
range
,
parent
)]
;
r
angesForPositions
.
push
(
new
vscode
.
SelectionRange
(
child
.
range
,
parent
))
;
}
}
r
eturn
[
child
]
;
r
angesForPositions
.
push
(
child
)
;
}
else
{
r
eturn
result
;
r
angesForPositions
.
push
(
result
[
0
])
;
}
});
if
(
rangesForPositions
)
{
// stop here
}
return
rangesForPositions
;
}
private
async
getBlockSelectionRanges
(
document
:
vscode
.
TextDocument
,
positions
:
vscode
.
Position
[]):
Promise
<
vscode
.
SelectionRange
[]
>
{
let
position
=
positions
[
0
];
private
async
getBlockSelectionRanges
(
document
:
vscode
.
TextDocument
,
position
:
vscode
.
Position
):
Promise
<
vscode
.
SelectionRange
>
{
const
tokens
=
await
this
.
engine
.
parse
(
document
);
...
...
@@ -68,17 +75,13 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
parentToken
=
sortedTokens
.
pop
();
if
(
sortedTokens
.
length
===
0
)
{
return
[];
}
if
(
parentToken
)
{
if
(
parentToken
.
type
===
'
fence
'
)
{
let
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
new
vscode
.
Position
(
parentToken
.
map
[
0
]
>
0
?
parentToken
.
map
[
0
]
-
1
:
0
,
0
),
new
vscode
.
Position
(
parentToken
.
map
[
1
],
0
)));
let
childRange
=
new
vscode
.
Range
(
new
vscode
.
Position
(
parentToken
.
map
[
0
]
+
1
,
0
),
new
vscode
.
Position
(
parentToken
.
map
[
1
]
-
1
,
0
));
if
(
parentRange
.
range
.
contains
(
childRange
))
{
let
child
=
new
vscode
.
SelectionRange
(
childRange
,
parentRange
);
return
[
child
]
;
return
child
;
}
}
else
{
let
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
new
vscode
.
Position
(
parentToken
.
map
[
0
],
0
),
new
vscode
.
Position
(
parentToken
.
map
[
1
],
0
)));
...
...
@@ -93,14 +96,12 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
return
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
));
}
});
return
ranges
.
length
>
0
?
[
ranges
[
0
]]
:
[
parentRange
]
;
return
ranges
.
length
>
0
?
ranges
[
0
]
:
parentRange
;
}
}
return
[];
}
private
async
getHeaderSelectionRanges
(
document
:
vscode
.
TextDocument
,
positions
:
vscode
.
Position
[]):
Promise
<
vscode
.
SelectionRange
[]
>
{
let
position
=
positions
[
0
];
private
async
getHeaderSelectionRanges
(
document
:
vscode
.
TextDocument
,
position
:
vscode
.
Position
):
Promise
<
vscode
.
SelectionRange
>
{
const
tocProvider
=
new
TableOfContentsProvider
(
this
.
engine
,
document
);
const
toc
=
await
tocProvider
.
getToc
();
...
...
@@ -109,10 +110,6 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
nearbyHeaders
=
toc
.
filter
(
header
=>
header
.
location
.
range
.
start
.
line
<=
position
.
line
&&
header
.
location
.
range
.
end
.
line
>=
position
.
line
);
let
sortedHeaders
=
nearbyHeaders
.
sort
((
header1
,
header2
)
=>
(
header1
.
line
-
position
.
line
)
-
(
header2
.
line
-
position
.
line
));
if
(
sortedHeaders
.
length
===
0
)
{
return
[];
}
let
parentHeader
=
sortedHeaders
.
shift
();
let
parentRange
:
vscode
.
SelectionRange
;
let
currentRange
:
vscode
.
SelectionRange
;
...
...
@@ -144,9 +141,9 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
}
);
if
(
!
currentRange
&&
parentRange
)
{
return
[
parentRange
]
;
return
parentRange
;
}
return
[
currentRange
]
;
return
currentRange
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录