Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Proguard breaks reflective CSS selectors #61

Open
GoogleCodeExporter opened this issue Jun 11, 2015 · 1 comment
Open

Proguard breaks reflective CSS selectors #61

GoogleCodeExporter opened this issue Jun 11, 2015 · 1 comment

Comments

@GoogleCodeExporter
Copy link

What steps will reproduce the problem?
1. Parse and render the attached SVG

What is the expected output? What do you see instead?
Expected is a paper with lines. (open in Chrome for test)
Actual is a paper without lines.

What version of the product are you using? On what operating system?
1.2.1, Android 4.4

Please provide any additional information below.
After some investigation I found the culprit. I'm using CSS in those SVG files 
and the element selectors (line { ... }) use reflection to match tag names:
    if (!sel.tag.equals(obj.getClass().getSimpleName().toLowerCase(Locale.US)))

This is happy until you shrink and obfuscate your code with ProGuard which 
renames the classes.

It would be nice if as an alternative to reflection you used hardcoded Strings 
which are more stable and it's probably faster as well:
class SvgElementBase {
   protected String tag;
   ...
}
class Line extends SvgElementBase {
   {tag = "line";} // this has the benefit of not needing to repeat the class name
   // or
   Line() { tag = "line";}
   ...
}

or any other method think fits.

Original issue reported on code.google.com by papp.robert.s on 7 May 2015 at 11:40

Attachments:

@GoogleCodeExporter
Copy link
Author

I found two workarounds for the issue in case anyone finds this:

1. Keep affected classes AND inner class attributes
    # See com.caverock.androidsvg.CSSParser.selectorMatch
    -keepnames class * extends com.caverock.androidsvg.SVG$SvgElementBase
    # Needed for Java to be able to decipher "SVG$Line" into "Line" when calling getSimpleName()
    -keepattributes InnerClasses

2. Use a mapping file to explicitly rename classes
This option doesn't require InnerClasses, but not futureproof at the same time.
    # See com.caverock.androidsvg.CSSParser.selectorMatch
    # Rename classes extending SvgElementBase explicitly to be directly in a package instead of an inner class
    -applymapping mapping.txt

Original comment by papp.robert.s on 7 May 2015 at 11:46

Attachments:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant