Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
01b7ae0a
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,体验更适合开发者的 AI 搜索 >>
提交
01b7ae0a
编写于
4月 26, 2018
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
properly handle exists-errors, #48660
上级
6cbbb7e6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
2 deletion
+22
-2
src/vs/workbench/services/files/electron-browser/remoteFileService.ts
...ench/services/files/electron-browser/remoteFileService.ts
+22
-2
未找到文件。
src/vs/workbench/services/files/electron-browser/remoteFileService.ts
浏览文件 @
01b7ae0a
...
...
@@ -557,6 +557,12 @@ export class RemoteFileService extends FileService {
}).
then
(
fileStat
=>
{
this
.
_onAfterOperation
.
fire
(
new
FileOperationEvent
(
source
,
FileOperation
.
MOVE
,
fileStat
));
return
fileStat
;
},
err
=>
{
const
result
=
this
.
_tryParseFileOperationResult
(
err
);
if
(
result
===
FileOperationResult
.
FILE_MOVE_CONFLICT
)
{
throw
new
FileOperationError
(
localize
(
'
fileMoveConflict
'
,
"
Unable to move/copy. File already exists at destination.
"
),
result
);
}
throw
err
;
});
});
}
...
...
@@ -581,7 +587,18 @@ export class RemoteFileService extends FileService {
if
(
source
.
scheme
===
target
.
scheme
&&
(
provider
.
capabilities
&
FileSystemProviderCapabilities
.
FileFolderCopy
))
{
// good: provider supports copy withing scheme
return
provider
.
copy
(
source
,
target
,
{
overwrite
}).
then
(
stat
=>
toIFileStat
(
provider
,
[
target
,
stat
]));
return
provider
.
copy
(
source
,
target
,
{
overwrite
}).
then
(
stat
=>
{
return
toIFileStat
(
provider
,
[
target
,
stat
]);
}).
then
(
fileStat
=>
{
this
.
_onAfterOperation
.
fire
(
new
FileOperationEvent
(
source
,
FileOperation
.
COPY
,
fileStat
));
return
fileStat
;
},
err
=>
{
const
result
=
this
.
_tryParseFileOperationResult
(
err
);
if
(
result
===
FileOperationResult
.
FILE_MOVE_CONFLICT
)
{
throw
new
FileOperationError
(
localize
(
'
fileMoveConflict
'
,
"
Unable to move/copy. File already exists at destination.
"
),
result
);
}
throw
err
;
});
}
const
prepare
=
overwrite
...
...
@@ -603,7 +620,10 @@ export class RemoteFileService extends FileService {
return
fileStat
;
});
},
err
=>
{
if
(
err
instanceof
Error
&&
err
.
name
===
'
ENOPRO
'
)
{
const
result
=
this
.
_tryParseFileOperationResult
(
err
);
if
(
result
===
FileOperationResult
.
FILE_MOVE_CONFLICT
)
{
throw
new
FileOperationError
(
localize
(
'
fileMoveConflict
'
,
"
Unable to move/copy. File already exists at destination.
"
),
result
);
}
else
if
(
err
instanceof
Error
&&
err
.
name
===
'
ENOPRO
'
)
{
// file scheme
return
super
.
updateContent
(
target
,
content
.
value
,
{
encoding
:
content
.
encoding
});
}
else
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录