Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
0239bdca
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 搜索 >>
提交
0239bdca
编写于
10月 11, 2020
作者:
M
meganrogge
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
header nesting works
上级
bfa72e0a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
36 addition
and
40 deletion
+36
-40
extensions/markdown-language-features/src/features/smartSelect.ts
...ns/markdown-language-features/src/features/smartSelect.ts
+36
-40
未找到文件。
extensions/markdown-language-features/src/features/smartSelect.ts
浏览文件 @
0239bdca
...
...
@@ -18,7 +18,7 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
await
this
.
getHeaderSelectionRanges
(
document
,
positions
),
await
this
.
getBlockSelectionRanges
(
document
,
positions
)
]);
let
result
=
flatten
(
ranges
)
.
filter
(
element
=>
element
)
;
let
result
=
flatten
(
ranges
);
// header will always be parent of block elements
// have to set the child's grandparent
if
(
result
.
length
===
2
)
{
...
...
@@ -26,12 +26,9 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
child
=
result
[
1
];
let
childParent
=
child
.
parent
;
if
(
childParent
)
{
if
(
childParent
.
range
.
contains
(
child
.
range
))
{
let
comboRange
=
parent
.
range
.
union
(
childParent
.
range
);
childParent
.
parent
=
new
vscode
.
SelectionRange
(
comboRange
);
let
res
=
new
vscode
.
SelectionRange
(
child
.
range
,
childParent
);
return
[
res
];
}
let
revisedParent
=
new
vscode
.
SelectionRange
(
parent
.
range
,
parent
);
let
res
=
new
vscode
.
SelectionRange
(
child
.
range
,
revisedParent
);
return
[
res
];
}
return
[
child
];
}
else
{
...
...
@@ -47,7 +44,7 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
nearbyTokens
=
tokens
.
filter
(
token
=>
token
.
map
&&
(
token
.
map
[
0
]
<=
position
.
line
&&
token
.
map
[
1
]
>=
position
.
line
));
// sort from smallest to largest range
// sort from smallest to largest
line
range
let
sortedTokens
=
nearbyTokens
.
sort
((
tokenOne
,
tokenTwo
)
=>
(
tokenTwo
.
map
[
1
]
-
tokenTwo
.
map
[
0
]
-
tokenOne
.
map
[
1
]
-
tokenOne
.
map
[
0
]));
let
parentToken
=
sortedTokens
.
pop
();
...
...
@@ -72,38 +69,37 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
position
=
positions
[
0
];
const
tocProvider
=
new
TableOfContentsProvider
(
this
.
engine
,
document
);
const
toc
=
await
tocProvider
.
getToc
();
// add header line if on header then select all contents under the header
// get all enclosing headers
let
nearbyHeaders
=
toc
.
filter
(
header
=>
header
.
line
<=
position
.
line
);
let
sortedHeaders
=
nearbyHeaders
.
sort
((
header2
,
header1
)
=>
(
header1
.
line
-
position
.
line
)
-
(
header2
.
line
-
position
.
line
));
let
parentHeader
=
sortedHeaders
.
pop
();
if
(
parentHeader
)
{
let
endLine
=
parentHeader
.
location
.
range
.
end
.
line
;
let
startPos
=
parentHeader
.
location
.
range
.
start
;
let
endPos
=
new
vscode
.
Position
(
endLine
,
parentHeader
.
location
.
range
.
end
.
character
);
let
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
));
let
ranges
=
sortedHeaders
.
map
(
entry
=>
{
let
endLine
=
entry
.
location
.
range
.
end
.
line
;
let
startPos
=
entry
.
location
.
range
.
start
;
let
endPos
=
new
vscode
.
Position
(
endLine
,
entry
.
location
.
range
.
end
.
character
);
if
(
parentRange
.
range
.
contains
(
new
vscode
.
Range
(
startPos
,
endPos
)))
{
return
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
),
parentRange
);
}
else
{
return
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
));
}
});
let
result
=
ranges
[
0
];
// sort ranges by their proximity to result
// for (let i = 1; i < 3; i++) {
// let sisterRange = result.range.union(ranges[i].range);
// if (result.parent?.range.contains(sisterRange)) {
// result.parent = new vscode.SelectionRange(sisterRange, result.parent);
// }
// }
return
[
result
];
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
));
let
parentHeader
=
sortedHeaders
.
shift
();
let
currentRange
:
vscode
.
SelectionRange
;
let
parentRange
:
vscode
.
SelectionRange
;
if
(
parentHeader
)
{
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
parentHeader
.
location
.
range
.
start
,
parentHeader
.
location
.
range
.
end
));
}
return
[];
sortedHeaders
.
forEach
(
header
=>
{
if
(
parentHeader
)
{
let
startPos
=
header
.
location
.
range
.
start
;
let
endPos
=
header
.
location
.
range
.
end
;
if
(
parentRange
.
range
.
contains
(
new
vscode
.
Range
(
startPos
,
endPos
)))
{
currentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
),
parentRange
);
}
else
{
currentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
startPos
,
endPos
));
}
}
parentHeader
=
header
;
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
parentHeader
.
location
.
range
.
start
,
parentHeader
.
location
.
range
.
end
),
parentRange
);
}
);
if
(
currentRange
)
{
return
[
currentRange
];
}
else
{
return
[];
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录