Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
57278dbe
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
57278dbe
编写于
3月 13, 2020
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Hook up isReadonly for custom editor input
上级
4493125a
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
37 addition
and
20 deletion
+37
-20
src/vs/workbench/api/browser/mainThreadWebview.ts
src/vs/workbench/api/browser/mainThreadWebview.ts
+28
-17
src/vs/workbench/contrib/customEditor/browser/customEditorInput.ts
...rkbench/contrib/customEditor/browser/customEditorInput.ts
+1
-1
src/vs/workbench/contrib/customEditor/common/customEditor.ts
src/vs/workbench/contrib/customEditor/common/customEditor.ts
+2
-0
src/vs/workbench/contrib/customEditor/common/customTextEditorModel.ts
...ench/contrib/customEditor/common/customTextEditorModel.ts
+6
-2
未找到文件。
src/vs/workbench/api/browser/mainThreadWebview.ts
浏览文件 @
57278dbe
...
...
@@ -279,12 +279,12 @@ export class MainThreadWebviews extends Disposable implements extHostProtocol.Ma
this
.
_revivers
.
delete
(
viewType
);
}
public
$registerTextEditorProvider
(
extensionData
:
extHostProtocol
.
WebviewExtensionDescription
,
viewType
:
string
,
options
:
modes
.
IWebviewPanelOptions
):
void
{
return
this
.
registerEditorProvider
(
ModelType
.
Text
,
extensionData
,
viewType
,
option
s
);
public
$registerTextEditorProvider
(
extensionData
:
extHostProtocol
.
WebviewExtensionDescription
,
viewType
:
string
,
options
:
modes
.
IWebviewPanelOptions
,
capabilities
:
extHostProtocol
.
CustomTextEditorCapabilities
):
void
{
this
.
registerEditorProvider
(
ModelType
.
Text
,
extensionData
,
viewType
,
options
,
capabilitie
s
);
}
public
$registerCustomEditorProvider
(
extensionData
:
extHostProtocol
.
WebviewExtensionDescription
,
viewType
:
string
,
options
:
modes
.
IWebviewPanelOptions
):
void
{
return
this
.
registerEditorProvider
(
ModelType
.
Custom
,
extensionData
,
viewType
,
options
);
this
.
registerEditorProvider
(
ModelType
.
Custom
,
extensionData
,
viewType
,
options
,
{}
);
}
private
registerEditorProvider
(
...
...
@@ -292,41 +292,45 @@ export class MainThreadWebviews extends Disposable implements extHostProtocol.Ma
extensionData
:
extHostProtocol
.
WebviewExtensionDescription
,
viewType
:
string
,
options
:
modes
.
IWebviewPanelOptions
,
):
void
{
capabilities
:
extHostProtocol
.
CustomTextEditorCapabilities
,
):
DisposableStore
{
if
(
this
.
_editorProviders
.
has
(
viewType
))
{
throw
new
Error
(
`Provider for
${
viewType
}
already registered`
);
}
const
extension
=
reviveWebviewExtension
(
extensionData
);
this
.
_editorProviders
.
set
(
viewType
,
this
.
_webviewWorkbenchService
.
registerResolver
({
const
disposables
=
new
DisposableStore
();
disposables
.
add
(
this
.
_webviewWorkbenchService
.
registerResolver
({
canResolve
:
(
webviewInput
)
=>
{
return
webviewInput
instanceof
CustomEditorInput
&&
webviewInput
.
viewType
===
viewType
;
},
resolveWebview
:
async
(
webviewInput
:
CustomEditorInput
)
=>
{
const
handle
=
webviewInput
.
id
;
this
.
_webviewInputs
.
add
(
handle
,
webviewInput
);
this
.
hookupWebviewEventDelegate
(
handle
,
webviewInput
);
this
.
hookupWebviewEventDelegate
(
handle
,
webviewInput
);
webviewInput
.
webview
.
options
=
options
;
webviewInput
.
webview
.
extension
=
extension
;
const
resource
=
webviewInput
.
resource
;
let
modelRef
=
await
this
.
getOrCreateCustomEditorModel
(
modelType
,
resource
,
viewType
);
const
modelRef
=
await
this
.
getOrCreateCustomEditorModel
(
modelType
,
webviewInput
,
resource
,
viewType
);
webviewInput
.
webview
.
onDispose
(()
=>
{
modelRef
.
dispose
();
});
if
(
capabilities
.
supportsMove
)
{
webviewInput
.
onMove
(
async
(
newResource
:
URI
)
=>
{
const
oldModel
=
modelRef
;
modelRef
=
await
this
.
getOrCreateCustomEditorModel
(
modelType
,
newResource
,
viewType
);
this
.
_proxy
.
$onMoveCustomEditor
(
handle
,
newResource
,
viewType
);
oldModel
.
dispose
();
});
}
try
{
await
this
.
_proxy
.
$resolveWebviewEditor
(
resource
,
handle
,
viewType
,
webviewInput
.
getTitle
(),
editorGroupToViewColumn
(
this
.
_editorGroupService
,
webviewInput
.
group
||
0
),
webviewInput
.
webview
.
options
);
await
this
.
_proxy
.
$resolveWebviewEditor
(
resource
,
handle
,
viewType
,
webviewInput
.
getTitle
(),
editorGroupToViewColumn
(
this
.
_editorGroupService
,
webviewInput
.
group
||
0
),
webviewInput
.
webview
.
options
);
}
catch
(
error
)
{
onUnexpectedError
(
error
);
webviewInput
.
webview
.
html
=
MainThreadWebviews
.
getDeserializationFailedContents
(
viewType
);
...
...
@@ -334,6 +338,10 @@ export class MainThreadWebviews extends Disposable implements extHostProtocol.Ma
}
}
}));
this
.
_editorProviders
.
set
(
viewType
,
disposables
);
return
disposables
;
}
public
$unregisterEditorProvider
(
viewType
:
string
):
void
{
...
...
@@ -350,11 +358,10 @@ export class MainThreadWebviews extends Disposable implements extHostProtocol.Ma
private
async
getOrCreateCustomEditorModel
(
modelType
:
ModelType
,
webviewInput
:
WebviewInput
,
resource
:
URI
,
viewType
:
string
,
):
Promise
<
IReference
<
ICustomEditorModel
>>
{
const
existingModel
=
this
.
_customEditorService
.
models
.
tryRetain
(
webviewInput
.
resource
,
webviewInput
.
viewType
);
const
existingModel
=
this
.
_customEditorService
.
models
.
tryRetain
(
resource
,
viewType
);
if
(
existingModel
)
{
return
existingModel
;
}
...
...
@@ -612,6 +619,10 @@ class MainThreadCustomEditorModel extends Disposable implements ICustomEditorMod
//#endregion
public
isReadonly
()
{
return
this
.
_editable
;
}
public
get
viewType
()
{
return
this
.
_viewType
;
}
...
...
src/vs/workbench/contrib/customEditor/browser/customEditorInput.ts
浏览文件 @
57278dbe
...
...
@@ -97,7 +97,7 @@ export class CustomEditorInput extends LazilyResolvedWebviewEditorInput {
}
public
isReadonly
():
boolean
{
return
false
;
// TODO
return
this
.
_modelRef
?
this
.
_modelRef
.
object
.
isReadonly
()
:
false
;
}
public
isDirty
():
boolean
{
...
...
src/vs/workbench/contrib/customEditor/common/customEditor.ts
浏览文件 @
57278dbe
...
...
@@ -49,6 +49,8 @@ export interface ICustomEditorModel extends IDisposable {
readonly
viewType
:
string
;
readonly
resource
:
URI
;
isReadonly
():
boolean
;
isDirty
():
boolean
;
readonly
onDidChangeDirty
:
Event
<
void
>
;
...
...
src/vs/workbench/contrib/customEditor/common/customTextEditorModel.ts
浏览文件 @
57278dbe
...
...
@@ -31,12 +31,12 @@ export class CustomTextEditorModel extends Disposable implements ICustomEditorMo
private
constructor
(
public
readonly
viewType
:
string
,
private
readonly
_resource
:
URI
,
model
:
IReference
<
IResolvedTextEditorModel
>
,
private
readonly
_
model
:
IReference
<
IResolvedTextEditorModel
>
,
@
ITextFileService
private
readonly
textFileService
:
ITextFileService
,
)
{
super
();
this
.
_register
(
model
);
this
.
_register
(
_
model
);
this
.
_register
(
this
.
textFileService
.
files
.
onDidChangeDirty
(
e
=>
{
if
(
isEqual
(
this
.
resource
,
e
.
resource
))
{
...
...
@@ -50,6 +50,10 @@ export class CustomTextEditorModel extends Disposable implements ICustomEditorMo
return
this
.
_resource
;
}
public
isReadonly
():
boolean
{
return
this
.
_model
.
object
.
isReadonly
();
}
public
isDirty
():
boolean
{
return
this
.
textFileService
.
isDirty
(
this
.
resource
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录