Proguard keep class names?
Asked Answered
V

4

41

Hello I am writing an Android app and I have set up Proguard to obfuscate my application. I however use a classloader to dynamically load different extensions to my application. The problem is that these don't load correctly if their names are changed. How do I keep Proguard from obfuscating specific class names?

Vacuous answered 10/6, 2012 at 19:47 Comment(0)
S
46

Use the -keepnames option in your proguard.cfg

Refer to the manual https://www.guardsquare.com/manual/configuration/usage#keepoptions

-keepnames class_specification

Short for -keep,allowshrinking class_specification

Specifies classes and class members whose names are to be preserved, if they aren't removed in the shrinking phase. For example, you may want to keep all class names of classes that implement the Serializable interface, so that the processed code remains compatible with any originally serialized classes. Classes that aren't used at all can still be removed. Only applicable when obfuscating.

Silvertongued answered 10/6, 2012 at 19:55 Comment(10)
Ok is there a way to do it with a whole package?Vacuous
Yes, you use the * wildcard. ie, -keepnames com.randompackage.lol.* Will keep all classes in lolSilvertongued
I have tried that and eclipse returns error 1. Are you sure i dont have to do -keepnames class com.randompackage.lol.ClassName ? I have tried this before posting here but it didn't work :SVacuous
Try just -keep instead of -keepnamesSilvertongued
Doesn't -keep NOT obfuscate the class?Vacuous
Yes it does. -keepnames is a better option if you only want to not obfuscate class names, but keep will do the same. obfuscate = rename.Silvertongued
Does "-keepnames" just keep the name of the class ? Or does it do more? I want to just keep the name.Superannuate
@androiddeveloper -keep and -keepnames do the same as far as obfuscation is concerned (class names specified in class_specification are kept). As stated above, the difference is in the shrinking phase (with -keepnames, an unused class name is removed instead of kept). Both of them will however obfuscate class members, except if you add a specification to prevent this: adding e.g. {*;} at the end of class_specification (to keep all class members). Note that adding {} is the same as adding no curly brackets at all.Pammy
@AymericS So it prevents renaming just the class, and if it seems unused, it will remove it. What would happen if you reach the class via reflection? Or even here it depends how you do it, because the shrinker might not understand that the class is really being used?Superannuate
Link in this answer is not working @ZaidDaghestaniMesics
A
46

This keeps classnames intact:

-keepnames class com.somepackage.* 
Araliaceous answered 25/9, 2014 at 18:25 Comment(0)
B
18

Handy tip for everyone who does not want ProGuard to change any class name:

# please KEEP ALL THE NAMES
-keepnames class ** { *; }

This way you will get readable stack traces while still throwing out things you don't need. :-)

Blent answered 2/10, 2014 at 21:20 Comment(3)
-dontobfuscate is the right way to disable obfuscation.Suckle
Wrong way. It's better to turn off obfuscation with this configuration: "-dontobfuscate /n -optimizations !code/allocation/variable"Alicia
Better yet, upload your symbols file and allow the capture properly.Windgall
I
5

If anyone is interested how to specify multiple class names to keep, then these classes can be separated by a comma. Example:

-keepnames class com.foo.**,com.bar.** { *; }

It is also possible to use negation with this because usually only own classes would be obfuscated and 3rd party libraries can be kept:

-keepnames class !com.foo.**,!com.bar.** { *; }

See the Proguard Documentation for this.

Iow answered 30/4, 2019 at 12:25 Comment(3)
I was. :) Now that I know to google for "comma-separated class names" I found this. :) Would you happen to know whether a space after the comma is allowed?Lampion
Not sure, try it, but I guess not, It might be considered as a new option.Iow
Space, and even newline, is allowed.Lampion

© 2022 - 2024 — McMap. All rights reserved.