Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
36cafba0
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,发现更多精彩内容 >>
提交
36cafba0
编写于
1月 23, 2018
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ext dev - delete untitled workspace on close
上级
24ecf494
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
13 addition
and
10 deletion
+13
-10
src/vs/code/electron-main/windows.ts
src/vs/code/electron-main/windows.ts
+13
-10
未找到文件。
src/vs/code/electron-main/windows.ts
浏览文件 @
36cafba0
...
...
@@ -1318,7 +1318,10 @@ export class WindowsManager implements IWindowsMainService {
}
if
(
e
.
window
.
config
&&
!!
e
.
window
.
config
.
extensionDevelopmentPath
)
{
return
;
// do not ask to save workspace when doing extension development
// do not ask to save workspace when doing extension development
// but still delete it.
this
.
workspacesMainService
.
deleteUntitledWorkspaceSync
(
workspace
);
return
;
}
if
(
windowClosing
&&
!
isMacintosh
&&
this
.
getWindowCount
()
===
1
)
{
...
...
@@ -1716,8 +1719,8 @@ class Dialogs {
class
WorkspacesManager
{
constructor
(
private
workspacesService
:
IWorkspacesMainService
,
private
backupService
:
IBackupMainService
,
private
workspaces
Main
Service
:
IWorkspacesMainService
,
private
backup
Main
Service
:
IBackupMainService
,
private
environmentService
:
IEnvironmentService
,
private
windowsMainService
:
IWindowsMainService
)
{
...
...
@@ -1741,7 +1744,7 @@ class WorkspacesManager {
return
TPromise
.
as
(
null
);
// return early if the workspace is not valid
}
return
this
.
workspacesService
.
createWorkspace
(
folders
).
then
(
workspace
=>
{
return
this
.
workspaces
Main
Service
.
createWorkspace
(
folders
).
then
(
workspace
=>
{
return
this
.
doSaveAndOpenWorkspace
(
window
,
workspace
,
path
);
});
});
...
...
@@ -1758,7 +1761,7 @@ class WorkspacesManager {
}
// Prevent overwriting a workspace that is currently opened in another window
if
(
findWindowOnWorkspace
(
this
.
windowsMainService
.
getWindows
(),
{
id
:
this
.
workspacesService
.
getWorkspaceId
(
path
),
configPath
:
path
}))
{
if
(
findWindowOnWorkspace
(
this
.
windowsMainService
.
getWindows
(),
{
id
:
this
.
workspaces
Main
Service
.
getWorkspaceId
(
path
),
configPath
:
path
}))
{
const
options
:
Electron
.
MessageBoxOptions
=
{
title
:
product
.
nameLong
,
type
:
'
info
'
,
...
...
@@ -1777,7 +1780,7 @@ class WorkspacesManager {
private
doSaveAndOpenWorkspace
(
window
:
CodeWindow
,
workspace
:
IWorkspaceIdentifier
,
path
?:
string
):
TPromise
<
IEnterWorkspaceResult
>
{
let
savePromise
:
TPromise
<
IWorkspaceIdentifier
>
;
if
(
path
)
{
savePromise
=
this
.
workspacesService
.
saveWorkspace
(
workspace
,
path
);
savePromise
=
this
.
workspaces
Main
Service
.
saveWorkspace
(
workspace
,
path
);
}
else
{
savePromise
=
TPromise
.
as
(
workspace
);
}
...
...
@@ -1788,7 +1791,7 @@ class WorkspacesManager {
// Register window for backups and migrate current backups over
let
backupPath
:
string
;
if
(
!
window
.
config
.
extensionDevelopmentPath
)
{
backupPath
=
this
.
backupService
.
registerWorkspaceBackupSync
(
workspace
,
window
.
config
.
backupPath
);
backupPath
=
this
.
backup
Main
Service
.
registerWorkspaceBackupSync
(
workspace
,
window
.
config
.
backupPath
);
}
// Update window configuration properly based on transition to workspace
...
...
@@ -1861,7 +1864,7 @@ class WorkspacesManager {
// Don't Save: delete workspace
case
ConfirmResult
.
DONT_SAVE
:
this
.
workspacesService
.
deleteUntitledWorkspaceSync
(
workspace
);
this
.
workspaces
Main
Service
.
deleteUntitledWorkspaceSync
(
workspace
);
return
false
;
// Save: save workspace, but do not veto unload
...
...
@@ -1873,7 +1876,7 @@ class WorkspacesManager {
defaultPath
:
this
.
getUntitledWorkspaceSaveDialogDefaultPath
(
workspace
)
},
window
).
then
(
target
=>
{
if
(
target
)
{
return
this
.
workspacesService
.
saveWorkspace
(
workspace
,
target
).
then
(()
=>
false
,
()
=>
false
);
return
this
.
workspaces
Main
Service
.
saveWorkspace
(
workspace
,
target
).
then
(()
=>
false
,
()
=>
false
);
}
return
true
;
// keep veto if no target was provided
...
...
@@ -1889,7 +1892,7 @@ class WorkspacesManager {
return
dirname
(
workspace
);
}
const
resolvedWorkspace
=
this
.
workspacesService
.
resolveWorkspaceSync
(
workspace
.
configPath
);
const
resolvedWorkspace
=
this
.
workspaces
Main
Service
.
resolveWorkspaceSync
(
workspace
.
configPath
);
if
(
resolvedWorkspace
&&
resolvedWorkspace
.
folders
.
length
>
0
)
{
for
(
const
folder
of
resolvedWorkspace
.
folders
)
{
if
(
folder
.
uri
.
scheme
===
Schemas
.
file
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录