- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想运行任务 wsUpload
,在 assembleMinAPI16ProdRelease
完成 Artifact 组装后运行 shell 脚本将 Artifact 上传到公司服务器。
从此开始:
afterEvaluate {
task wsUpload(type: Exec, dependsOn: assembleMinAPI16ProdRelease) {
def localPropertiesFile = rootProject.file("local.properties");
def localProperties = new Properties()
localProperties.load(new FileInputStream(localPropertiesFile))
def WORK_EMAIL = localProperties['WORK_EMAIL']
commandLine '../scripts/ws_upload.sh'
args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload start ")
commandLine '../scripts/ws_upload.sh'
// args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload end")
}
assembleMinAPI16ProdRelease.doLast {
println("-------------------------------------")
println("---------------DO LAST---------------")
println("-------------------------------------")
crashlyticsUploadDistributionMinAPI16ProdRelease.execute()
}
}
但它在 assembleRelease 完成之前运行。然后我尝试了这个 answer
task wsUpload(type: Exec) {
def localPropertiesFile = rootProject.file("local.properties");
def localProperties = new Properties()
localProperties.load(new FileInputStream(localPropertiesFile))
def WORK_EMAIL = localProperties['WORK_EMAIL']
commandLine '../scripts/ws_upload.sh'
args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload start ")
doLast {
exec {
commandLine '../scripts/ws_upload.sh'
args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload end")
}
}
}
afterEvaluate {
assembleMinAPI16ProdRelease.doLast {
println("-------------------------------------")
println("---------------DO LAST---------------")
println("-------------------------------------")
crashlyticsUploadDistributionMinAPI16ProdRelease.execute()
}
assembleMinAPI16ProdRelease.doLast {
wsUpload.execute()
}
}
给我留下了 > java.lang.NullPointerException(没有错误信息)
然后我尝试将整个 swUpload 设置为 doLast
task wsUpload(type: Exec) << {
def localPropertiesFile = rootProject.file("local.properties");
def localProperties = new Properties()
localProperties.load(new FileInputStream(localPropertiesFile))
def WORK_EMAIL = localProperties['WORK_EMAIL']
commandLine '../scripts/ws_upload.sh'
args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload start ")
commandLine '../scripts/ws_upload.sh'
args = [rootProject.ext.VERSION_CODE, WORK_EMAIL]
println("wsUpload end")
}
出现错误:
Execution failed for task ':app:wsUpload'.
> execCommand == null!
最佳答案
首先,您需要以正确的方式定义一个任务(阅读关于 配置 与 执行 在 gradle 中),这将是:
task wsUpload(type: Exec) {
def localPropertiesFile = rootProject.file("local.properties");
def localProperties = new Properties()
localProperties.load(new FileInputStream(localPropertiesFile))
def WORK_EMAIL = localProperties['WORK_EMAIL']
commandLine '../scripts/ws_upload.sh'
args [rootProject.ext.VERSION_CODE, WORK_EMAIL]
}
现在您需要定义任务之间的执行顺序依赖关系 - 切记永远不要直接在任务实例上调用 execute()
!
我想 assembleMinAPI16ProdRelease
和 crashlyticsUploadDistributionMinAPI16ProdRelease
都是动态任务(在项目评估后创建)所以在 afterEvaluate
中定义依赖关系是明智的> 阻止:
afterEvaluate {
crashlyticsUploadDistributionMinAPI16ProdRelease.dependsOn assembleMinAPI16ProdRelease
crashlyticsUploadDistributionMinAPI16ProdRelease.mustRunAfter assembleMinAPI16ProdRelease
wsUpload.dependsOn crashlyticsUploadDistributionMinAPI16ProdRelease
wsUpload.mustRunAfter crashlyticsUploadDistributionMinAPI16ProdRelease
}
为什么 mustRunAfter
和 dependsOn
都有?不仅要定义依赖关系,还要定义正确的执行顺序。现在您应该能够运行 gradle wsUpload
并且一切正常。
如果您想运行 assembleMinAPI16ProdRelease
并上传 Artifact ,则应使用 finalizedBy
:
afterEvaluate {
assembleMinAPI16ProdRelease.finalizedBy crashlyticsUploadDistributionMinAPI16ProdRelease
crashlyticsUploadDistributionMinAPI16ProdRelease.finalizedBy wsUpload
}
请注意,由于我不是 Android 开发人员,我无法正确测试它 - 所以如果它不起作用,请在投反对票之前告诉我 ;)
关于android - Artifact 组装后如何运行shell脚本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46283371/
在组装方面,我绝对是个初学者。我尝试找出以下内容的输出应该是什么: Jan dd 255,256 Feb dw 16, 17, 18, 19 Mar db 8, 9, 10, 11 Sub edi,
我正在用 AT&T 语法编写。这个循环应该检查大小写是否在 61-7A ASCII 范围内(这意味着是这个小字母) - 如果不是,则将其转换为空格“”。 change: movb (%esi)
mov eax, ptr_to_num1 ; little endian mov ebx, ptr_to_num2 ; little endian xor ecx, ecx xor edx, edx
我正在制作用于组装的 atoi 函数。 无论我尝试什么都行不通,我也不知道为什么。 有谁知道是什么问题? org 100h mov si, stri ;parameter call atoi
我正在使用 tasm 编写汇编程序。我的任务是编写一个程序,该程序将使用冒泡排序按字母顺序对输入的字符串进行排序。前任。如果你输入“hello”,它应该写成“ehello”。我已经写了请求输入字符串并
假设我的 GPU 包含一个名为 ADT7473 的芯片。 . 我有兴趣从该芯片接收有关我的卡温度的信息。 我的问题是,如何访问这个芯片?是使用 IN/OUT 指令完成的吗? 编辑: 我可能会添加芯片文
我需要在DOS下通过Assembly(intel)+C(c99)绘制QRCode。但看来我的内存太少了。我尝试将图像存储为位数组: image db 11111110b, ... 但无论如何我没有结果
这里有一个简短的问题。我有一个程序集被一些开发人员重复使用,其中包含各种功能,但在技术上分为代表功能逻辑 block 的各种命名空间。 现在,它提供的公共(public) namespace 越少越好
小端: mov eax,4 push dword 0x44434241 mov ebx,1 mov ecx,esp mov edx,4 int 0x80 add esp,4 我不明白为什么它打印 A
是否可以使用元编程技巧来允许在 assembly block 上使用 SFINAE?例如检测处理器上是否有类似“CPUID”的指令:(这不是有效的代码,但说明了我想要实现的目标) // This sh
我有以下形式的项目 - pom.xml - projectA - pom.xml - src/main/ - java - startupScript - projectB
在《微处理器的音乐应用》一书中,作者给出了以下算法,将两个 8 位有符号整数与 16 位有符号结果进行 4 象限相乘: 对原始操作数进行无符号乘法。然后为了更正结果,如果被乘数符号为负,则无符号单精度
我们有一个项目,我们正在 build 大量 Scalatra microservices通过使用 sbt-assembly 打包它们插件,然后使用 sbt-docker 创建 Docker 镜像插入。
所有使用布局的 assemble 用户都知道“{{> body }}”标记了任何使用布局的页面的内容插入点。但是是否可以定义多个插入点,而不是将所有内容都扔到 {{> body }} 所在的位置? 例
我刚开始学习汇编,我没有找到任何有用的内容。 我正在创建一个简单的程序来读取用户输入,基本上: section .bss opA: resw 1 opB: resw 1 section
我目前正在尝试在 bochs 中编译并运行一个简单的引导加载程序。目前,这是我的 bootloader.asm 文件: [BITS 16] [ORG 0x7C00] ;Where the code g
我正在组装一个“simon”游戏,我需要在按钮打开时发出蜂鸣声,蜂鸣声也应该彼此不同。谢谢 最佳答案 您可以使用speaker让您的设计保持简单。 扬声器可让您播放不同频率的方波,it can act
我无法通过任何文档找到问题的答案。 可靠集合通过云的多个节点共享,并且具有名称和持久性。 它们可以通过不同的应用程序共享还是特定于应用程序? 例如,两个不同的 MVC 应用程序对同一帐户托管的可靠字典
嗨,我有一个 SBT 构建文件,用于处理我们组织内的集成测试,测试本身可以工作,我可以单独运行单元和它测试。但是,当使用 sbt-assemble 打包应用程序时,我无法按顺序运行两个测试(unit+
我正在运行一些汇编代码,但我无法弄清楚一行代码的作用。代码是: leaq 0(,%rax,4), %rdx 我知道lea基本上是一种mov指令,但它只移动地址。因此,我们将某些内容的地址移动到%
我是一名优秀的程序员,十分优秀!