ProGuard“保持”论证中的泛化

时间:2012-07-12 10:59:08

标签: java android scala proguard sbt-android-plugin

ProGuard定义了它的“保持”语法here

[@annotationtype] [[!]public|final|abstract|@ ...] [!]interface|class|enum classname
    [extends|implements [@annotationtype] classname]
[{
    [@annotationtype] [[!]public|private|protected|static|volatile|transient ...] <fields> |
                                                                      (fieldtype fieldname);
    [@annotationtype] [[!]public|private|protected|static|synchronized|native|abstract|strictfp ...] <methods> |
                                                                                           <init>(argumenttype,...) |
                                                                                           classname(argumenttype,...) |
                                                                                           (returntype methodname(argumenttype,...));
    [@annotationtype] [[!]public|private|protected|static ... ] *;
    ...
}]

是否可以继续使用广义修饰符和类型?
例如-keep * * my.package.MySomething { *; } 第一个*将表示此部分中的任何内容:[!]public|final|abstract|@ ...]
第二个*表示此部分的任何内容:[!]interface|class|enum

更深入一点,我正在尝试动态生成ProGuard参数,我不知道my.package.MySomethingabstract class还是public enum还是其他任何内容。

有没有办法,ProGuard中的一个选项可以帮助我实现这个目标?

1 个答案:

答案 0 :(得分:2)

配置

-keep class my.package.MySomething { *; }

做你想要的。如果您想进一步限制匹配(例如public;或接口而不是类),您只需添加访问修饰符。