Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
e1f98574
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,发现更多精彩内容 >>
提交
e1f98574
编写于
5月 16, 2016
作者:
I
isidor
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
debug: smarter lazy transition to running state
fixes #5966 fixes #5812
上级
df0e5235
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
27 addition
and
26 deletion
+27
-26
src/vs/workbench/parts/debug/electron-browser/debugService.ts
...vs/workbench/parts/debug/electron-browser/debugService.ts
+27
-26
未找到文件。
src/vs/workbench/parts/debug/electron-browser/debugService.ts
浏览文件 @
e1f98574
...
...
@@ -9,6 +9,7 @@ import lifecycle = require('vs/base/common/lifecycle');
import
mime
=
require
(
'
vs/base/common/mime
'
);
import
Event
,
{
Emitter
}
from
'
vs/base/common/event
'
;
import
uri
from
'
vs/base/common/uri
'
;
import
{
RunOnceScheduler
}
from
'
vs/base/common/async
'
;
import
{
Action
}
from
'
vs/base/common/actions
'
;
import
arrays
=
require
(
'
vs/base/common/arrays
'
);
import
types
=
require
(
'
vs/base/common/types
'
);
...
...
@@ -857,41 +858,41 @@ export class DebugService implements debug.IDebugService {
return
this
.
session
.
pause
({
threadId
});
}
private
lazyTransitionToRunningState
(
threadId
?:
number
):
void
{
let
cancelTransitionToRunningState
=
false
;
let
setNewFocusedStackFrameScheduler
:
RunOnceScheduler
;
const
toDispose
=
this
.
session
.
onDidStop
(
e
=>
{
if
(
e
.
body
.
threadId
===
threadId
||
e
.
body
.
allThreadsStopped
||
!
threadId
)
{
cancelTransitionToRunningState
=
true
;
setNewFocusedStackFrameScheduler
.
cancel
()
;
}
});
// Do not immediatly transition to running state since that might cause unnecessery flickering
// of the tree in the debug viewlet. Only transition if no stopped event has arrived in 500ms.
setTimeout
(()
=>
{
toDispose
.
dispose
();
if
(
!
cancelTransitionToRunningState
)
{
aria
.
status
(
nls
.
localize
(
'
debuggingContinued
'
,
"
Debugging continued.
"
));
// TODO@Isidor temporary workaround for #1703
if
(
this
.
session
&&
strings
.
equalsIgnoreCase
(
this
.
session
.
configuration
.
type
,
'
php
'
))
{
this
.
model
.
clearThreads
(
false
,
threadId
);
}
else
{
this
.
model
.
clearThreads
(
false
);
}
// TODO@Isidor temporary workaround for #1703
if
(
this
.
session
&&
strings
.
equalsIgnoreCase
(
this
.
session
.
configuration
.
type
,
'
php
'
))
{
this
.
model
.
clearThreads
(
false
,
threadId
);
}
else
{
this
.
model
.
clearThreads
(
false
);
}
// Get a top stack frame of a stopped thread if there is any.
const
threads
=
this
.
model
.
getThreads
();
const
stoppedReference
=
Object
.
keys
(
threads
).
filter
(
ref
=>
threads
[
ref
].
stopped
).
pop
();
const
stoppedThread
=
stoppedReference
?
threads
[
parseInt
(
stoppedReference
)]
:
null
;
const
callStack
=
stoppedThread
?
stoppedThread
.
getCachedCallStack
()
:
null
;
const
stackFrameToFocus
=
callStack
&&
callStack
.
length
>
0
?
callStack
[
0
]
:
null
;
// Get a top stack frame of a stopped thread if there is any.
const
threads
=
this
.
model
.
getThreads
();
const
stoppedReference
=
Object
.
keys
(
threads
).
filter
(
ref
=>
threads
[
ref
].
stopped
).
pop
();
const
stoppedThread
=
stoppedReference
?
threads
[
parseInt
(
stoppedReference
)]
:
null
;
const
callStack
=
stoppedThread
?
stoppedThread
.
getCachedCallStack
()
:
null
;
const
stackFrameToFocus
=
callStack
&&
callStack
.
length
>
0
?
callStack
[
0
]
:
null
;
this
.
setFocusedStackFrameAndEvaluate
(
stackFrameToFocus
).
done
(
null
,
errors
.
onUnexpectedError
);
if
(
!
stoppedThread
)
{
this
.
setStateAndEmit
(
this
.
configurationManager
.
configuration
.
noDebug
?
debug
.
State
.
RunningNoDebug
:
debug
.
State
.
Running
);
}
}
if
(
!
stoppedThread
)
{
this
.
setStateAndEmit
(
this
.
configurationManager
.
configuration
.
noDebug
?
debug
.
State
.
RunningNoDebug
:
debug
.
State
.
Running
);
}
// Do not immediatly set a new focused stack frame since that might cause unnecessery flickering
// of the tree in the debug viewlet. Only set focused stack frame if no stopped event has arrived in 500ms.
setNewFocusedStackFrameScheduler
=
new
RunOnceScheduler
(()
=>
{
toDispose
.
dispose
();
aria
.
status
(
nls
.
localize
(
'
debuggingContinued
'
,
"
Debugging continued.
"
));
this
.
setFocusedStackFrameAndEvaluate
(
stackFrameToFocus
).
done
(
null
,
errors
.
onUnexpectedError
);
},
500
);
setNewFocusedStackFrameScheduler
.
schedule
();
}
private
getDebugStringEditorInput
(
source
:
Source
,
value
:
string
,
mtype
:
string
):
DebugStringEditorInput
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录