Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
37c73f0c
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,发现更多精彩内容 >>
提交
37c73f0c
编写于
7月 24, 2017
作者:
D
Daniel Imms
提交者:
GitHub
7月 24, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #31263 from cleidigh/terminal-clicklink/bug
Handle Alt+Click for terminal links. Fixes #30761
上级
2bac5fd0
b2101ca1
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
3 deletion
+12
-3
src/vs/workbench/parts/terminal/electron-browser/terminalLinkHandler.ts
...ch/parts/terminal/electron-browser/terminalLinkHandler.ts
+12
-3
未找到文件。
src/vs/workbench/parts/terminal/electron-browser/terminalLinkHandler.ts
浏览文件 @
37c73f0c
...
...
@@ -72,7 +72,11 @@ export class TerminalLinkHandler {
const
baseLocalLinkClause
=
_platform
===
platform
.
Platform
.
Windows
?
winLocalLinkClause
:
unixLocalLinkClause
;
// Append line and column number regex
this
.
_localLinkPattern
=
new
RegExp
(
`
${
baseLocalLinkClause
}
(
${
lineAndColumnClause
}
)`
);
this
.
_xterm
.
setHypertextLinkHandler
(
this
.
_wrapLinkHandler
(()
=>
true
));
this
.
_xterm
.
setHypertextLinkHandler
(
this
.
_wrapLinkHandler
(
uri
=>
{
this
.
_handleHypertextLink
(
uri
);
}));
this
.
_xterm
.
setHypertextValidationCallback
((
uri
:
string
,
element
:
HTMLElement
,
callback
:
(
isValid
:
boolean
)
=>
void
)
=>
{
this
.
_validateWebLink
(
uri
,
element
,
callback
);
});
...
...
@@ -101,7 +105,6 @@ export class TerminalLinkHandler {
public
registerLocalLinkHandler
():
number
{
const
wrappedHandler
=
this
.
_wrapLinkHandler
(
url
=>
{
this
.
_handleLocalLink
(
url
);
return
;
});
return
this
.
_xterm
.
registerLinkMatcher
(
this
.
_localLinkRegex
,
wrappedHandler
,
{
...
...
@@ -117,9 +120,10 @@ export class TerminalLinkHandler {
private
_wrapLinkHandler
(
handler
:
(
uri
:
string
)
=>
boolean
|
void
):
XtermLinkMatcherHandler
{
return
(
event
:
MouseEvent
,
uri
:
string
)
=>
{
// Prevent default electron link handling so Alt+Click mode works normally
event
.
preventDefault
();
// Require correct modifier on click
if
(
!
this
.
_isLinkActivationModifierDown
(
event
))
{
event
.
preventDefault
();
return
false
;
}
return
handler
(
uri
);
...
...
@@ -164,6 +168,11 @@ export class TerminalLinkHandler {
callback
(
true
);
}
private
_handleHypertextLink
(
url
:
string
):
void
{
let
uri
=
Uri
.
parse
(
url
);
this
.
_openerService
.
open
(
uri
);
}
private
_isLinkActivationModifierDown
(
event
:
MouseEvent
):
boolean
{
const
editorConf
=
this
.
_configurationService
.
getConfiguration
<
{
multiCursorModifier
:
'
ctrlCmd
'
|
'
alt
'
}
>
(
'
editor
'
);
if
(
editorConf
.
multiCursorModifier
===
'
ctrlCmd
'
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录