我正在尝试根据风味 buildType 定义一个 buildConfigVariable。理想情况下,这就是我想要的
2 3 4 5 6 | strawberry { buildConfigField"String","WS_API_KEY", name + variant.buildType.name } ... more flavors .. } |
name 确实包含"strawberry",但我不知道是否可以访问该变体的 buildType。
放置在 Android 闭包之外,我确实可以访问 BuildType 和变体,但是我不能调用
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | println"****************************" println"variant: ${variant.name}" println"flavor: ${variant.flavorName}" println"****************************" if (variant.buildType.name == 'release') { if (variant.flavorName == 'strawberry') { buildConfigField"String","WS_API_KEY", '"strawberry_release"' } else { buildConfigField"String","WS_API_KEY", '"chocolate_release"' } } else if(variant.buildType.name == 'debug') { if (variant.flavorName == 'strawberry') { buildConfigField"String","WS_API_KEY", '"strawberry_debug"' } else { buildConfigField"String","WS_API_KEY", '"chocolate_debug"' } } **************************** variant: strawberryRelease flavor: strawberry **************************** org.gradle.api.internal.MissingMethodException: Could not find method buildConfigField() for arguments [String, WS_API_KEY,"strawberry_release"] |
我可以轻松创建 Java 工厂并根据一些
Edit2:0.14.2 之后的版本将允许这样做:
2 3 | variant.buildConfigField"int","VALUE","1" } |
所以你可以做这样的事情(以匹配原始问题):
2 3 | variant.buildConfigField"String","WS_API_KEY", variant.productFlavors.get(0).name + '_' + variant.buildType.name } |
编辑:目前不可能。缺少此 API。
错误:https://code.google.com/p/android/issues/detail?id=67416
试试这个:
2 3 | variant.mergedFlavor.buildConfigField"String","NAME", '"VALUE"' } |
警告:这可能是一个脆弱的解决方案,使用风险自负。请参阅 https://code.google.com/p/android/issues/detail?id=67416
我就是这样完成了我想要的。您需要在任务执行之前更改值,所以我需要一种方法将我的代码挂在那里。
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | gradle.taskGraph.beforeTask { Task task -> if (task.path ==~ /:$projectName:generate.*BuildConfig/) { //extracts flavor and buildType name. See http://stackoverflow.com/a/7594052/218473 for regex final values = task.name.replace("generate","").replace("BuildConfig","").split("(?<!(^|[A-Z]))(?=[A-Z])|(?<!^)(?=[A-Z][a-z])") final flavorName = values[0].toLowerCase() final buildTypeName = values[1].toLowerCase() com.android.build.gradle.api.ApplicationVariant variant; android.applicationVariants.all { currentVariant -> if (currentVariant.getVariantData().getVariantConfiguration().getBuildType().getName() == buildTypeName) { if (currentVariant.getVariantData().getVariantConfiguration().getFlavorName() == flavorName) { variant = currentVariant; } } } if(variant != null) { com.android.builder.internal.ClassFieldImpl apiKeyField if (flavorName == 'strawberry') { if (buildTypeName == 'release') { apiKeyField = new com.android.builder.internal.ClassFieldImpl("String","WS_API_KEY", '"strawberry_release"') } else { apiKeyField = new com.android.builder.internal.ClassFieldImpl("String","WS_API_KEY", '"strawberry_debug"') } } else if (flavorName == 'chocolate') { if (buildTypeName == 'release') { apiKeyField = new com.android.builder.internal.ClassFieldImpl("String","WS_API_KEY", '"chocolate_release"') } else { apiKeyField = new com.android.builder.internal.ClassFieldImpl("String","WS_API_KEY", '"chocolate_debug"') } } variant.getVariantData().getVariantConfiguration().getFlavorConfigs().get(0).addBuildConfigField(apiKeyField) } } } |
要了解其工作原理,请下载 AOSP 源代码并检查 VariantConfiguration.getBuildConfigItems()
使用 Xavier 的答案会引发 MethodMissingError。如果我使用 variant.mergedFlavor.addBuildConfigField() 没有错误,但没有添加变量。
最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路
我在我的rails应用程序中安装了来自github.com的acts_as_versioned插件,但有一段代码我不完全理解,我希望有人能帮我解决这个问题class_eval我知道block内的方法(或任何它是什么)被定义为类内的实例方法,但我在插件的任何地方都找不到定义为常量的CLASS_METHODS,而且我也不确定是什么here,并且有问题的代码从lib/acts_as_versioned.rb的第199行开始。如果有人愿意告诉我这里的内幕,我将不胜感激。谢谢-C 最佳答案 这是一个异端。http://en.wikipedia
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?
我在Ruby中遇到了一个关于Dir[]和File.join()的简单程序,blobs_dir='/path/to/dir'Dir[File.join(blobs_dir,"**","*")].eachdo|file|FileUtils.rm_rf(file)ifFile.symlink?(file)我有两个困惑:首先,File.join(@blobs_dir,"**","*")中的第二个和第三个参数是什么意思?其次,Dir[]在Ruby中有什么用?我只知道它等价于Dir.glob(),但是,我对Dir.glob()确实不是很清楚。 最佳答案
1.回顾.TransportServicepublicclassTransportServiceextendsAbstractLifecycleComponentTransportService:方法:1publicfinalTextendsTransportResponse>voidsendRequest(finalTransport.Connectionconnection,finalStringaction,finalTransportRequestrequest,finalTransportRequestOptionsoptions,TransportResponseHandlerT>
目录一.大致如下常见问题:(1)找不到程序所依赖的Qt库version`Qt_5'notfound(requiredby(2)CouldnotLoadtheQtplatformplugin"xcb"in""eventhoughitwasfound(3)打包到在不同的linux系统下,或者打包到高版本的相同系统下,运行程序时,直接提示段错误即segmentationfault,或者Illegalinstruction(coredumped)非法指令(4)ldd应用程序或者库,查看运行所依赖的库时,直接报段错误二.问题逐个分析,得出解决方法:(1)找不到程序所依赖的Qt库version`Qt_5'
我是Ruby的新手,但过去两周我一直在对Chef测试进行大量研究。该测试使用ChefSpec和Fauxhai,但它看起来不是很“像ruby”,我希望社区能给我一些编码风格的建议。有没有更好的方法来编写这样的嵌套循环?Recipe/foo/recipes/default.rbpackage"foo"doaction:installendRecipe/foo/spec/default_spec.rbrequire'chefspec'describe'foo::default'doplatforms={"debian"=>['6.0.5'],"ubuntu"=>['12.04','10.04
我在config/unicorn.rb中有一行看起来像这样:working_directory"/SomePath/Web\Development/Rails/learning"但是在生产环境中,需要不同的路径。我想尽可能多地保留源代码控制(还没有放弃任何东西)。有没有办法根据环境设置working_directory? 最佳答案 您尝试如何访问RAILS_ENV或RACK_ENV?它应该通过“ENV”就像...ENV['RAILS_ENV']……或者……ENV['RACK_ENV']当您将“-E”标志传递给unicorn时,一个或
假设一个使用类变量的简单ruby程序,classHolder@@var=99defHolder.var=(val)@@var=valenddefvar@@varendend@@var="toplevelvariable"a=Holder.newputsa.var我猜结果应该是99,但输出不是99。我想知道为什么。由于类变量的范围是类,我假设@@var="toplevelvariable"行不会影响类中的变量。 最佳答案 @@var是Holder的类变量。而顶层的@@var不是Holder的同名类变量@@var,是你在创建类Obj
一文解决关于VLAN所有的疑惑VLAN基本概念为什么需要VLAN?怎么在交换机上划分VLAN,VLAN的工作原理有了子网,已经隔离了广播,还需要VLAN干啥?只进行子网划分,不进行VLAN划分VLAN划分与子网划分附加VLAN信息的方法VLAN划分交换机的端口类型(Access和Trunk)一、访问链接二、汇聚链接汇聚链接VLAN间通信为什么要进行VLAN间通信?路由器实现VLAN间通信路由器和交换机的连接方式通信细节三层交换机实现VLAN间通信加速VLAN间通信三层交换机与路由器三层交换机路由器路由器和交换机配合构建LAN的实例使用VLAN设计局域网的特点VLAN增加网络的灵活性不使用VLA