Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
09ebde8a
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,发现更多精彩内容 >>
提交
09ebde8a
编写于
12月 05, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
💄
上级
c032f0e2
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
26 addition
and
27 deletion
+26
-27
src/vs/code/electron-main/windows.ts
src/vs/code/electron-main/windows.ts
+1
-1
src/vs/platform/backup/common/backup.ts
src/vs/platform/backup/common/backup.ts
+1
-1
src/vs/platform/backup/electron-main/backupMainService.ts
src/vs/platform/backup/electron-main/backupMainService.ts
+7
-8
src/vs/platform/backup/test/electron-main/backupMainService.test.ts
...tform/backup/test/electron-main/backupMainService.test.ts
+17
-17
未找到文件。
src/vs/code/electron-main/windows.ts
浏览文件 @
09ebde8a
...
...
@@ -769,7 +769,7 @@ export class WindowsManager implements IWindowsMainService {
}
if
(
!
configuration
.
extensionDevelopmentPath
)
{
this
.
backupService
.
registerWindowForBackups
(
vscodeWindow
.
id
,
!
configuration
.
workspacePath
,
emptyWorkspaceBackupFolder
,
configuration
.
workspacePath
);
this
.
backupService
.
registerWindowForBackups
Sync
(
vscodeWindow
.
id
,
!
configuration
.
workspacePath
,
emptyWorkspaceBackupFolder
,
configuration
.
workspacePath
);
}
// Only load when the window has not vetoed this
...
...
src/vs/platform/backup/common/backup.ts
浏览文件 @
09ebde8a
...
...
@@ -20,7 +20,7 @@ export interface IBackupMainService extends IBackupService {
workspaceBackupPaths
:
string
[];
emptyWorkspaceBackupPaths
:
string
[];
registerWindowForBackups
(
windowId
:
number
,
isEmptyWorkspace
:
boolean
,
backupFolder
?:
string
,
workspacePath
?:
string
)
;
registerWindowForBackups
Sync
(
windowId
:
number
,
isEmptyWorkspace
:
boolean
,
backupFolder
?:
string
,
workspacePath
?:
string
):
void
;
}
export
interface
IBackupService
{
...
...
src/vs/platform/backup/electron-main/backupMainService.ts
浏览文件 @
09ebde8a
...
...
@@ -22,8 +22,7 @@ export class BackupMainService implements IBackupMainService {
protected
workspacesJsonPath
:
string
;
private
backups
:
IBackupWorkspacesFormat
;
protected
mapWindowToBackupFolder
:
{
[
windowId
:
number
]:
string
;
};
private
mapWindowToBackupFolder
:
{
[
windowId
:
number
]:
string
;
};
constructor
(
@
IEnvironmentService
private
environmentService
:
IEnvironmentService
...
...
@@ -51,7 +50,7 @@ export class BackupMainService implements IBackupMainService {
return
TPromise
.
as
(
path
.
join
(
this
.
backupHome
,
this
.
mapWindowToBackupFolder
[
windowId
]));
}
public
registerWindowForBackups
(
windowId
:
number
,
isEmptyWorkspace
:
boolean
,
backupFolder
?:
string
,
workspacePath
?:
string
):
void
{
public
registerWindowForBackups
Sync
(
windowId
:
number
,
isEmptyWorkspace
:
boolean
,
backupFolder
?:
string
,
workspacePath
?:
string
):
void
{
// Generate a new folder if this is a new empty workspace
if
(
isEmptyWorkspace
&&
!
backupFolder
)
{
backupFolder
=
this
.
getRandomEmptyWorkspaceId
();
...
...
@@ -61,11 +60,7 @@ export class BackupMainService implements IBackupMainService {
this
.
pushBackupPathsSync
(
isEmptyWorkspace
?
backupFolder
:
workspacePath
,
isEmptyWorkspace
);
}
private
getRandomEmptyWorkspaceId
():
string
{
return
(
Date
.
now
()
+
Math
.
round
(
Math
.
random
()
*
1000
)).
toString
();
}
protected
pushBackupPathsSync
(
workspaceIdentifier
:
string
,
isEmptyWorkspace
:
boolean
):
string
{
private
pushBackupPathsSync
(
workspaceIdentifier
:
string
,
isEmptyWorkspace
:
boolean
):
string
{
if
(
!
isEmptyWorkspace
)
{
workspaceIdentifier
=
this
.
sanitizePath
(
workspaceIdentifier
);
}
...
...
@@ -212,6 +207,10 @@ export class BackupMainService implements IBackupMainService {
}
}
private
getRandomEmptyWorkspaceId
():
string
{
return
(
Date
.
now
()
+
Math
.
round
(
Math
.
random
()
*
1000
)).
toString
();
}
private
sanitizePath
(
p
)
{
return
platform
.
isLinux
?
p
:
p
.
toLowerCase
();
}
...
...
src/vs/platform/backup/test/electron-main/backupMainService.test.ts
浏览文件 @
09ebde8a
...
...
@@ -77,16 +77,16 @@ suite('BackupMainService', () => {
test
(
'
service validates backup workspaces on startup and cleans up
'
,
done
=>
{
// 1) backup workspace path does not exist
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
loadSync
();
assert
.
deepEqual
(
service
.
workspaceBackupPaths
,
[]);
// 2) backup workspace path exists with empty contents within
fs
.
mkdirSync
(
service
.
toBackupPath
(
fooFile
.
fsPath
));
fs
.
mkdirSync
(
service
.
toBackupPath
(
barFile
.
fsPath
));
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
loadSync
();
assert
.
deepEqual
(
service
.
workspaceBackupPaths
,
[]);
assert
.
ok
(
!
fs
.
exists
(
service
.
toBackupPath
(
fooFile
.
fsPath
)));
...
...
@@ -97,8 +97,8 @@ suite('BackupMainService', () => {
fs
.
mkdirSync
(
service
.
toBackupPath
(
barFile
.
fsPath
));
fs
.
mkdirSync
(
path
.
join
(
service
.
toBackupPath
(
fooFile
.
fsPath
),
'
file
'
));
fs
.
mkdirSync
(
path
.
join
(
service
.
toBackupPath
(
barFile
.
fsPath
),
'
untitled
'
));
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
loadSync
();
assert
.
deepEqual
(
service
.
workspaceBackupPaths
,
[]);
assert
.
ok
(
!
fs
.
exists
(
service
.
toBackupPath
(
fooFile
.
fsPath
)));
...
...
@@ -110,7 +110,7 @@ suite('BackupMainService', () => {
fs
.
mkdirSync
(
service
.
toBackupPath
(
fooFile
.
fsPath
));
fs
.
mkdirSync
(
service
.
toBackupPath
(
barFile
.
fsPath
));
fs
.
mkdirSync
(
fileBackups
);
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
assert
.
equal
(
service
.
workspaceBackupPaths
.
length
,
1
);
assert
.
equal
(
service
.
emptyWorkspaceBackupPaths
.
length
,
0
);
fs
.
writeFileSync
(
path
.
join
(
fileBackups
,
'
backup.txt
'
),
''
);
...
...
@@ -233,8 +233,8 @@ suite('BackupMainService', () => {
suite
(
'
registerWindowForBackups
'
,
()
=>
{
test
(
'
pushWorkspaceBackupPathsSync should persist paths to workspaces.json
'
,
()
=>
{
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
false
,
null
,
barFile
.
fsPath
);
assert
.
deepEqual
(
service
.
workspaceBackupPaths
,
[
fooFile
.
fsPath
,
barFile
.
fsPath
]);
pfs
.
readFile
(
backupWorkspacesPath
,
'
utf-8
'
).
then
(
buffer
=>
{
const
json
=
<
IBackupWorkspacesFormat
>
JSON
.
parse
(
buffer
);
...
...
@@ -245,8 +245,8 @@ suite('BackupMainService', () => {
suite
(
'
removeBackupPathSync
'
,
()
=>
{
test
(
'
should remove folder workspaces from workspaces.json
'
,
done
=>
{
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
false
,
null
,
barFile
.
fsPath
);
service
.
removeBackupPathSync
(
fooFile
.
fsPath
,
false
);
pfs
.
readFile
(
backupWorkspacesPath
,
'
utf-8
'
).
then
(
buffer
=>
{
const
json
=
<
IBackupWorkspacesFormat
>
JSON
.
parse
(
buffer
);
...
...
@@ -261,8 +261,8 @@ suite('BackupMainService', () => {
});
test
(
'
should remove empty workspaces from workspaces.json
'
,
done
=>
{
service
.
registerWindowForBackups
(
1
,
true
,
'
foo
'
);
service
.
registerWindowForBackups
(
2
,
true
,
'
bar
'
);
service
.
registerWindowForBackups
Sync
(
1
,
true
,
'
foo
'
);
service
.
registerWindowForBackups
Sync
(
2
,
true
,
'
bar
'
);
service
.
removeBackupPathSync
(
'
foo
'
,
true
);
pfs
.
readFile
(
backupWorkspacesPath
,
'
utf-8
'
).
then
(
buffer
=>
{
const
json
=
<
IBackupWorkspacesFormat
>
JSON
.
parse
(
buffer
);
...
...
@@ -313,8 +313,8 @@ suite('BackupMainService', () => {
suite
(
'
getBackupPath
'
,
()
=>
{
test
(
'
should return the window
\'
s correct path
'
,
done
=>
{
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
2
,
true
,
'
test
'
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
2
,
true
,
'
test
'
);
service
.
getBackupPath
(
1
).
then
(
window1Path
=>
{
assert
.
equal
(
window1Path
,
service
.
toBackupPath
(
fooFile
.
fsPath
));
service
.
getBackupPath
(
2
).
then
(
window2Path
=>
{
...
...
@@ -325,8 +325,8 @@ suite('BackupMainService', () => {
});
test
(
'
should override stale window paths with new paths
'
,
done
=>
{
service
.
registerWindowForBackups
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
(
1
,
false
,
null
,
barFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
fooFile
.
fsPath
);
service
.
registerWindowForBackups
Sync
(
1
,
false
,
null
,
barFile
.
fsPath
);
service
.
getBackupPath
(
1
).
then
(
windowPath
=>
{
assert
.
equal
(
windowPath
,
service
.
toBackupPath
(
barFile
.
fsPath
));
done
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录