Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
5341fac1
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,发现更多精彩内容 >>
提交
5341fac1
编写于
6月 19, 2017
作者:
T
t-amqi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add telemetry and AB test options
上级
7942e121
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
57 addition
and
13 deletion
+57
-13
src/vs/platform/telemetry/common/telemetry.ts
src/vs/platform/telemetry/common/telemetry.ts
+1
-0
src/vs/platform/telemetry/common/telemetryUtils.ts
src/vs/platform/telemetry/common/telemetryUtils.ts
+5
-1
src/vs/workbench/parts/quickopen/common/quickopenActions.ts
src/vs/workbench/parts/quickopen/common/quickopenActions.ts
+19
-1
src/vs/workbench/services/textfile/common/textFileEditorModel.ts
...workbench/services/textfile/common/textFileEditorModel.ts
+32
-11
未找到文件。
src/vs/platform/telemetry/common/telemetry.ts
浏览文件 @
5341fac1
...
...
@@ -23,6 +23,7 @@ export interface ITelemetryData {
export
interface
ITelemetryExperiments
{
mergeQuickLinks
:
boolean
;
showTaskDocumentation
:
boolean
;
}
export
interface
ITelemetryService
{
...
...
src/vs/platform/telemetry/common/telemetryUtils.ts
浏览文件 @
5341fac1
...
...
@@ -18,6 +18,7 @@ import { ServicesAccessor } from 'vs/platform/instantiation/common/instantiation
export
const
defaultExperiments
:
ITelemetryExperiments
=
{
mergeQuickLinks
:
false
,
showTaskDocumentation
:
true
};
export
const
NullTelemetryService
=
{
...
...
@@ -45,10 +46,12 @@ export function loadExperiments(accessor: ServicesAccessor): ITelemetryExperimen
let
{
mergeQuickLinks
,
showTaskDocumentation
,
}
=
splitExperimentsRandomness
(
storageService
);
return
applyOverrides
({
mergeQuickLinks
,
showTaskDocumentation
,
},
configurationService
);
}
...
...
@@ -64,13 +67,14 @@ function applyOverrides(experiments: ITelemetryExperiments, configurationService
function
splitExperimentsRandomness
(
storageService
:
IStorageService
):
ITelemetryExperiments
{
const
random1
=
getExperimentsRandomness
(
storageService
);
const
[
random2
,
/* showNewUserWatermark */
]
=
splitRandom
(
random1
);
const
[
random2
,
showTaskDocumentation
]
=
splitRandom
(
random1
);
const
[
random3
,
/* openUntitledFile */
]
=
splitRandom
(
random2
);
const
[
random4
,
mergeQuickLinks
]
=
splitRandom
(
random3
);
// tslint:disable-next-line:no-unused-variable (https://github.com/Microsoft/TypeScript/issues/16628)
const
[
random5
,
/* enableWelcomePage */
]
=
splitRandom
(
random4
);
return
{
mergeQuickLinks
,
showTaskDocumentation
,
};
}
...
...
src/vs/workbench/parts/quickopen/common/quickopenActions.ts
浏览文件 @
5341fac1
...
...
@@ -16,7 +16,7 @@ export const ALL_COMMANDS_PREFIX = '>';
export
class
ShowTasksAction
extends
Action
{
public
static
ID
=
'
workbench.action.showTasks
'
;
public
static
LABEL
=
nls
.
localize
(
'
showTasks
'
,
"
Show
Task M
enu
"
);
public
static
LABEL
=
nls
.
localize
(
'
showTasks
'
,
"
Show
task m
enu
"
);
constructor
(
id
:
string
,
...
...
@@ -34,3 +34,21 @@ export class ShowTasksAction extends Action {
return
TPromise
.
as
(
null
);
}
}
export
class
ShowTasksDocumentationAction
extends
Action
{
public
static
ID
=
'
workbench.action.showTaskDocumentation
'
;
public
static
LABEL
=
nls
.
localize
(
'
showTaskDocumentation
'
,
"
Show task documentation
"
);
constructor
(
id
:
string
,
label
:
string
,
)
{
super
(
id
,
label
);
}
public
run
(
context
?:
any
):
TPromise
<
any
>
{
window
.
open
(
'
https://go.microsoft.com/fwlink/?LinkId=733558
'
);
return
TPromise
.
as
(
null
);
}
}
\ No newline at end of file
src/vs/workbench/services/textfile/common/textFileEditorModel.ts
浏览文件 @
5341fac1
...
...
@@ -31,12 +31,12 @@ import { IMessageService, Severity, IChoiceService } from 'vs/platform/message/c
import
{
IModeService
}
from
'
vs/editor/common/services/modeService
'
;
import
{
IModelService
}
from
'
vs/editor/common/services/modelService
'
;
import
{
ITelemetryService
}
from
'
vs/platform/telemetry/common/telemetry
'
;
import
{
anonymize
}
from
'
vs/platform/telemetry/common/telemetryUtils
'
;
import
{
anonymize
,
isShowTaskDocumentation
}
from
'
vs/platform/telemetry/common/telemetryUtils
'
;
import
{
RunOnceScheduler
}
from
'
vs/base/common/async
'
;
import
{
IRawTextSource
}
from
'
vs/editor/common/model/textSource
'
;
import
{
StorageScope
,
IStorageService
}
from
'
vs/platform/storage/common/storage
'
;
import
{
localize
}
from
'
vs/nls
'
;
import
{
ShowTasksAction
}
from
'
vs/workbench/parts/quickopen/common/quickopenActions
'
;
import
{
ShowTasksAction
,
ShowTasksDocumentationAction
}
from
'
vs/workbench/parts/quickopen/common/quickopenActions
'
;
/**
* The text file editor model listens to changes to its underlying code editor model and saves these changes through the file service back to the disk.
*/
...
...
@@ -333,23 +333,44 @@ export class TextFileEditorModel extends BaseTextEditorModel implements ITextFil
private
showTaskNotification
():
void
{
const
storageKey
=
'
workbench.tasks.ranTaskBefore
'
;
if
(
!
this
.
storageService
.
get
(
storageKey
))
{
if
(
this
.
storageService
.
get
(
storageKey
))
{
const
fileName
=
path
.
relative
(
this
.
contextService
.
getWorkspace
().
resource
.
toString
(),
this
.
resource
.
toString
());
if
(
fileName
.
match
(
/^gruntfile
\.
js$/i
)
||
fileName
.
match
(
/^gulpfile
\.
js$/i
)
||
fileName
.
match
(
/^tsconfig
\.
json$/i
))
{
const
message
=
localize
(
'
taskFileOpened
'
,
"
Visual Studio Code has extra functionality for this type of file
"
);
const
action
=
this
.
instantiationService
.
createInstance
(
ShowTasksAction
,
ShowTasksAction
.
ID
,
localize
(
'
showTasks
'
,
"
Show Tasks
"
));
const
message
=
localize
(
'
taskFileOpened
'
,
`Run your
${
fileName
.
split
(
'
.
'
)[
0
]}
in vscode. Get started here.`
);
let
action
:
any
;
let
messageTest
:
string
;
const
showDocumentation
=
isShowTaskDocumentation
(
this
.
storageService
);
if
(
showDocumentation
)
{
action
=
this
.
instantiationService
.
createInstance
(
ShowTasksDocumentationAction
,
ShowTasksDocumentationAction
.
ID
,
localize
(
'
showTaskDocumentation
'
,
"
Show task Documentation
"
));
messageTest
=
ShowTasksDocumentationAction
.
LABEL
;
}
else
{
action
=
this
.
instantiationService
.
createInstance
(
ShowTasksAction
,
ShowTasksAction
.
ID
,
localize
(
'
showTasks
'
,
"
Show tasks
"
));
messageTest
=
ShowTasksAction
.
LABEL
;
}
const
options
=
[
action
.
label
,
messageTest
,
localize
(
'
neverShowAgain
'
,
"
Don't show again
"
),
localize
(
'
close
'
,
"
Close
"
)
,
localize
(
'
close
'
,
"
Close
"
)
];
this
.
choiceService
.
choose
(
Severity
.
Info
,
message
,
options
,
2
).
done
(
choice
=>
{
switch
(
choice
)
{
case
0
:
return
action
.
run
();
case
1
:
return
this
.
storageService
.
store
(
storageKey
,
true
,
StorageScope
.
GLOBAL
);
case
2
:
return
;
case
0
:
{
this
.
telemetryService
.
publicLog
(
'
taskNotificationOptionChoice
'
,
{
choice
:
0
,
test
:
showDocumentation
});
this
.
storageService
.
store
(
storageKey
,
true
,
StorageScope
.
GLOBAL
);
return
action
.
run
();
}
case
1
:
{
this
.
telemetryService
.
publicLog
(
'
taskNotificationOptionChoice
'
,
{
choice
:
1
,
test
:
showDocumentation
});
return
this
.
storageService
.
store
(
storageKey
,
true
,
StorageScope
.
GLOBAL
);
}
case
2
:
{
this
.
telemetryService
.
publicLog
(
'
taskNotificationOptionChoice
'
,
{
choice
:
2
,
test
:
showDocumentation
});
return
;
}
}
});
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录