Re-enable ProGuard, and finally identified the workaround that seems to make 4.4 work with our code without a VerifyError

git-svn-id: https://zxing.googlecode.com/svn/trunk@1025 59b500cc-1b3d-0410-9834-0bbf25fbcc57
This commit is contained in:
srowen 2009-07-22 10:36:11 +00:00
parent 9dc583f556
commit 91d8e04d86
2 changed files with 44 additions and 3 deletions

View file

@ -95,7 +95,7 @@ limitations under the License.
<property name="source-location" value="${basedir}/${source-folder}" /> <property name="source-location" value="${basedir}/${source-folder}" />
<!-- folder for the 3rd party java libraries --> <!-- folder for the 3rd party java libraries -->
<property name="external-libs-folder" value="../core" /> <!--<property name="external-libs-folder" value="../core" />-->
<!-- folder for the native libraries --> <!-- folder for the native libraries -->
<property name="native-libs-folder" value="libs" /> <property name="native-libs-folder" value="libs" />
@ -179,9 +179,37 @@ limitations under the License.
<src path="${gen-folder}" /> <src path="${gen-folder}" />
<classpath> <classpath>
<fileset dir="${external-libs-folder}" includes="*.jar"/> <fileset dir="${external-libs-folder}" includes="*.jar"/>
<!-- yeah, want to not use this mechanism above -->
<pathelement path="../core/core.jar"/>
<pathelement path="${main-out-classes}"/> <pathelement path="${main-out-classes}"/>
</classpath> </classpath>
</javac> </javac>
<!-- Optimize with ProGuard -->
<unzip src="../core/core.jar" dest="${out-classes}" overwrite="true"/>
<jar jarfile="temp.jar" basedir="${out-classes}"/>
<delete dir="${out-classes}"/>
<mkdir dir="${out-classes}"/>
<property name="libraryjars.path" refid="android.target.classpath"/>
<java jar="${WTK-home}/bin/proguard.jar" fork="true" failonerror="true">
<jvmarg value="-Dmaximum.inlined.code.length=32"/>
<arg value="-injars temp.jar"/>
<arg value="-outjars temp-optimized.jar"/>
<arg value="-libraryjars ${libraryjars.path}"/>
<arg value="-keep class com.google.zxing.client.android.*Activity"/>
<arg value="-keep class com.google.zxing.client.android.ViewfinderView { public * ; }"/>
<arg value="-keep class com.google.zxing.client.android.SearchBookContents* { public * ; }"/>
<arg value="-target 5"/>
<arg value="-optimizationpasses 7"/>
<arg value="-dontshrink"/>
<arg value="-dontobfuscate"/>
<arg value="-dontskipnonpubliclibraryclasses"/>
<arg value="-verbose"/>
<arg value="-dump proguard-dump.txt"/>
</java>
<delete file="temp.jar"/>
<unzip src="temp-optimized.jar" dest="${out-classes}" overwrite="true"/>
<delete file="temp-optimized.jar"/>
</target> </target>
<!-- Convert this project's .class files into .dex files. --> <!-- Convert this project's .class files into .dex files. -->
@ -213,6 +241,19 @@ limitations under the License.
basename="${ant.project.name}" /> basename="${ant.project.name}" />
</target> </target>
<!--
Getting an error like this?
[apply] UNEXPECTED TOP-LEVEL EXCEPTION:
[apply] com.android.dx.cf.code.SimException: local variable type
mismatch: attempt to set or access a value of type int using a local
variable of type com.google.zxing.qrcode.decoder.Version. This is
symptomatic of .class transformation tools that ignore local variable
information.
Build core/ with the 'build-no-debug' target. It's a long story.
-->
<!-- Package the application and sign it with a debug key. <!-- Package the application and sign it with a debug key.
This is the default target when building. It is used for debug. --> This is the default target when building. It is used for debug. -->
<target name="debug" depends="dex, package-resources"> <target name="debug" depends="dex, package-resources">

View file

@ -189,12 +189,12 @@ public final class Version {
private final int ecCodewordsPerBlock; private final int ecCodewordsPerBlock;
private final ECB[] ecBlocks; private final ECB[] ecBlocks;
private ECBlocks(int ecCodewordsPerBlock, ECB ecBlocks) { ECBlocks(int ecCodewordsPerBlock, ECB ecBlocks) {
this.ecCodewordsPerBlock = ecCodewordsPerBlock; this.ecCodewordsPerBlock = ecCodewordsPerBlock;
this.ecBlocks = new ECB[]{ecBlocks}; this.ecBlocks = new ECB[]{ecBlocks};
} }
private ECBlocks(int ecCodewordsPerBlock, ECB ecBlocks1, ECB ecBlocks2) { ECBlocks(int ecCodewordsPerBlock, ECB ecBlocks1, ECB ecBlocks2) {
this.ecCodewordsPerBlock = ecCodewordsPerBlock; this.ecCodewordsPerBlock = ecCodewordsPerBlock;
this.ecBlocks = new ECB[]{ecBlocks1, ecBlocks2}; this.ecBlocks = new ECB[]{ecBlocks1, ecBlocks2};
} }