我已经在我的项目启动以来的ProGuard我试图释放这个在谷歌播放。 尽管proguard的-android.txt有
-keepclassmembers class **.R$* {
public static <fields>;
}
这意味着它不应该混淆R.raw类,我需要,我发现这段代码运行时
import headwayEnt.Blackhole_Darksun.R;
private static final String RES_PATH = "headwayEnt.Blackhole_Darksun.R";
public static int getFileHandle(String fileName, String path) {
String fullPath = RES_PATH + '$' + path;
if (subClass == null) {
Class<headwayEnt.Blackhole_Darksun.R> c = null;
try {
c = (Class<R>)Class.forName(RES_PATH);
} catch(ClassNotFoundException e) {
e.printStackTrace();
} catch(ClassCastException e) {
e.printStackTrace();
}
subClass = c.getDeclaredClasses();
}
int fileHandle = 0;
try {
int i = 0;
System.out.println("fullPath: " + fullPath + " subclass len: " +
subClass.length);
for (; i < subClass.length; ++i) {
String name = subClass[i].getName();
if (subClass[i].getName().equals(fullPath)) {
break;
}
}
System.out.println("found i: " + i);
Field[] f = subClass[i].getDeclaredFields();
for (i = 0; i < f.length; ++i) {
if (f[i].getName().equals(fileName)) {
break;
}
}
try {
fileHandle = f[i].getInt(null);
} catch(IllegalAccessException e) {
}
} catch (RuntimeException e) {
System.out.println("Could not find filename: " + fileName +
" with path: " + path);
throw e;
}
return fileHandle;
}
与例如路径原材料,并从那里的文件名,我得到的线一个ArrayIndexOutOfBoundsException
Field[] f = subClass[i].getDeclaredFields();
因为subClass.length是0。
如果不是混淆所以我的问题是使用ProGuard这件事的工作就好了。
我试着用不同的方法来使其不混淆将R类这样玩:
-keep public class headwayEnt.HotshotEngine.Resource.ENG_Resource { *; }
-keep class headwayEnt.HotshotEngine.** { *; }
-keep class **.R$*
-keep public class headwayEnt.Blackhole_Darksun.R { *; }
-keep public class headwayEnt.Blackhole_Darksun_Full.R { *; }
-repackageclasses ''
-keep public class **.R {
public *;
}
-keep public class **.R$* {
public *;
}
而仍然无法正常工作。
不得不提的是,所有的我的代码是在库(headwayEnt.Blackhole_Darksun)和我引用headwayEnt.Blackhole_Darksun_Full该库。 基本上我从建相同的代码两个版本,一个完整的版本,一个是免费的演示。 所有这一切都发生混淆的应用程序,而不是在引用的库(只是要清除)。