Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
c1d001a9
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,发现更多精彩内容 >>
提交
c1d001a9
编写于
3月 12, 2019
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Re-applying Cleaning up reviver handling for webviews
Reverting the revert of
09d4f006
上级
d9bc0a18
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
57 addition
and
43 deletion
+57
-43
src/vs/workbench/api/electron-browser/mainThreadWebview.ts
src/vs/workbench/api/electron-browser/mainThreadWebview.ts
+56
-42
src/vs/workbench/contrib/webview/electron-browser/webviewEditorService.ts
.../contrib/webview/electron-browser/webviewEditorService.ts
+1
-1
未找到文件。
src/vs/workbench/api/electron-browser/mainThreadWebview.ts
浏览文件 @
c1d001a9
...
...
@@ -3,7 +3,7 @@
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import
{
onUnexpectedError
}
from
'
vs/base/common/errors
'
;
import
{
Disposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
Disposable
,
IDisposable
}
from
'
vs/base/common/lifecycle
'
;
import
*
as
map
from
'
vs/base/common/map
'
;
import
{
URI
,
UriComponents
}
from
'
vs/base/common/uri
'
;
import
{
ICodeEditorService
}
from
'
vs/editor/browser/services/codeEditorService
'
;
...
...
@@ -17,8 +17,8 @@ import { ExtHostContext, ExtHostWebviewsShape, IExtHostContext, MainContext, Mai
import
{
editorGroupToViewColumn
,
EditorViewColumn
,
viewColumnToEditorGroup
}
from
'
vs/workbench/api/shared/editor
'
;
import
{
CodeInsetController
}
from
'
vs/workbench/contrib/codeinset/electron-browser/codeInset.contribution
'
;
import
{
WebviewEditor
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewEditor
'
;
import
{
RevivedWebviewEditorInput
,
WebviewEditorInput
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewEditorInput
'
;
import
{
ICreateWebViewShowOptions
,
IWebviewEditorService
,
WebviewInputOptions
,
WebviewReviver
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewEditorService
'
;
import
{
WebviewEditorInput
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewEditorInput
'
;
import
{
ICreateWebViewShowOptions
,
IWebviewEditorService
,
WebviewInputOptions
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewEditorService
'
;
import
{
WebviewElement
}
from
'
vs/workbench/contrib/webview/electron-browser/webviewElement
'
;
import
{
IEditorGroupsService
}
from
'
vs/workbench/services/editor/common/editorGroupsService
'
;
import
{
ACTIVE_GROUP
,
IEditorService
}
from
'
vs/workbench/services/editor/common/editorService
'
;
...
...
@@ -28,9 +28,7 @@ import * as vscode from 'vscode';
import
{
extHostNamedCustomer
}
from
'
./extHostCustomers
'
;
@
extHostNamedCustomer
(
MainContext
.
MainThreadWebviews
)
export
class
MainThreadWebviews
extends
Disposable
implements
MainThreadWebviewsShape
,
WebviewReviver
{
private
static
readonly
viewType
=
'
mainThreadWebview
'
;
export
class
MainThreadWebviews
extends
Disposable
implements
MainThreadWebviewsShape
{
private
static
readonly
standardSupportedLinkSchemes
=
[
'
http
'
,
'
https
'
,
'
mailto
'
];
...
...
@@ -40,18 +38,18 @@ export class MainThreadWebviews extends Disposable implements MainThreadWebviews
private
readonly
_proxy
:
ExtHostWebviewsShape
;
private
readonly
_webviews
=
new
Map
<
WebviewPanelHandle
,
WebviewEditorInput
>
();
private
readonly
_webviewsElements
=
new
Map
<
WebviewInsetHandle
,
WebviewElement
>
();
private
readonly
_revivers
=
new
Set
<
string
>
();
private
readonly
_revivers
=
new
Map
<
string
,
IDisposable
>
();
private
_activeWebview
:
WebviewPanelHandle
|
undefined
=
undefined
;
constructor
(
context
:
IExtHostContext
,
@
ILifecycleService
lifecycleService
:
ILifecycleService
,
@
IExtensionService
extensionService
:
IExtensionService
,
@
IEditorGroupsService
private
readonly
_editorGroupService
:
IEditorGroupsService
,
@
IEditorService
private
readonly
_editorService
:
IEditorService
,
@
IWebviewEditorService
private
readonly
_webviewService
:
IWebviewEditorService
,
@
IOpenerService
private
readonly
_openerService
:
IOpenerService
,
@
IExtensionService
private
readonly
_extensionService
:
IExtensionService
,
@
ITelemetryService
private
readonly
_telemetryService
:
ITelemetryService
,
@
IInstantiationService
private
readonly
_instantiationService
:
IInstantiationService
,
@
ICodeEditorService
private
readonly
_codeEditorService
:
ICodeEditorService
,
...
...
@@ -63,7 +61,18 @@ export class MainThreadWebviews extends Disposable implements MainThreadWebviews
_editorService
.
onDidActiveEditorChange
(
this
.
onActiveEditorChanged
,
this
,
this
.
_toDispose
);
_editorService
.
onDidVisibleEditorsChange
(
this
.
onVisibleEditorsChanged
,
this
,
this
.
_toDispose
);
this
.
_toDispose
.
push
(
_webviewService
.
registerReviver
(
this
));
// This reviver's only job is to activate webview extensions
// This should trigger the real reviver to be registered from the extension host side.
this
.
_toDispose
.
push
(
_webviewService
.
registerReviver
({
canRevive
:
(
webview
)
=>
{
const
viewType
=
webview
.
state
.
viewType
;
if
(
viewType
)
{
extensionService
.
activateByEvent
(
`onWebviewPanel:
${
viewType
}
`
);
}
return
false
;
},
reviveWebview
:
()
=>
{
throw
new
Error
(
'
not implemented
'
);
}
}));
lifecycleService
.
onBeforeShutdown
(
e
=>
{
e
.
veto
(
this
.
_onBeforeShutdown
());
...
...
@@ -85,7 +94,7 @@ export class MainThreadWebviews extends Disposable implements MainThreadWebviews
mainThreadShowOptions
.
group
=
viewColumnToEditorGroup
(
this
.
_editorGroupService
,
showOptions
.
viewColumn
);
}
const
webview
=
this
.
_webviewService
.
createWebview
(
MainThreadWebviews
.
viewType
,
title
,
mainThreadShowOptions
,
reviveWebviewOptions
(
options
),
URI
.
revive
(
extensionLocation
),
this
.
createWebviewEventDelegate
(
handle
));
const
webview
=
this
.
_webviewService
.
createWebview
(
this
.
getInternalWebviewId
(
viewType
)
,
title
,
mainThreadShowOptions
,
reviveWebviewOptions
(
options
),
URI
.
revive
(
extensionLocation
),
this
.
createWebviewEventDelegate
(
handle
));
webview
.
state
=
{
viewType
:
viewType
,
state
:
undefined
...
...
@@ -206,50 +215,55 @@ export class MainThreadWebviews extends Disposable implements MainThreadWebviews
}
public
$registerSerializer
(
viewType
:
string
):
void
{
this
.
_revivers
.
add
(
viewType
);
}
public
$unregisterSerializer
(
viewType
:
string
):
void
{
this
.
_revivers
.
delete
(
viewType
);
}
public
reviveWebview
(
webview
:
WebviewEditorInput
):
Promise
<
void
>
{
const
viewType
=
webview
.
state
.
viewType
;
return
Promise
.
resolve
(
this
.
_extensionService
.
activateByEvent
(
`onWebviewPanel:
${
viewType
}
`
).
then
(()
=>
{
const
handle
=
'
revival-
'
+
MainThreadWebviews
.
revivalPool
++
;
this
.
_webviews
.
set
(
handle
,
webview
);
webview
.
_events
=
this
.
createWebviewEventDelegate
(
handle
);
let
state
=
undefined
;
if
(
webview
.
state
.
state
)
{
try
{
state
=
JSON
.
parse
(
webview
.
state
.
state
);
}
catch
{
// noop
if
(
this
.
_revivers
.
has
(
viewType
))
{
throw
new
Error
(
`Reviver for
${
viewType
}
already registered`
);
}
this
.
_revivers
.
set
(
viewType
,
this
.
_webviewService
.
registerReviver
({
canRevive
:
(
webview
)
=>
{
return
!
webview
.
isDisposed
()
&&
webview
.
state
&&
webview
.
state
.
viewType
===
viewType
;
},
reviveWebview
:
async
(
webview
):
Promise
<
void
>
=>
{
const
viewType
=
webview
.
state
.
viewType
;
const
handle
=
'
revival-
'
+
MainThreadWebviews
.
revivalPool
++
;
this
.
_webviews
.
set
(
handle
,
webview
);
webview
.
_events
=
this
.
createWebviewEventDelegate
(
handle
);
let
state
=
undefined
;
if
(
webview
.
state
.
state
)
{
try
{
state
=
JSON
.
parse
(
webview
.
state
.
state
);
}
catch
{
// noop
}
}
}
return
this
.
_proxy
.
$deserializeWebviewPanel
(
handle
,
webview
.
state
.
viewType
,
webview
.
getTitle
(),
state
,
editorGroupToViewColumn
(
this
.
_editorGroupService
,
webview
.
group
||
ACTIVE_GROUP
),
webview
.
options
)
.
then
(
undefined
,
error
=>
{
try
{
await
this
.
_proxy
.
$deserializeWebviewPanel
(
handle
,
webview
.
state
.
viewType
,
webview
.
getTitle
(),
state
,
editorGroupToViewColumn
(
this
.
_editorGroupService
,
webview
.
group
||
ACTIVE_GROUP
),
webview
.
options
);
}
catch
(
error
)
{
onUnexpectedError
(
error
);
webview
.
html
=
MainThreadWebviews
.
getDeserializationFailedContents
(
viewType
);
});
}
}
}));
}
public
canRevive
(
webview
:
WebviewEditorInput
):
boolean
{
if
(
webview
.
isDisposed
()
||
!
webview
.
state
||
webview
.
viewType
!==
MainThreadWebviews
.
viewType
)
{
return
false
;
public
$unregisterSerializer
(
viewType
:
string
):
void
{
const
reviver
=
this
.
_revivers
.
get
(
viewType
);
if
(
!
reviver
)
{
throw
new
Error
(
`No reviver for
${
viewType
}
registered`
);
}
return
this
.
_revivers
.
has
(
webview
.
state
.
viewType
)
||
!!
(
webview
as
RevivedWebviewEditorInput
).
reviver
;
reviver
.
dispose
();
this
.
_revivers
.
delete
(
viewType
);
}
private
getInternalWebviewId
(
viewType
:
string
):
string
{
return
`mainThreadWebview-
${
viewType
}
`
;
}
private
_onBeforeShutdown
():
boolean
{
this
.
_webviews
.
forEach
((
view
)
=>
{
if
(
this
.
canRevive
(
view
))
{
view
.
state
.
state
=
view
.
webviewState
;
this
.
_webviews
.
forEach
((
web
view
)
=>
{
if
(
!
webview
.
isDisposed
()
&&
webview
.
state
&&
this
.
_revivers
.
has
(
webview
.
state
.
viewType
))
{
webview
.
state
.
state
=
web
view
.
webviewState
;
}
});
return
false
;
// Don't veto shutdown
...
...
src/vs/workbench/contrib/webview/electron-browser/webviewEditorService.ts
浏览文件 @
c1d001a9
...
...
@@ -92,7 +92,7 @@ export class WebviewEditorService implements IWebviewEditorService {
_serviceBrand
:
any
;
private
readonly
_revivers
=
new
Set
<
WebviewReviver
>
();
private
_awaitingRevival
:
{
input
:
WebviewEditorInput
,
resolve
:
()
=>
void
}[]
=
[];
private
_awaitingRevival
:
Array
<
{
input
:
WebviewEditorInput
,
resolve
:
()
=>
void
}
>
=
[];
constructor
(
@
IEditorService
private
readonly
_editorService
:
IEditorService
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录