Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
8bff3955
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,发现更多精彩内容 >>
提交
8bff3955
编写于
4月 19, 2018
作者:
D
Daniel Imms
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Dispose of proxy listeners properly
上级
b7985f41
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
22 addition
and
14 deletion
+22
-14
src/vs/workbench/api/electron-browser/mainThreadTerminalService.ts
...rkbench/api/electron-browser/mainThreadTerminalService.ts
+3
-4
src/vs/workbench/parts/terminal/common/terminal.ts
src/vs/workbench/parts/terminal/common/terminal.ts
+5
-4
src/vs/workbench/parts/terminal/node/terminalProcessExtHostProxy.ts
...kbench/parts/terminal/node/terminalProcessExtHostProxy.ts
+14
-6
未找到文件。
src/vs/workbench/api/electron-browser/mainThreadTerminalService.ts
浏览文件 @
8bff3955
...
@@ -109,10 +109,9 @@ export class MainThreadTerminalService implements MainThreadTerminalServiceShape
...
@@ -109,10 +109,9 @@ export class MainThreadTerminalService implements MainThreadTerminalServiceShape
env
:
request
.
shellLaunchConfig
.
env
env
:
request
.
shellLaunchConfig
.
env
};
};
this
.
_proxy
.
$createProcess
(
request
.
proxy
.
terminalId
,
shellLaunchConfigDto
,
request
.
cols
,
request
.
rows
);
this
.
_proxy
.
$createProcess
(
request
.
proxy
.
terminalId
,
shellLaunchConfigDto
,
request
.
cols
,
request
.
rows
);
// TODO: Dispose of this properly when the terminal/process dies
request
.
proxy
.
onInput
(
data
=>
this
.
_proxy
.
$acceptProcessInput
(
request
.
proxy
.
terminalId
,
data
));
this
.
_toDispose
.
push
(
request
.
proxy
.
onInput
(
data
=>
this
.
_proxy
.
$acceptProcessInput
(
request
.
proxy
.
terminalId
,
data
)));
request
.
proxy
.
onResize
((
cols
,
rows
)
=>
this
.
_proxy
.
$acceptProcessResize
(
request
.
proxy
.
terminalId
,
cols
,
rows
));
this
.
_toDispose
.
push
(
request
.
proxy
.
onResize
((
cols
,
rows
)
=>
this
.
_proxy
.
$acceptProcessResize
(
request
.
proxy
.
terminalId
,
cols
,
rows
)));
request
.
proxy
.
onShutdown
(()
=>
this
.
_proxy
.
$acceptProcessShutdown
(
request
.
proxy
.
terminalId
));
this
.
_toDispose
.
push
(
request
.
proxy
.
onShutdown
(()
=>
this
.
_proxy
.
$acceptProcessShutdown
(
request
.
proxy
.
terminalId
)));
}
}
public
$sendProcessTitle
(
terminalId
:
number
,
title
:
string
):
void
{
public
$sendProcessTitle
(
terminalId
:
number
,
title
:
string
):
void
{
...
...
src/vs/workbench/parts/terminal/common/terminal.ts
浏览文件 @
8bff3955
...
@@ -518,16 +518,17 @@ export enum ProcessState {
...
@@ -518,16 +518,17 @@ export enum ProcessState {
}
}
export
interface
ITerminalProcessExtHostProxy
{
export
interface
ITerminalProcessExtHostProxy
extends
IDisposable
{
readonly
terminalId
:
number
;
readonly
terminalId
:
number
;
emitData
(
data
:
string
):
void
;
emitData
(
data
:
string
):
void
;
emitTitle
(
title
:
string
):
void
;
emitTitle
(
title
:
string
):
void
;
emitPid
(
pid
:
number
):
void
;
emitPid
(
pid
:
number
):
void
;
emitExit
(
exitCode
:
number
):
void
;
emitExit
(
exitCode
:
number
):
void
;
onInput
(
listener
:
(
data
:
string
)
=>
void
):
IDisposable
;
onResize
(
listener
:
(
cols
:
number
,
rows
:
number
)
=>
void
):
IDisposable
;
onInput
(
listener
:
(
data
:
string
)
=>
void
):
void
;
onShutdown
(
listener
:
()
=>
void
):
IDisposable
;
onResize
(
listener
:
(
cols
:
number
,
rows
:
number
)
=>
void
):
void
;
onShutdown
(
listener
:
()
=>
void
):
void
;
}
}
export
interface
ITerminalProcessExtHostRequest
{
export
interface
ITerminalProcessExtHostRequest
{
...
...
src/vs/workbench/parts/terminal/node/terminalProcessExtHostProxy.ts
浏览文件 @
8bff3955
...
@@ -12,6 +12,8 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
...
@@ -12,6 +12,8 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
// For ext host processes connected checks happen on the ext host
// For ext host processes connected checks happen on the ext host
public
connected
:
boolean
=
true
;
public
connected
:
boolean
=
true
;
private
_disposables
:
IDisposable
[]
=
[];
constructor
(
constructor
(
public
terminalId
:
number
,
public
terminalId
:
number
,
shellLaunchConfig
:
IShellLaunchConfig
,
shellLaunchConfig
:
IShellLaunchConfig
,
...
@@ -25,6 +27,11 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
...
@@ -25,6 +27,11 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
this
.
_terminalService
.
requestExtHostProcess
(
this
,
shellLaunchConfig
,
cols
,
rows
);
this
.
_terminalService
.
requestExtHostProcess
(
this
,
shellLaunchConfig
,
cols
,
rows
);
}
}
public
dispose
():
void
{
this
.
_disposables
.
forEach
(
d
=>
d
.
dispose
());
this
.
_disposables
.
length
=
0
;
}
public
emitData
(
data
:
string
):
void
{
public
emitData
(
data
:
string
):
void
{
this
.
emit
(
'
message
'
,
{
type
:
'
data
'
,
content
:
data
}
as
IMessageFromTerminalProcess
);
this
.
emit
(
'
message
'
,
{
type
:
'
data
'
,
content
:
data
}
as
IMessageFromTerminalProcess
);
}
}
...
@@ -39,6 +46,7 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
...
@@ -39,6 +46,7 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
public
emitExit
(
exitCode
:
number
):
void
{
public
emitExit
(
exitCode
:
number
):
void
{
this
.
emit
(
'
exit
'
,
exitCode
);
this
.
emit
(
'
exit
'
,
exitCode
);
this
.
dispose
();
}
}
public
send
(
message
:
IMessageToTerminalProcess
):
boolean
{
public
send
(
message
:
IMessageToTerminalProcess
):
boolean
{
...
@@ -50,21 +58,21 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
...
@@ -50,21 +58,21 @@ export class TerminalProcessExtHostProxy extends EventEmitter implements ITermin
return
true
;
return
true
;
}
}
public
onInput
(
listener
:
(
data
:
string
)
=>
void
):
IDisposable
{
public
onInput
(
listener
:
(
data
:
string
)
=>
void
):
void
{
const
outerListener
=
(
data
)
=>
listener
(
data
);
const
outerListener
=
(
data
)
=>
listener
(
data
);
this
.
on
(
'
input
'
,
outerListener
);
this
.
on
(
'
input
'
,
outerListener
);
return
toDisposable
(()
=>
this
.
removeListener
(
'
input
'
,
outerListener
));
this
.
_disposables
.
push
(
toDisposable
(()
=>
this
.
removeListener
(
'
input
'
,
outerListener
)
));
}
}
public
onResize
(
listener
:
(
cols
:
number
,
rows
:
number
)
=>
void
):
IDisposable
{
public
onResize
(
listener
:
(
cols
:
number
,
rows
:
number
)
=>
void
):
void
{
const
outerListener
=
(
cols
,
rows
)
=>
listener
(
cols
,
rows
);
const
outerListener
=
(
cols
,
rows
)
=>
listener
(
cols
,
rows
);
this
.
on
(
'
resize
'
,
outerListener
);
this
.
on
(
'
resize
'
,
outerListener
);
return
toDisposable
(()
=>
this
.
removeListener
(
'
resize
'
,
outerListener
));
this
.
_disposables
.
push
(
toDisposable
(()
=>
this
.
removeListener
(
'
resize
'
,
outerListener
)
));
}
}
public
onShutdown
(
listener
:
()
=>
void
):
IDisposable
{
public
onShutdown
(
listener
:
()
=>
void
):
void
{
const
outerListener
=
()
=>
listener
();
const
outerListener
=
()
=>
listener
();
this
.
on
(
'
shutdown
'
,
outerListener
);
this
.
on
(
'
shutdown
'
,
outerListener
);
return
toDisposable
(()
=>
this
.
removeListener
(
'
shutdown
'
,
outerListener
));
this
.
_disposables
.
push
(
toDisposable
(()
=>
this
.
removeListener
(
'
shutdown
'
,
outerListener
)
));
}
}
}
}
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录