Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
b9a348e2
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,发现更多精彩内容 >>
提交
b9a348e2
编写于
6月 28, 2017
作者:
D
Dirk Baeumer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixes #29761: Use picker instead of quick pick to select a build or test task.
上级
1bd94398
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
152 addition
and
238 deletion
+152
-238
src/vs/workbench/parts/tasks/browser/buildQuickOpen.ts
src/vs/workbench/parts/tasks/browser/buildQuickOpen.ts
+0
-69
src/vs/workbench/parts/tasks/browser/quickOpen.ts
src/vs/workbench/parts/tasks/browser/quickOpen.ts
+4
-56
src/vs/workbench/parts/tasks/browser/taskQuickOpen.ts
src/vs/workbench/parts/tasks/browser/taskQuickOpen.ts
+2
-11
src/vs/workbench/parts/tasks/browser/testQuickOpen.ts
src/vs/workbench/parts/tasks/browser/testQuickOpen.ts
+0
-63
src/vs/workbench/parts/tasks/common/taskService.ts
src/vs/workbench/parts/tasks/common/taskService.ts
+5
-2
src/vs/workbench/parts/tasks/electron-browser/task.contribution.ts
...rkbench/parts/tasks/electron-browser/task.contribution.ts
+141
-37
未找到文件。
src/vs/workbench/parts/tasks/browser/buildQuickOpen.ts
已删除
100644 → 0
浏览文件 @
1bd94398
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
nls
=
require
(
'
vs/nls
'
);
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
QuickOpen
=
require
(
'
vs/base/parts/quickopen/common/quickOpen
'
);
import
Model
=
require
(
'
vs/base/parts/quickopen/browser/quickOpenModel
'
);
import
{
IQuickOpenService
}
from
'
vs/platform/quickOpen/common/quickOpen
'
;
import
{
ProblemMatcherRegistry
}
from
'
vs/platform/markers/common/problemMatcher
'
;
import
{
Task
,
TaskGroup
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
ITaskService
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
*
as
base
from
'
./quickOpen
'
;
class
TaskEntry
extends
base
.
TaskEntry
{
constructor
(
taskService
:
ITaskService
,
quickOpenService
:
IQuickOpenService
,
task
:
Task
,
highlights
:
Model
.
IHighlight
[]
=
[])
{
super
(
taskService
,
quickOpenService
,
task
,
highlights
);
}
public
run
(
mode
:
QuickOpen
.
Mode
,
context
:
Model
.
IContext
):
boolean
{
if
(
mode
===
QuickOpen
.
Mode
.
PREVIEW
)
{
return
false
;
}
let
task
=
this
.
_task
;
if
(
this
.
taskService
.
canCustomize
()
&&
task
.
problemMatchers
===
void
0
||
task
.
problemMatchers
.
length
===
0
)
{
this
.
attachProblemMatcher
(
task
).
then
((
task
)
=>
{
if
(
task
)
{
this
.
doRun
(
task
);
}
});
return
true
;
}
else
{
return
this
.
doRun
(
task
);
}
}
}
export
class
QuickOpenHandler
extends
base
.
QuickOpenHandler
{
constructor
(
@
IQuickOpenService
quickOpenService
:
IQuickOpenService
,
@
ITaskService
taskService
:
ITaskService
)
{
super
(
quickOpenService
,
taskService
);
}
public
getAriaLabel
():
string
{
return
nls
.
localize
(
'
tasksAriaLabel
'
,
"
Type the name of a build task
"
);
}
protected
getTasks
():
TPromise
<
Task
[]
>
{
return
ProblemMatcherRegistry
.
onReady
().
then
(()
=>
this
.
taskService
.
getTasksForGroup
(
TaskGroup
.
Build
));
}
protected
createEntry
(
task
:
Task
,
highlights
:
Model
.
IHighlight
[]):
base
.
TaskEntry
{
return
new
TaskEntry
(
this
.
taskService
,
this
.
quickOpenService
,
task
,
highlights
);
}
public
getEmptyLabel
(
searchString
:
string
):
string
{
if
(
searchString
.
length
>
0
)
{
return
nls
.
localize
(
'
noTasksMatching
'
,
"
No tasks matching
"
);
}
return
nls
.
localize
(
'
noTasksFound
'
,
"
No build tasks found
"
);
}
}
src/vs/workbench/parts/tasks/browser/quickOpen.ts
浏览文件 @
b9a348e2
...
...
@@ -9,23 +9,16 @@ import Filters = require('vs/base/common/filters');
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
{
Action
,
IAction
}
from
'
vs/base/common/actions
'
;
import
{
IStringDictionary
}
from
'
vs/base/common/collections
'
;
import
*
as
Objects
from
'
vs/base/common/objects
'
;
import
Quickopen
=
require
(
'
vs/workbench/browser/quickopen
'
);
import
QuickOpen
=
require
(
'
vs/base/parts/quickopen/common/quickOpen
'
);
import
Model
=
require
(
'
vs/base/parts/quickopen/browser/quickOpenModel
'
);
import
{
IQuickOpenService
,
IPickOpenEntry
}
from
'
vs/platform/quickOpen/common/quickOpen
'
;
import
{
ProblemMatcherRegistry
,
NamedProblemMatcher
}
from
'
vs/platform/markers/common/problemMatcher
'
;
import
{
IQuickOpenService
}
from
'
vs/platform/quickOpen/common/quickOpen
'
;
import
{
Task
,
TaskSourceKind
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
ITaskService
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
{
ITaskService
,
RunOptions
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
{
ActionBarContributor
,
ContributableActionProvider
}
from
'
vs/workbench/browser/actions
'
;
interface
ProblemMatcherPickEntry
extends
IPickOpenEntry
{
matcher
:
NamedProblemMatcher
;
learnMore
?:
boolean
;
}
export
class
TaskEntry
extends
Model
.
QuickOpenEntry
{
constructor
(
protected
taskService
:
ITaskService
,
protected
quickOpenService
:
IQuickOpenService
,
protected
_task
:
Task
,
highlights
:
Model
.
IHighlight
[]
=
[])
{
...
...
@@ -44,53 +37,8 @@ export class TaskEntry extends Model.QuickOpenEntry {
return
this
.
_task
;
}
protected
attachProblemMatcher
(
task
:
Task
):
TPromise
<
Task
>
{
let
entries
:
ProblemMatcherPickEntry
[]
=
[];
for
(
let
key
of
ProblemMatcherRegistry
.
keys
())
{
let
matcher
=
ProblemMatcherRegistry
.
get
(
key
);
if
(
matcher
.
name
===
matcher
.
label
)
{
entries
.
push
({
label
:
matcher
.
name
,
matcher
:
matcher
});
}
else
{
entries
.
push
({
label
:
matcher
.
label
,
description
:
`$
${
matcher
.
name
}
`
,
matcher
:
matcher
});
}
}
if
(
entries
.
length
>
0
)
{
entries
=
entries
.
sort
((
a
,
b
)
=>
a
.
label
.
localeCompare
(
b
.
label
));
entries
[
0
].
separator
=
{
border
:
true
};
entries
.
unshift
(
{
label
:
nls
.
localize
(
'
continueWithout
'
,
'
Continue without scanning the build output
'
),
matcher
:
undefined
},
{
label
:
nls
.
localize
(
'
learnMoreAbout
'
,
'
Learn more about scanning the build output
'
),
matcher
:
undefined
,
learnMore
:
true
}
);
return
this
.
quickOpenService
.
pick
(
entries
,
{
placeHolder
:
nls
.
localize
(
'
selectProblemMatcher
'
,
'
Select for which kind of errors and warnings to scan the build output
'
)
}).
then
((
selected
)
=>
{
if
(
selected
)
{
if
(
selected
.
learnMore
)
{
this
.
taskService
.
openDocumentation
();
return
undefined
;
}
else
if
(
selected
.
matcher
)
{
let
newTask
=
Objects
.
deepClone
(
task
);
let
matcherReference
=
`$
${
selected
.
matcher
.
name
}
`
;
newTask
.
problemMatchers
=
[
matcherReference
];
this
.
taskService
.
customize
(
task
,
{
problemMatcher
:
[
matcherReference
]
},
true
);
return
newTask
;
}
else
{
return
task
;
}
}
else
{
return
task
;
}
});
}
return
TPromise
.
as
(
task
);
}
protected
doRun
(
task
:
Task
):
boolean
{
this
.
taskService
.
run
(
task
);
protected
doRun
(
task
:
Task
,
options
?:
RunOptions
):
boolean
{
this
.
taskService
.
run
(
task
,
options
);
if
(
task
.
command
.
presentation
.
focus
)
{
this
.
quickOpenService
.
close
();
return
false
;
...
...
src/vs/workbench/parts/tasks/browser/taskQuickOpen.ts
浏览文件 @
b9a348e2
...
...
@@ -10,7 +10,7 @@ import QuickOpen = require('vs/base/parts/quickopen/common/quickOpen');
import
Model
=
require
(
'
vs/base/parts/quickopen/browser/quickOpenModel
'
);
import
{
IQuickOpenService
}
from
'
vs/platform/quickOpen/common/quickOpen
'
;
import
{
Task
,
TaskGroup
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
Task
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
ITaskService
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
{
IExtensionService
}
from
'
vs/platform/extensions/common/extensions
'
;
...
...
@@ -27,16 +27,7 @@ class TaskEntry extends base.TaskEntry {
return
false
;
}
let
task
=
this
.
_task
;
if
(
this
.
taskService
.
canCustomize
()
&&
task
.
group
===
TaskGroup
.
Build
&&
((
task
.
problemMatchers
===
void
0
)
||
task
.
problemMatchers
.
length
===
0
))
{
this
.
attachProblemMatcher
(
task
).
then
(
task
=>
{
if
(
task
)
{
this
.
doRun
(
task
);
}
});
return
true
;
}
else
{
return
this
.
doRun
(
task
);
}
return
this
.
doRun
(
task
,
{
attachProblemMatcher
:
true
});
}
}
...
...
src/vs/workbench/parts/tasks/browser/testQuickOpen.ts
已删除
100644 → 0
浏览文件 @
1bd94398
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
nls
=
require
(
'
vs/nls
'
);
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
QuickOpen
=
require
(
'
vs/base/parts/quickopen/common/quickOpen
'
);
import
Model
=
require
(
'
vs/base/parts/quickopen/browser/quickOpenModel
'
);
import
{
IQuickOpenService
}
from
'
vs/platform/quickOpen/common/quickOpen
'
;
import
{
Task
,
TaskGroup
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
ITaskService
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
*
as
base
from
'
./quickOpen
'
;
class
TaskEntry
extends
base
.
TaskEntry
{
constructor
(
taskService
:
ITaskService
,
quickOpenService
:
IQuickOpenService
,
task
:
Task
,
highlights
:
Model
.
IHighlight
[]
=
[])
{
super
(
taskService
,
quickOpenService
,
task
,
highlights
);
}
public
run
(
mode
:
QuickOpen
.
Mode
,
context
:
Model
.
IContext
):
boolean
{
if
(
mode
===
QuickOpen
.
Mode
.
PREVIEW
)
{
return
false
;
}
let
task
=
this
.
_task
;
this
.
taskService
.
run
(
task
);
if
(
task
.
command
.
presentation
.
focus
)
{
this
.
quickOpenService
.
close
();
return
false
;
}
return
true
;
}
}
export
class
QuickOpenHandler
extends
base
.
QuickOpenHandler
{
constructor
(
@
IQuickOpenService
quickOpenService
:
IQuickOpenService
,
@
ITaskService
taskService
:
ITaskService
)
{
super
(
quickOpenService
,
taskService
);
}
public
getAriaLabel
():
string
{
return
nls
.
localize
(
'
tasksAriaLabel
'
,
"
Type the name of a test task
"
);
}
protected
getTasks
():
TPromise
<
Task
[]
>
{
return
this
.
taskService
.
getTasksForGroup
(
TaskGroup
.
Test
);
}
protected
createEntry
(
task
:
Task
,
highlights
:
Model
.
IHighlight
[]):
base
.
TaskEntry
{
return
new
TaskEntry
(
this
.
taskService
,
this
.
quickOpenService
,
task
,
highlights
);
}
public
getEmptyLabel
(
searchString
:
string
):
string
{
if
(
searchString
.
length
>
0
)
{
return
nls
.
localize
(
'
noTasksMatching
'
,
"
No tasks matching
"
);
}
return
nls
.
localize
(
'
noTasksFound
'
,
"
No test tasks found
"
);
}
}
src/vs/workbench/parts/tasks/common/taskService.ts
浏览文件 @
b9a348e2
...
...
@@ -27,15 +27,18 @@ export interface ITaskProvider {
provideTasks
():
TPromise
<
TaskSet
>
;
}
export
interface
RunOptions
{
attachProblemMatcher
?:
boolean
;
}
export
interface
ITaskService
extends
IEventEmitter
{
_serviceBrand
:
any
;
configureAction
():
Action
;
openDocumentation
():
void
;
build
():
TPromise
<
ITaskSummary
>
;
rebuild
():
TPromise
<
ITaskSummary
>
;
clean
():
TPromise
<
ITaskSummary
>
;
runTest
():
TPromise
<
ITaskSummary
>
;
run
(
task
:
string
|
Task
):
TPromise
<
ITaskSummary
>
;
run
(
task
:
string
|
Task
,
options
?:
RunOptions
):
TPromise
<
ITaskSummary
>
;
inTerminal
():
boolean
;
isActive
():
TPromise
<
boolean
>
;
getActiveTasks
():
TPromise
<
Task
[]
>
;
...
...
src/vs/workbench/parts/tasks/electron-browser/task.contribution.ts
浏览文件 @
b9a348e2
...
...
@@ -6,8 +6,6 @@
import
'
vs/css!./media/task.contribution
'
;
import
'
vs/workbench/parts/tasks/browser/taskQuickOpen
'
;
import
'
vs/workbench/parts/tasks/browser/buildQuickOpen
'
;
import
'
vs/workbench/parts/tasks/browser/testQuickOpen
'
;
import
*
as
nls
from
'
vs/nls
'
;
...
...
@@ -43,7 +41,7 @@ import { IExtensionService } from 'vs/platform/extensions/common/extensions';
import
{
CommandsRegistry
}
from
'
vs/platform/commands/common/commands
'
;
import
{
KeybindingsRegistry
}
from
'
vs/platform/keybinding/common/keybindingsRegistry
'
;
import
{
ServicesAccessor
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
ProblemMatcherRegistry
}
from
'
vs/platform/markers/common/problemMatcher
'
;
import
{
ProblemMatcherRegistry
,
NamedProblemMatcher
}
from
'
vs/platform/markers/common/problemMatcher
'
;
import
{
IStorageService
,
StorageScope
}
from
'
vs/platform/storage/common/storage
'
;
import
{
IProgressService2
,
IProgressOptions
,
ProgressLocation
}
from
'
vs/platform/progress/common/progress
'
;
import
{
IOpenerService
}
from
'
vs/platform/opener/common/opener
'
;
...
...
@@ -76,7 +74,7 @@ import { ITerminalService } from 'vs/workbench/parts/terminal/common/terminal';
import
{
ITaskSystem
,
ITaskResolver
,
ITaskSummary
,
ITaskExecuteResult
,
TaskExecuteKind
,
TaskError
,
TaskErrors
,
TaskSystemEvents
,
TaskTerminateResponse
}
from
'
vs/workbench/parts/tasks/common/taskSystem
'
;
import
{
Task
,
CustomTask
,
ConfiguringTask
,
ContributedTask
,
TaskSet
,
TaskGroup
,
ExecutionEngine
,
JsonSchemaVersion
,
TaskSourceKind
,
TaskIdentifier
}
from
'
vs/workbench/parts/tasks/common/tasks
'
;
import
{
ITaskService
,
TaskServiceEvents
,
ITaskProvider
,
TaskEvent
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
{
ITaskService
,
TaskServiceEvents
,
ITaskProvider
,
TaskEvent
,
RunOptions
}
from
'
vs/workbench/parts/tasks/common/taskService
'
;
import
{
templates
as
taskTemplates
}
from
'
vs/workbench/parts/tasks/common/taskTemplates
'
;
import
*
as
TaskConfig
from
'
../node/taskConfiguration
'
;
...
...
@@ -797,7 +795,7 @@ class TaskService extends EventEmitter implements ITaskService {
});
}
public
run
(
task
:
string
|
Task
):
TPromise
<
ITaskSummary
>
{
public
run
(
task
:
string
|
Task
,
options
?:
RunOptions
):
TPromise
<
ITaskSummary
>
{
return
this
.
getTaskSets
().
then
((
values
)
=>
{
let
resolver
=
this
.
createResolver
(
values
);
let
requested
:
string
;
...
...
@@ -812,6 +810,15 @@ class TaskService extends EventEmitter implements ITaskService {
if
(
!
toExecute
)
{
throw
new
TaskError
(
Severity
.
Info
,
nls
.
localize
(
'
TaskServer.noTask
'
,
'
Requested task {0} to execute not found.
'
,
requested
),
TaskErrors
.
TaskNotFound
);
}
else
{
if
(
options
&&
options
.
attachProblemMatcher
&&
this
.
canCustomize
()
&&
toExecute
.
group
===
TaskGroup
.
Build
&&
(
toExecute
.
problemMatchers
===
void
0
||
toExecute
.
problemMatchers
.
length
===
0
))
{
return
this
.
attachProblemMatcher
(
toExecute
).
then
((
toExecute
)
=>
{
if
(
toExecute
)
{
return
this
.
executeTask
(
toExecute
,
resolver
);
}
else
{
return
TPromise
.
as
(
undefined
);
}
});
}
return
this
.
executeTask
(
toExecute
,
resolver
);
}
}).
then
(
value
=>
value
,
(
error
)
=>
{
...
...
@@ -820,6 +827,56 @@ class TaskService extends EventEmitter implements ITaskService {
});
}
private
attachProblemMatcher
(
task
:
Task
):
TPromise
<
Task
>
{
interface
ProblemMatcherPickEntry
extends
IPickOpenEntry
{
matcher
:
NamedProblemMatcher
;
learnMore
?:
boolean
;
}
let
entries
:
ProblemMatcherPickEntry
[]
=
[];
for
(
let
key
of
ProblemMatcherRegistry
.
keys
())
{
let
matcher
=
ProblemMatcherRegistry
.
get
(
key
);
if
(
matcher
.
name
===
matcher
.
label
)
{
entries
.
push
({
label
:
matcher
.
name
,
matcher
:
matcher
});
}
else
{
entries
.
push
({
label
:
matcher
.
label
,
description
:
`$
${
matcher
.
name
}
`
,
matcher
:
matcher
});
}
}
if
(
entries
.
length
>
0
)
{
entries
=
entries
.
sort
((
a
,
b
)
=>
a
.
label
.
localeCompare
(
b
.
label
));
entries
[
0
].
separator
=
{
border
:
true
};
entries
.
unshift
(
{
label
:
nls
.
localize
(
'
continueWithout
'
,
'
Continue without scanning the build output
'
),
matcher
:
undefined
},
{
label
:
nls
.
localize
(
'
learnMoreAbout
'
,
'
Learn more about scanning the build output
'
),
matcher
:
undefined
,
learnMore
:
true
}
);
return
this
.
quickOpenService
.
pick
(
entries
,
{
placeHolder
:
nls
.
localize
(
'
selectProblemMatcher
'
,
'
Select for which kind of errors and warnings to scan the build output
'
),
autoFocus
:
{
autoFocusFirstEntry
:
true
}
}).
then
((
selected
)
=>
{
if
(
selected
)
{
if
(
selected
.
learnMore
)
{
this
.
openDocumentation
();
return
undefined
;
}
else
if
(
selected
.
matcher
)
{
let
newTask
=
Objects
.
deepClone
(
task
);
let
matcherReference
=
`$
${
selected
.
matcher
.
name
}
`
;
newTask
.
problemMatchers
=
[
matcherReference
];
this
.
customize
(
task
,
{
problemMatcher
:
[
matcherReference
]
},
true
);
return
newTask
;
}
else
{
return
task
;
}
}
else
{
return
task
;
}
});
}
return
TPromise
.
as
(
task
);
}
public
getTasksForGroup
(
group
:
string
):
TPromise
<
Task
[]
>
{
return
this
.
getTaskSets
().
then
((
values
)
=>
{
let
result
:
Task
[]
=
[];
...
...
@@ -1464,6 +1521,73 @@ class TaskService extends EventEmitter implements ITaskService {
return
true
;
}
private
showQuickPick
(
tasks
:
Task
[],
placeHolder
:
string
,
group
:
boolean
=
false
,
sort
:
boolean
=
false
):
TPromise
<
Task
>
{
if
(
tasks
===
void
0
||
tasks
===
null
||
tasks
.
length
===
0
)
{
return
TPromise
.
as
(
undefined
);
}
interface
TaskQickPickEntry
extends
IPickOpenEntry
{
task
:
Task
;
}
function
TaskQickPickEntry
(
task
:
Task
):
TaskQickPickEntry
{
return
{
label
:
task
.
_label
,
task
};
}
function
fillEntries
(
entries
:
TaskQickPickEntry
[],
tasks
:
Task
[],
groupLabel
:
string
,
withBorder
:
boolean
=
false
):
void
{
let
first
=
true
;
for
(
let
task
of
tasks
)
{
if
(
first
)
{
first
=
false
;
let
entry
=
TaskQickPickEntry
(
task
);
entry
.
separator
=
{
label
:
groupLabel
,
border
:
withBorder
};
entries
.
push
(
entry
);
}
else
{
entries
.
push
(
TaskQickPickEntry
(
task
));
}
}
}
let
entries
:
TaskQickPickEntry
[];
if
(
group
)
{
entries
=
[];
if
(
tasks
.
length
===
1
)
{
entries
.
push
(
TaskQickPickEntry
(
tasks
[
0
]));
}
else
{
let
recentlyUsedTasks
=
this
.
getRecentlyUsedTasks
();
let
recent
:
Task
[]
=
[];
let
configured
:
Task
[]
=
[];
let
detected
:
Task
[]
=
[];
let
taskMap
:
IStringDictionary
<
Task
>
=
Object
.
create
(
null
);
tasks
.
forEach
(
task
=>
taskMap
[
Task
.
getKey
(
task
)]
=
task
);
recentlyUsedTasks
.
keys
().
forEach
(
key
=>
{
let
task
=
taskMap
[
key
];
if
(
task
)
{
recent
.
push
(
task
);
}
});
for
(
let
task
of
tasks
)
{
if
(
!
recentlyUsedTasks
.
has
(
Task
.
getKey
(
task
)))
{
if
(
task
.
_source
.
kind
===
TaskSourceKind
.
Workspace
)
{
configured
.
push
(
task
);
}
else
{
detected
.
push
(
task
);
}
}
}
let
hasRecentlyUsed
:
boolean
=
recent
.
length
>
0
;
fillEntries
(
entries
,
recent
,
nls
.
localize
(
'
recentlyUsed
'
,
'
recently used tasks
'
));
configured
=
configured
.
sort
((
a
,
b
)
=>
a
.
_label
.
localeCompare
(
b
.
_label
));
let
hasConfigured
=
configured
.
length
>
0
;
fillEntries
(
entries
,
configured
,
nls
.
localize
(
'
configured
'
,
'
configured tasks
'
),
hasRecentlyUsed
);
detected
=
detected
.
sort
((
a
,
b
)
=>
a
.
_label
.
localeCompare
(
b
.
_label
));
fillEntries
(
entries
,
detected
,
nls
.
localize
(
'
detected
'
,
'
detected tasks
'
),
hasRecentlyUsed
||
hasConfigured
);
}
}
else
{
entries
=
tasks
.
map
<
TaskQickPickEntry
>
(
task
=>
{
return
{
label
:
task
.
_label
,
task
};
});
if
(
sort
)
{
entries
=
entries
.
sort
((
a
,
b
)
=>
a
.
task
.
_label
.
localeCompare
(
b
.
task
.
_label
));
}
}
return
this
.
quickOpenService
.
pick
(
entries
,
{
placeHolder
,
autoFocus
:
{
autoFocusFirstEntry
:
true
}
}).
then
(
entry
=>
entry
?
entry
.
task
:
undefined
);
}
private
runTaskCommand
(
accessor
:
ServicesAccessor
,
arg
:
any
):
void
{
if
(
!
this
.
canRunCommand
())
{
return
;
...
...
@@ -1514,7 +1638,11 @@ class TaskService extends EventEmitter implements ITaskService {
this
.
run
(
primaries
[
0
]);
return
;
}
this
.
quickOpenService
.
show
(
'
build task
'
);
this
.
showQuickPick
(
tasks
,
nls
.
localize
(
'
TaskService.pickBuildTask
'
,
'
Select the build task to run
'
),
true
).
then
((
task
)
=>
{
if
(
task
)
{
this
.
run
(
task
,
{
attachProblemMatcher
:
true
});
}
});
});
this
.
progressService
.
withProgress
(
options
,
()
=>
promise
);
}
...
...
@@ -1552,7 +1680,11 @@ class TaskService extends EventEmitter implements ITaskService {
this
.
run
(
primaries
[
0
]);
return
;
}
this
.
quickOpenService
.
show
(
'
test task
'
);
this
.
showQuickPick
(
tasks
,
nls
.
localize
(
'
TaskService.pickTestTask
'
,
'
Select the test task to run
'
),
true
).
then
((
task
)
=>
{
if
(
task
)
{
this
.
run
(
task
);
}
});
});
this
.
progressService
.
withProgress
(
options
,
()
=>
promise
);
}
...
...
@@ -1567,7 +1699,7 @@ class TaskService extends EventEmitter implements ITaskService {
this
.
messageService
.
show
(
Severity
.
Info
,
nls
.
localize
(
'
TaskService.noTaskRunning
'
,
'
No task is currently running.
'
));
return
;
}
this
.
showQuickPick
(
activeTasks
,
nls
.
localize
(
'
TaskService.tastToTerminate
'
,
'
Select task to terminate
'
)).
then
(
task
=>
{
this
.
showQuickPick
(
activeTasks
,
nls
.
localize
(
'
TaskService.tastToTerminate
'
,
'
Select task to terminate
'
)
,
false
,
true
).
then
(
task
=>
{
if
(
task
)
{
this
.
terminate
(
task
);
}
...
...
@@ -1593,14 +1725,6 @@ class TaskService extends EventEmitter implements ITaskService {
}
}
private
showQuickPick
(
tasks
:
Task
[],
placeHolder
:
string
):
TPromise
<
Task
>
{
interface
TaskQickPickEntry
extends
IPickOpenEntry
{
task
:
Task
;
}
let
entries
:
TaskQickPickEntry
[]
=
tasks
.
map
<
TaskQickPickEntry
>
(
task
=>
{
return
{
label
:
task
.
_label
,
task
};
});
return
this
.
quickOpenService
.
pick
(
entries
,
{
placeHolder
}).
then
(
entry
=>
entry
?
entry
.
task
:
undefined
);
}
private
runRestartTaskCommand
(
accessor
:
ServicesAccessor
,
arg
:
any
):
void
{
if
(
!
this
.
canRunCommand
())
{
return
;
...
...
@@ -1611,7 +1735,7 @@ class TaskService extends EventEmitter implements ITaskService {
this
.
messageService
.
show
(
Severity
.
Info
,
nls
.
localize
(
'
TaskService.noTaskToRestart
'
,
'
No task to restart.
'
));
return
;
}
this
.
showQuickPick
(
activeTasks
,
nls
.
localize
(
'
TaskService.tastToRestart
'
,
'
Select the task to restart
'
)).
then
(
task
=>
{
this
.
showQuickPick
(
activeTasks
,
nls
.
localize
(
'
TaskService.tastToRestart
'
,
'
Select the task to restart
'
)
,
false
,
true
).
then
(
task
=>
{
if
(
task
)
{
this
.
restart
(
task
);
}
...
...
@@ -1659,26 +1783,6 @@ quickOpenRegistry.registerQuickOpenHandler(
)
);
quickOpenRegistry
.
registerQuickOpenHandler
(
new
QuickOpenHandlerDescriptor
(
'
vs/workbench/parts/tasks/browser/buildQuickOpen
'
,
'
QuickOpenHandler
'
,
'
build task
'
,
tasksPickerContextKey
,
nls
.
localize
(
'
quickOpen.buildTask
'
,
"
Build Task
"
)
)
);
quickOpenRegistry
.
registerQuickOpenHandler
(
new
QuickOpenHandlerDescriptor
(
'
vs/workbench/parts/tasks/browser/testQuickOpen
'
,
'
QuickOpenHandler
'
,
'
test task
'
,
tasksPickerContextKey
,
nls
.
localize
(
'
quickOpen.testTask
'
,
"
Test Task
"
)
)
);
const
actionBarRegistry
=
Registry
.
as
<
IActionBarRegistry
>
(
ActionBarExtensions
.
Actionbar
);
actionBarRegistry
.
registerActionBarContributor
(
Scope
.
VIEWER
,
QuickOpenActionContributor
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录