Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
9e5efe61
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,发现更多精彩内容 >>
提交
9e5efe61
编写于
10月 23, 2020
作者:
R
Rob Lourens
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Ensure that "starting" label shows up for all new remote terminals
上级
47f1e94d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
2 deletion
+18
-2
src/vs/workbench/contrib/terminal/browser/remoteTerminalService.ts
...rkbench/contrib/terminal/browser/remoteTerminalService.ts
+18
-2
未找到文件。
src/vs/workbench/contrib/terminal/browser/remoteTerminalService.ts
浏览文件 @
9e5efe61
...
...
@@ -3,6 +3,7 @@
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import
*
as
nls
from
'
vs/nls
'
;
import
{
Barrier
}
from
'
vs/base/common/async
'
;
import
{
Emitter
,
Event
}
from
'
vs/base/common/event
'
;
import
{
Disposable
}
from
'
vs/base/common/lifecycle
'
;
...
...
@@ -21,6 +22,7 @@ export class RemoteTerminalService extends Disposable implements IRemoteTerminal
public
_serviceBrand
:
undefined
;
private
readonly
_remoteTerminalChannel
:
RemoteTerminalChannelClient
|
null
;
private
_hasConnectedToRemote
=
false
;
constructor
(
@
ITerminalInstanceService
readonly
terminalInstanceService
:
ITerminalInstanceService
,
...
...
@@ -43,7 +45,15 @@ export class RemoteTerminalService extends Disposable implements IRemoteTerminal
throw
new
Error
(
`Cannot create remote terminal when there is no remote!`
);
}
return
new
RemoteTerminalProcess
(
terminalId
,
shellLaunchConfig
,
activeWorkspaceRootUri
,
cols
,
rows
,
configHelper
,
this
.
_remoteTerminalChannel
,
this
.
_remoteAgentService
,
this
.
_logService
,
this
.
_commandService
);
let
isPreconnectionTerminal
=
false
;
if
(
!
this
.
_hasConnectedToRemote
)
{
isPreconnectionTerminal
=
true
;
this
.
_remoteAgentService
.
getEnvironment
().
then
(()
=>
{
this
.
_hasConnectedToRemote
=
true
;
});
}
return
new
RemoteTerminalProcess
(
terminalId
,
shellLaunchConfig
,
activeWorkspaceRootUri
,
cols
,
rows
,
configHelper
,
isPreconnectionTerminal
,
this
.
_remoteTerminalChannel
,
this
.
_remoteAgentService
,
this
.
_logService
,
this
.
_commandService
);
}
public
async
listTerminals
():
Promise
<
IRemoteTerminalAttachTarget
[]
>
{
...
...
@@ -86,6 +96,7 @@ export class RemoteTerminalProcess extends Disposable implements ITerminalChildP
private
readonly
_cols
:
number
,
private
readonly
_rows
:
number
,
private
readonly
_configHelper
:
ITerminalConfigHelper
,
private
readonly
_isPreconnectionTerminal
:
boolean
,
private
readonly
_remoteTerminalChannel
:
RemoteTerminalChannelClient
,
private
readonly
_remoteAgentService
:
IRemoteAgentService
,
private
readonly
_logService
:
ILogService
,
...
...
@@ -94,10 +105,15 @@ export class RemoteTerminalProcess extends Disposable implements ITerminalChildP
super
();
this
.
_startBarrier
=
new
Barrier
();
this
.
_remoteTerminalId
=
0
;
if
(
this
.
_isPreconnectionTerminal
)
{
// Add a loading title only if this terminal is
// instantiated before a connection is up and running
setTimeout
(()
=>
this
.
_onProcessTitleChanged
.
fire
(
nls
.
localize
(
'
terminal.integrated.starting
'
,
"
Starting2...
"
)),
0
);
}
}
public
async
start
():
Promise
<
ITerminalLaunchError
|
undefined
>
{
// Fetch the environment to check shell permissions
const
env
=
await
this
.
_remoteAgentService
.
getEnvironment
();
if
(
!
env
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录