Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
bfa72e0a
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 搜索 >>
提交
bfa72e0a
编写于
10月 09, 2020
作者:
M
meganrogge
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
working for item and header selection
上级
79879f2c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
13 deletion
+15
-13
extensions/markdown-language-features/src/features/smartSelect.ts
...ns/markdown-language-features/src/features/smartSelect.ts
+15
-13
未找到文件。
extensions/markdown-language-features/src/features/smartSelect.ts
浏览文件 @
bfa72e0a
...
...
@@ -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
);
let
result
=
flatten
(
ranges
)
.
filter
(
element
=>
element
)
;
// header will always be parent of block elements
// have to set the child's grandparent
if
(
result
.
length
===
2
)
{
...
...
@@ -26,9 +26,11 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
child
=
result
[
1
];
let
childParent
=
child
.
parent
;
if
(
childParent
)
{
childParent
.
parent
=
parent
;
if
(
childParent
.
range
.
contains
(
child
.
range
))
{
return
[
new
vscode
.
SelectionRange
(
child
.
range
,
childParent
)];
let
comboRange
=
parent
.
range
.
union
(
childParent
.
range
);
childParent
.
parent
=
new
vscode
.
SelectionRange
(
comboRange
);
let
res
=
new
vscode
.
SelectionRange
(
child
.
range
,
childParent
);
return
[
res
];
}
}
return
[
child
];
...
...
@@ -51,17 +53,17 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
let
parentToken
=
sortedTokens
.
pop
();
if
(
parentToken
)
{
let
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
new
vscode
.
Position
(
parentToken
.
map
[
0
],
0
),
new
vscode
.
Position
(
document
.
lineAt
(
parentToken
.
map
[
1
]).
isEmptyOrWhitespace
?
parentToken
.
map
[
1
]
-
1
:
parentToken
.
map
[
1
],
0
)));
let
parentRange
=
new
vscode
.
SelectionRange
(
new
vscode
.
Range
(
new
vscode
.
Position
(
parentToken
.
map
[
0
],
0
),
new
vscode
.
Position
(
parentToken
.
map
[
1
],
0
)));
let
ranges
=
sortedTokens
.
map
(
token
=>
{
let
startPos
=
new
vscode
.
Position
(
token
.
map
[
0
],
0
);
let
endPos
=
new
vscode
.
Position
(
document
.
lineAt
(
token
.
map
[
1
]).
isEmptyOrWhitespace
?
token
.
map
[
1
]
-
1
:
token
.
map
[
1
],
0
);
let
endPos
=
new
vscode
.
Position
(
token
.
map
[
1
],
0
);
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
));
}
});
return
[
ranges
[
0
]
];
return
ranges
?
[
ranges
[
0
]]
:
[
parentRange
];
}
return
[];
}
...
...
@@ -70,7 +72,7 @@ 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
));
...
...
@@ -94,12 +96,12 @@ export default class MarkdownSmartSelect implements vscode.SelectionRangeProvide
});
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
);
}
}
//
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
];
}
return
[];
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录