Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
dacd7728
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,发现更多精彩内容 >>
提交
dacd7728
编写于
9月 24, 2018
作者:
D
Dirk Baeumer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixes #40905: Operating system specific args don't override args defined in the task
上级
7a629db3
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
53 addition
and
3 deletion
+53
-3
src/vs/workbench/parts/tasks/node/taskConfiguration.ts
src/vs/workbench/parts/tasks/node/taskConfiguration.ts
+3
-3
src/vs/workbench/parts/tasks/test/electron-browser/configuration.test.ts
...h/parts/tasks/test/electron-browser/configuration.test.ts
+50
-0
未找到文件。
src/vs/workbench/parts/tasks/node/taskConfiguration.ts
浏览文件 @
dacd7728
...
...
@@ -858,7 +858,7 @@ namespace CommandConfiguration {
osConfig
=
fromBase
(
config
.
linux
,
context
);
}
if
(
osConfig
)
{
result
=
assignProperties
(
result
,
osConfig
);
result
=
assignProperties
(
result
,
osConfig
,
context
.
schemaVersion
===
Tasks
.
JsonSchemaVersion
.
V2_0_0
);
}
return
isEmpty
(
result
)
?
undefined
:
result
;
}
...
...
@@ -929,7 +929,7 @@ namespace CommandConfiguration {
return
_isEmpty
(
value
,
properties
);
}
export
function
assignProperties
(
target
:
Tasks
.
CommandConfiguration
,
source
:
Tasks
.
CommandConfiguration
):
Tasks
.
CommandConfiguration
{
export
function
assignProperties
(
target
:
Tasks
.
CommandConfiguration
,
source
:
Tasks
.
CommandConfiguration
,
overwriteArgs
:
boolean
):
Tasks
.
CommandConfiguration
{
if
(
isEmpty
(
source
))
{
return
target
;
}
...
...
@@ -941,7 +941,7 @@ namespace CommandConfiguration {
assignProperty
(
target
,
source
,
'
taskSelector
'
);
assignProperty
(
target
,
source
,
'
suppressTaskName
'
);
if
(
source
.
args
!==
void
0
)
{
if
(
target
.
args
===
void
0
)
{
if
(
target
.
args
===
void
0
||
overwriteArgs
)
{
target
.
args
=
source
.
args
;
}
else
{
target
.
args
=
target
.
args
.
concat
(
source
.
args
);
...
...
src/vs/workbench/parts/tasks/test/electron-browser/configuration.test.ts
浏览文件 @
dacd7728
...
...
@@ -1585,6 +1585,56 @@ suite('Tasks version 2.0.0', () => {
presentation
().
echo
(
true
);
testConfiguration
(
external
,
builder
);
});
test
(
'
Arg overwrite
'
,
()
=>
{
let
external
:
ExternalTaskRunnerConfiguration
=
{
version
:
'
2.0.0
'
,
tasks
:
[
{
label
:
'
echo
'
,
type
:
'
shell
'
,
command
:
'
echo
'
,
args
:
[
'
global
'
],
windows
:
{
args
:
[
'
windows
'
]
},
linux
:
{
args
:
[
'
linux
'
]
},
osx
:
{
args
:
[
'
osx
'
]
}
}
]
};
let
builder
=
new
ConfiguationBuilder
();
if
(
Platform
.
isWindows
)
{
builder
.
task
(
'
echo
'
,
'
echo
'
).
command
().
suppressTaskName
(
true
).
args
([
'
windows
'
]).
runtime
(
Tasks
.
RuntimeType
.
Shell
).
presentation
().
echo
(
true
);
testConfiguration
(
external
,
builder
);
}
else
if
(
Platform
.
isLinux
)
{
builder
.
task
(
'
echo
'
,
'
echo
'
).
command
().
suppressTaskName
(
true
).
args
([
'
linux
'
]).
runtime
(
Tasks
.
RuntimeType
.
Shell
).
presentation
().
echo
(
true
);
testConfiguration
(
external
,
builder
);
}
else
if
(
Platform
.
isMacintosh
)
{
builder
.
task
(
'
echo
'
,
'
echo
'
).
command
().
suppressTaskName
(
true
).
args
([
'
osx
'
]).
runtime
(
Tasks
.
RuntimeType
.
Shell
).
presentation
().
echo
(
true
);
testConfiguration
(
external
,
builder
);
}
});
});
suite
(
'
Bugs / regression tests
'
,
()
=>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录