Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
ffaea408
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,发现更多精彩内容 >>
提交
ffaea408
编写于
7月 10, 2017
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
move things that belong into window into window
上级
d1a43b1d
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
37 addition
and
38 deletion
+37
-38
src/vs/code/electron-main/window.ts
src/vs/code/electron-main/window.ts
+37
-18
src/vs/code/electron-main/windows.ts
src/vs/code/electron-main/windows.ts
+0
-20
未找到文件。
src/vs/code/electron-main/window.ts
浏览文件 @
ffaea408
...
...
@@ -9,6 +9,7 @@ import * as path from 'path';
import
*
as
objects
from
'
vs/base/common/objects
'
;
import
{
stopProfiling
}
from
'
vs/base/node/profiler
'
;
import
nls
=
require
(
'
vs/nls
'
);
import
URI
from
"
vs/base/common/uri
"
;
import
{
IStorageService
}
from
'
vs/platform/storage/node/storage
'
;
import
{
shell
,
screen
,
BrowserWindow
,
systemPreferences
,
app
}
from
'
electron
'
;
import
{
TPromise
,
TValueCallback
}
from
'
vs/base/common/winjs.base
'
;
...
...
@@ -110,10 +111,6 @@ export class CodeWindow implements ICodeWindow {
// respect configured menu bar visibility
this
.
onConfigurationUpdated
();
// TODO@joao: hook this up to some initialization routine this causes a race between setting the headers and doing
// a request that needs them. chances are low
this
.
setCommonHTTPHeaders
();
// Eventing
this
.
registerListeners
();
}
...
...
@@ -203,20 +200,6 @@ export class CodeWindow implements ICodeWindow {
this
.
_lastFocusTime
=
Date
.
now
();
// since we show directly, we need to set the last focus time too
}
private
setCommonHTTPHeaders
():
void
{
getCommonHTTPHeaders
().
done
(
headers
=>
{
if
(
!
this
.
_win
)
{
return
;
}
const
urls
=
[
'
https://marketplace.visualstudio.com/*
'
,
'
https://*.vsassets.io/*
'
];
this
.
_win
.
webContents
.
session
.
webRequest
.
onBeforeSendHeaders
({
urls
},
(
details
,
cb
)
=>
{
cb
({
cancel
:
false
,
requestHeaders
:
objects
.
assign
(
details
.
requestHeaders
,
headers
)
});
});
});
}
public
hasHiddenTitleBarStyle
():
boolean
{
return
this
.
hiddenTitleBarStyle
;
}
...
...
@@ -315,6 +298,42 @@ export class CodeWindow implements ICodeWindow {
private
registerListeners
():
void
{
// Set common HTTP headers
// TODO@joao: hook this up to some initialization routine this causes a race between setting the headers and doing
// a request that needs them. chances are low
getCommonHTTPHeaders
().
done
(
headers
=>
{
if
(
!
this
.
_win
)
{
return
;
}
const
urls
=
[
'
https://marketplace.visualstudio.com/*
'
,
'
https://*.vsassets.io/*
'
];
this
.
_win
.
webContents
.
session
.
webRequest
.
onBeforeSendHeaders
({
urls
},
(
details
,
cb
)
=>
{
cb
({
cancel
:
false
,
requestHeaders
:
objects
.
assign
(
details
.
requestHeaders
,
headers
)
});
});
});
// Prevent loading of svgs
this
.
_win
.
webContents
.
session
.
webRequest
.
onBeforeRequest
((
details
,
callback
)
=>
{
if
(
details
.
url
.
indexOf
(
'
.svg
'
)
>
0
)
{
const
uri
=
URI
.
parse
(
details
.
url
);
if
(
uri
&&
!
uri
.
scheme
.
match
(
/file/i
)
&&
(
uri
.
path
as
any
).
endsWith
(
'
.svg
'
))
{
return
callback
({
cancel
:
true
});
}
}
return
callback
({});
});
this
.
_win
.
webContents
.
session
.
webRequest
.
onHeadersReceived
((
details
,
callback
)
=>
{
const
contentType
:
string
[]
=
(
details
.
responseHeaders
[
'
content-type
'
]
||
details
.
responseHeaders
[
'
Content-Type
'
])
as
any
;
if
(
contentType
&&
Array
.
isArray
(
contentType
)
&&
contentType
.
some
(
x
=>
x
.
toLowerCase
().
indexOf
(
'
image/svg
'
)
>=
0
))
{
return
callback
({
cancel
:
true
});
}
return
callback
({
cancel
:
false
,
responseHeaders
:
details
.
responseHeaders
});
});
// Remember that we loaded
this
.
_win
.
webContents
.
on
(
'
did-finish-load
'
,
()
=>
{
this
.
_readyState
=
ReadyState
.
LOADING
;
...
...
src/vs/code/electron-main/windows.ts
浏览文件 @
ffaea408
...
...
@@ -10,7 +10,6 @@ import * as fs from 'original-fs';
import
*
as
nls
from
'
vs/nls
'
;
import
*
as
arrays
from
'
vs/base/common/arrays
'
;
import
{
assign
,
mixin
}
from
'
vs/base/common/objects
'
;
import
URI
from
'
vs/base/common/uri
'
;
import
{
IBackupMainService
}
from
'
vs/platform/backup/common/backup
'
;
import
{
IEnvironmentService
,
ParsedArgs
}
from
'
vs/platform/environment/common/environment
'
;
import
{
IStorageService
}
from
'
vs/platform/storage/node/storage
'
;
...
...
@@ -836,25 +835,6 @@ export class WindowsManager implements IWindowsMainService {
codeWindow
.
win
.
on
(
'
unresponsive
'
,
()
=>
this
.
onWindowError
(
codeWindow
,
WindowError
.
UNRESPONSIVE
));
codeWindow
.
win
.
on
(
'
closed
'
,
()
=>
this
.
onWindowClosed
(
codeWindow
));
// Prevent loading on svgs in main renderer
codeWindow
.
win
.
webContents
.
session
.
webRequest
.
onBeforeRequest
((
details
,
callback
)
=>
{
if
(
details
.
url
.
indexOf
(
'
.svg
'
)
>
0
)
{
const
uri
=
URI
.
parse
(
details
.
url
);
if
(
uri
&&
!
uri
.
scheme
.
match
(
/file/i
)
&&
(
uri
.
path
as
any
).
endsWith
(
'
.svg
'
))
{
return
callback
({
cancel
:
true
});
}
}
return
callback
({});
});
codeWindow
.
win
.
webContents
.
session
.
webRequest
.
onHeadersReceived
((
details
,
callback
)
=>
{
const
contentType
:
string
[]
=
(
details
.
responseHeaders
[
'
content-type
'
]
||
details
.
responseHeaders
[
'
Content-Type
'
])
as
any
;
if
(
contentType
&&
Array
.
isArray
(
contentType
)
&&
contentType
.
some
(
x
=>
x
.
toLowerCase
().
indexOf
(
'
image/svg
'
)
>=
0
))
{
return
callback
({
cancel
:
true
});
}
return
callback
({
cancel
:
false
,
responseHeaders
:
details
.
responseHeaders
});
});
// Lifecycle
this
.
lifecycleService
.
registerWindow
(
codeWindow
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录