Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
6027600f
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,发现更多精彩内容 >>
提交
6027600f
编写于
9月 27, 2017
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Console.logs from command handler not linked to origin (fixes #35140)
上级
c3beb361
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
55 addition
and
2 deletion
+55
-2
src/vs/base/node/console.ts
src/vs/base/node/console.ts
+12
-2
src/vs/base/test/node/console.test.ts
src/vs/base/test/node/console.test.ts
+43
-0
未找到文件。
src/vs/base/node/console.ts
浏览文件 @
6027600f
...
...
@@ -59,11 +59,21 @@ export function getFirstFrame(arg0: IRemoteConsoleLog | string): IStackFrame {
return
getFirstFrame
(
parse
(
arg0
).
stack
);
}
// Parse a source information out of the stack if we have one. Format:
// Parse a source information out of the stack if we have one. Format
can be
:
// at vscode.commands.registerCommand (/Users/someone/Desktop/test-ts/out/src/extension.js:18:17)
// or
// at /Users/someone/Desktop/test-ts/out/src/extension.js:18:17
// or
// at c:\Users\someone\Desktop\end-js\extension.js:19:17
// or
// at e.$executeContributedCommand(c:\Users\someone\Desktop\end-js\extension.js:19:17)
const
stack
=
arg0
;
if
(
stack
)
{
const
matches
=
/.+
\((
.+
)
:
(\d
+
)
:
(\d
+
)\)
/
.
exec
(
stack
);
// at [^\/]* => line starts with "at" followed by any character except '/' (to not capture unix paths too late)
// (?:(?:[a-zA-Z]+:)|(?:[\/])|(?:\\\\) => windows drive letter OR unix root OR unc root
// (?:.+) => simple pattern for the path, only works because of the line/col pattern after
// :(?:\d+):(?:\d+) => :line:column data
const
matches
=
/at
[^\/]
*
((?:(?:[
a-zA-Z
]
+:
)
|
(?:[\/])
|
(?:\\\\))(?:
.+
))
:
(\d
+
)
:
(\d
+
)
/
.
exec
(
stack
);
if
(
matches
.
length
===
4
)
{
return
{
uri
:
URI
.
file
(
matches
[
1
]),
...
...
src/vs/base/test/node/console.test.ts
0 → 100644
浏览文件 @
6027600f
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
*
as
assert
from
'
assert
'
;
import
{
getFirstFrame
}
from
'
vs/base/node/console
'
;
import
{
normalize
}
from
'
path
'
;
suite
(
'
Console
'
,
()
=>
{
test
(
'
getFirstFrame
'
,
function
()
{
let
stack
=
'
at vscode.commands.registerCommand (/Users/someone/Desktop/test-ts/out/src/extension.js:18:17)
'
;
let
frame
=
getFirstFrame
(
stack
);
assert
.
equal
(
frame
.
uri
.
fsPath
,
normalize
(
'
/Users/someone/Desktop/test-ts/out/src/extension.js
'
));
assert
.
equal
(
frame
.
line
,
18
);
assert
.
equal
(
frame
.
column
,
17
);
stack
=
'
at /Users/someone/Desktop/test-ts/out/src/extension.js:18:17
'
;
frame
=
getFirstFrame
(
stack
);
assert
.
equal
(
frame
.
uri
.
fsPath
,
normalize
(
'
/Users/someone/Desktop/test-ts/out/src/extension.js
'
));
assert
.
equal
(
frame
.
line
,
18
);
assert
.
equal
(
frame
.
column
,
17
);
stack
=
'
at c:
\\
Users
\\
someone
\\
Desktop
\\
end-js
\\
extension.js:18:17
'
;
frame
=
getFirstFrame
(
stack
);
assert
.
equal
(
frame
.
uri
.
fsPath
,
'
c:
\\
Users
\\
someone
\\
Desktop
\\
end-js
\\
extension.js
'
);
assert
.
equal
(
frame
.
line
,
18
);
assert
.
equal
(
frame
.
column
,
17
);
stack
=
'
at e.$executeContributedCommand(c:
\\
Users
\\
someone
\\
Desktop
\\
end-js
\\
extension.js:18:17)
'
;
frame
=
getFirstFrame
(
stack
);
assert
.
equal
(
frame
.
uri
.
fsPath
,
'
c:
\\
Users
\\
someone
\\
Desktop
\\
end-js
\\
extension.js
'
);
assert
.
equal
(
frame
.
line
,
18
);
assert
.
equal
(
frame
.
column
,
17
);
});
});
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录