sometsome 3.10.48 → 3.10.50.35
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- metadata +13 -963
- data/lib/hola.rb +0 -5
- data/lib/proguard4.7/README +0 -33
- data/lib/proguard4.7/bin/proguard.bat +0 -14
- data/lib/proguard4.7/bin/proguard.sh +0 -11
- data/lib/proguard4.7/bin/proguardgui.bat +0 -14
- data/lib/proguard4.7/bin/proguardgui.sh +0 -15
- data/lib/proguard4.7/bin/retrace.bat +0 -14
- data/lib/proguard4.7/bin/retrace.sh +0 -12
- data/lib/proguard4.7/build/build.sh +0 -94
- data/lib/proguard4.7/build/build.xml +0 -171
- data/lib/proguard4.7/build/makefile +0 -94
- data/lib/proguard4.7/docs/FAQ.html +0 -253
- data/lib/proguard4.7/docs/GPL.html +0 -406
- data/lib/proguard4.7/docs/GPL_exception.html +0 -56
- data/lib/proguard4.7/docs/acknowledgements.html +0 -76
- data/lib/proguard4.7/docs/alternatives.html +0 -699
- data/lib/proguard4.7/docs/checkmark.gif +0 -0
- data/lib/proguard4.7/docs/downloads.html +0 -623
- data/lib/proguard4.7/docs/drop1.gif +0 -0
- data/lib/proguard4.7/docs/drop2.gif +0 -0
- data/lib/proguard4.7/docs/drop3.gif +0 -0
- data/lib/proguard4.7/docs/favicon.ico +0 -0
- data/lib/proguard4.7/docs/feedback.html +0 -120
- data/lib/proguard4.7/docs/index.html +0 -92
- data/lib/proguard4.7/docs/license.html +0 -60
- data/lib/proguard4.7/docs/main.html +0 -102
- data/lib/proguard4.7/docs/manual/ant.html +0 -634
- data/lib/proguard4.7/docs/manual/attention.gif +0 -0
- data/lib/proguard4.7/docs/manual/examples.html +0 -1504
- data/lib/proguard4.7/docs/manual/gui.html +0 -479
- data/lib/proguard4.7/docs/manual/index.html +0 -51
- data/lib/proguard4.7/docs/manual/introduction.html +0 -173
- data/lib/proguard4.7/docs/manual/limitations.html +0 -69
- data/lib/proguard4.7/docs/manual/optimizations.html +0 -172
- data/lib/proguard4.7/docs/manual/refcard.html +0 -486
- data/lib/proguard4.7/docs/manual/retrace/examples.html +0 -345
- data/lib/proguard4.7/docs/manual/retrace/index.html +0 -37
- data/lib/proguard4.7/docs/manual/retrace/introduction.html +0 -79
- data/lib/proguard4.7/docs/manual/retrace/usage.html +0 -127
- data/lib/proguard4.7/docs/manual/sections.html +0 -60
- data/lib/proguard4.7/docs/manual/style.css +0 -105
- data/lib/proguard4.7/docs/manual/troubleshooting.html +0 -729
- data/lib/proguard4.7/docs/manual/usage.html +0 -1243
- data/lib/proguard4.7/docs/manual/wtk.html +0 -70
- data/lib/proguard4.7/docs/quality.html +0 -56
- data/lib/proguard4.7/docs/results.html +0 -170
- data/lib/proguard4.7/docs/saikoalogo.png +0 -0
- data/lib/proguard4.7/docs/screenshot_console.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_console_small.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui1.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui2.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui3.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui4.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui5.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui6.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui7.gif +0 -0
- data/lib/proguard4.7/docs/screenshot_gui8.gif +0 -0
- data/lib/proguard4.7/docs/screenshots.html +0 -67
- data/lib/proguard4.7/docs/screenshots_gui_small.gif +0 -0
- data/lib/proguard4.7/docs/sections.html +0 -64
- data/lib/proguard4.7/docs/sflogo.png +0 -0
- data/lib/proguard4.7/docs/steel.gif +0 -0
- data/lib/proguard4.7/docs/style.css +0 -223
- data/lib/proguard4.7/docs/testimonials.html +0 -133
- data/lib/proguard4.7/docs/title.gif +0 -0
- data/lib/proguard4.7/docs/title.html +0 -17
- data/lib/proguard4.7/examples/android.pro +0 -149
- data/lib/proguard4.7/examples/annotations/examples.pro +0 -60
- data/lib/proguard4.7/examples/annotations/examples/Applet.java +0 -22
- data/lib/proguard4.7/examples/annotations/examples/Application.java +0 -20
- data/lib/proguard4.7/examples/annotations/examples/Bean.java +0 -56
- data/lib/proguard4.7/examples/annotations/examples/NativeCallBack.java +0 -44
- data/lib/proguard4.7/examples/annotations/lib/annotations.jar +0 -0
- data/lib/proguard4.7/examples/annotations/lib/annotations.pro +0 -118
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/Keep.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepApplication.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepClassMemberNames.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepClassMembers.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepGettersSetters.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepImplementations.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepName.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicClassMemberNames.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicClassMembers.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicGettersSetters.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicImplementations.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicProtectedClassMemberNames.java +0 -18
- data/lib/proguard4.7/examples/annotations/src/proguard/annotation/KeepPublicProtectedClassMembers.java +0 -19
- data/lib/proguard4.7/examples/ant/android-8.xml +0 -177
- data/lib/proguard4.7/examples/ant/applets.xml +0 -88
- data/lib/proguard4.7/examples/ant/applications1.xml +0 -15
- data/lib/proguard4.7/examples/ant/applications2.xml +0 -74
- data/lib/proguard4.7/examples/ant/applications3.xml +0 -98
- data/lib/proguard4.7/examples/ant/library.xml +0 -102
- data/lib/proguard4.7/examples/ant/midlets.xml +0 -52
- data/lib/proguard4.7/examples/ant/proguard.xml +0 -78
- data/lib/proguard4.7/examples/ant/servlets.xml +0 -88
- data/lib/proguard4.7/examples/applets.pro +0 -69
- data/lib/proguard4.7/examples/applications.pro +0 -75
- data/lib/proguard4.7/examples/dictionaries/compact.txt +0 -18
- data/lib/proguard4.7/examples/dictionaries/keywords.txt +0 -58
- data/lib/proguard4.7/examples/dictionaries/shakespeare.txt +0 -23
- data/lib/proguard4.7/examples/dictionaries/windows.txt +0 -209
- data/lib/proguard4.7/examples/library.pro +0 -79
- data/lib/proguard4.7/examples/midlets.pro +0 -67
- data/lib/proguard4.7/examples/proguard.pro +0 -57
- data/lib/proguard4.7/examples/proguardall.pro +0 -62
- data/lib/proguard4.7/examples/proguardgui.pro +0 -50
- data/lib/proguard4.7/examples/retrace.pro +0 -43
- data/lib/proguard4.7/examples/scala.pro +0 -132
- data/lib/proguard4.7/examples/servlets.pro +0 -70
- data/lib/proguard4.7/lib/proguard.jar +0 -0
- data/lib/proguard4.7/lib/proguardgui.jar +0 -0
- data/lib/proguard4.7/lib/retrace.jar +0 -0
- data/lib/proguard4.7/src/proguard/ArgumentWordReader.java +0 -111
- data/lib/proguard4.7/src/proguard/ClassPath.java +0 -94
- data/lib/proguard4.7/src/proguard/ClassPathEntry.java +0 -282
- data/lib/proguard4.7/src/proguard/ClassSpecification.java +0 -259
- data/lib/proguard4.7/src/proguard/ClassSpecificationVisitorFactory.java +0 -503
- data/lib/proguard4.7/src/proguard/Configuration.java +0 -328
- data/lib/proguard4.7/src/proguard/ConfigurationConstants.java +0 -123
- data/lib/proguard4.7/src/proguard/ConfigurationParser.java +0 -1285
- data/lib/proguard4.7/src/proguard/ConfigurationWriter.java +0 -651
- data/lib/proguard4.7/src/proguard/DataEntryReaderFactory.java +0 -141
- data/lib/proguard4.7/src/proguard/DataEntryWriterFactory.java +0 -150
- data/lib/proguard4.7/src/proguard/DescriptorKeepChecker.java +0 -169
- data/lib/proguard4.7/src/proguard/DuplicateClassPrinter.java +0 -63
- data/lib/proguard4.7/src/proguard/FileWordReader.java +0 -55
- data/lib/proguard4.7/src/proguard/FullyQualifiedClassNameChecker.java +0 -191
- data/lib/proguard4.7/src/proguard/GPL.java +0 -197
- data/lib/proguard4.7/src/proguard/Initializer.java +0 -424
- data/lib/proguard4.7/src/proguard/InputReader.java +0 -233
- data/lib/proguard4.7/src/proguard/KeepClassMemberChecker.java +0 -87
- data/lib/proguard4.7/src/proguard/KeepClassSpecification.java +0 -137
- data/lib/proguard4.7/src/proguard/LineWordReader.java +0 -74
- data/lib/proguard4.7/src/proguard/MANIFEST.MF +0 -2
- data/lib/proguard4.7/src/proguard/MemberSpecification.java +0 -114
- data/lib/proguard4.7/src/proguard/OutputWriter.java +0 -296
- data/lib/proguard4.7/src/proguard/ParseException.java +0 -51
- data/lib/proguard4.7/src/proguard/ProGuard.java +0 -512
- data/lib/proguard4.7/src/proguard/SeedPrinter.java +0 -97
- data/lib/proguard4.7/src/proguard/SubclassedClassFilter.java +0 -62
- data/lib/proguard4.7/src/proguard/Targeter.java +0 -88
- data/lib/proguard4.7/src/proguard/UpToDateChecker.java +0 -232
- data/lib/proguard4.7/src/proguard/WordReader.java +0 -387
- data/lib/proguard4.7/src/proguard/ant/ClassPathElement.java +0 -191
- data/lib/proguard4.7/src/proguard/ant/ClassSpecificationElement.java +0 -258
- data/lib/proguard4.7/src/proguard/ant/ConfigurationElement.java +0 -53
- data/lib/proguard4.7/src/proguard/ant/ConfigurationTask.java +0 -441
- data/lib/proguard4.7/src/proguard/ant/FilterElement.java +0 -85
- data/lib/proguard4.7/src/proguard/ant/KeepSpecificationElement.java +0 -87
- data/lib/proguard4.7/src/proguard/ant/MemberSpecificationElement.java +0 -218
- data/lib/proguard4.7/src/proguard/ant/ProGuardTask.java +0 -352
- data/lib/proguard4.7/src/proguard/ant/package.html +0 -3
- data/lib/proguard4.7/src/proguard/ant/task.properties +0 -2
- data/lib/proguard4.7/src/proguard/classfile/ClassConstants.java +0 -316
- data/lib/proguard4.7/src/proguard/classfile/ClassPool.java +0 -152
- data/lib/proguard4.7/src/proguard/classfile/Clazz.java +0 -261
- data/lib/proguard4.7/src/proguard/classfile/Field.java +0 -32
- data/lib/proguard4.7/src/proguard/classfile/LibraryClass.java +0 -548
- data/lib/proguard4.7/src/proguard/classfile/LibraryField.java +0 -77
- data/lib/proguard4.7/src/proguard/classfile/LibraryMember.java +0 -108
- data/lib/proguard4.7/src/proguard/classfile/LibraryMethod.java +0 -83
- data/lib/proguard4.7/src/proguard/classfile/Member.java +0 -57
- data/lib/proguard4.7/src/proguard/classfile/Method.java +0 -32
- data/lib/proguard4.7/src/proguard/classfile/ProgramClass.java +0 -572
- data/lib/proguard4.7/src/proguard/classfile/ProgramField.java +0 -93
- data/lib/proguard4.7/src/proguard/classfile/ProgramMember.java +0 -168
- data/lib/proguard4.7/src/proguard/classfile/ProgramMethod.java +0 -99
- data/lib/proguard4.7/src/proguard/classfile/VisitorAccepter.java +0 -47
- data/lib/proguard4.7/src/proguard/classfile/attribute/Attribute.java +0 -142
- data/lib/proguard4.7/src/proguard/classfile/attribute/BootstrapMethodInfo.java +0 -89
- data/lib/proguard4.7/src/proguard/classfile/attribute/BootstrapMethodsAttribute.java +0 -95
- data/lib/proguard4.7/src/proguard/classfile/attribute/CodeAttribute.java +0 -202
- data/lib/proguard4.7/src/proguard/classfile/attribute/ConstantValueAttribute.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/DeprecatedAttribute.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/EnclosingMethodAttribute.java +0 -132
- data/lib/proguard4.7/src/proguard/classfile/attribute/ExceptionInfo.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/attribute/ExceptionsAttribute.java +0 -80
- data/lib/proguard4.7/src/proguard/classfile/attribute/InnerClassesAttribute.java +0 -80
- data/lib/proguard4.7/src/proguard/classfile/attribute/InnerClassesInfo.java +0 -119
- data/lib/proguard4.7/src/proguard/classfile/attribute/LineNumberInfo.java +0 -50
- data/lib/proguard4.7/src/proguard/classfile/attribute/LineNumberTableAttribute.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/attribute/LocalVariableInfo.java +0 -99
- data/lib/proguard4.7/src/proguard/classfile/attribute/LocalVariableTableAttribute.java +0 -79
- data/lib/proguard4.7/src/proguard/classfile/attribute/LocalVariableTypeInfo.java +0 -107
- data/lib/proguard4.7/src/proguard/classfile/attribute/LocalVariableTypeTableAttribute.java +0 -79
- data/lib/proguard4.7/src/proguard/classfile/attribute/SignatureAttribute.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/attribute/SourceDirAttribute.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/SourceFileAttribute.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/SyntheticAttribute.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/UnknownAttribute.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/Annotation.java +0 -143
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/AnnotationDefaultAttribute.java +0 -73
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/AnnotationElementValue.java +0 -76
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/AnnotationsAttribute.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/ArrayElementValue.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/ClassElementValue.java +0 -95
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/ConstantElementValue.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/ElementValue.java +0 -126
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/EnumConstantElementValue.java +0 -99
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/ParameterAnnotationsAttribute.java +0 -83
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/RuntimeInvisibleAnnotationsAttribute.java +0 -70
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/RuntimeInvisibleParameterAnnotationsAttribute.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/RuntimeVisibleAnnotationsAttribute.java +0 -70
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/RuntimeVisibleParameterAnnotationsAttribute.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/package.html +0 -4
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/AllAnnotationVisitor.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/AnnotatedClassVisitor.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/AnnotationToMemberVisitor.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/AnnotationTypeFilter.java +0 -102
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/AnnotationVisitor.java +0 -40
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/ElementValueVisitor.java +0 -51
- data/lib/proguard4.7/src/proguard/classfile/attribute/annotation/visitor/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/attribute/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/DoubleType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/FloatType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/FullFrame.java +0 -202
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/IntegerType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/LessZeroFrame.java +0 -103
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/LongType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/MoreZeroFrame.java +0 -161
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/NullType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/ObjectType.java +0 -107
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/SameOneFrame.java +0 -115
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/SameZeroFrame.java +0 -74
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/StackMapAttribute.java +0 -91
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/StackMapFrame.java +0 -117
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/StackMapTableAttribute.java +0 -93
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/TopType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/UninitializedThisType.java +0 -66
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/UninitializedType.java +0 -106
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/VerificationType.java +0 -103
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/VerificationTypeFactory.java +0 -112
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/visitor/StackMapFrameVisitor.java +0 -40
- data/lib/proguard4.7/src/proguard/classfile/attribute/preverification/visitor/VerificationTypeVisitor.java +0 -65
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AllAttributeVisitor.java +0 -117
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AllBootstrapMethodInfoVisitor.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AllExceptionInfoVisitor.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AllInnerClassesInfoVisitor.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AttributeNameFilter.java +0 -368
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/AttributeVisitor.java +0 -90
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/BootstrapMethodInfoVisitor.java +0 -40
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/ExceptionInfoVisitor.java +0 -37
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/InnerClassesInfoVisitor.java +0 -38
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/LineNumberInfoVisitor.java +0 -38
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/LocalVariableInfoVisitor.java +0 -38
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/LocalVariableTypeInfoVisitor.java +0 -38
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/MultiAttributeVisitor.java +0 -365
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/NonEmptyAttributeFilter.java +0 -293
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/RequiredAttributeFilter.java +0 -360
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/StackSizeComputer.java +0 -378
- data/lib/proguard4.7/src/proguard/classfile/attribute/visitor/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/constant/ClassConstant.java +0 -105
- data/lib/proguard4.7/src/proguard/classfile/constant/Constant.java +0 -68
- data/lib/proguard4.7/src/proguard/classfile/constant/DoubleConstant.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/constant/FieldrefConstant.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/constant/FloatConstant.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/constant/IntegerConstant.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/constant/InterfaceMethodrefConstant.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/constant/InvokeDynamicConstant.java +0 -148
- data/lib/proguard4.7/src/proguard/classfile/constant/LongConstant.java +0 -82
- data/lib/proguard4.7/src/proguard/classfile/constant/MethodHandleConstant.java +0 -124
- data/lib/proguard4.7/src/proguard/classfile/constant/MethodTypeConstant.java +0 -93
- data/lib/proguard4.7/src/proguard/classfile/constant/MethodrefConstant.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/constant/NameAndTypeConstant.java +0 -119
- data/lib/proguard4.7/src/proguard/classfile/constant/RefConstant.java +0 -130
- data/lib/proguard4.7/src/proguard/classfile/constant/StringConstant.java +0 -135
- data/lib/proguard4.7/src/proguard/classfile/constant/Utf8Constant.java +0 -285
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/AllConstantVisitor.java +0 -53
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/BootstrapMethodHandleTraveler.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/ConstantTagFilter.java +0 -86
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/ConstantVisitor.java +0 -49
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/ExceptClassConstantFilter.java +0 -69
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/MethodrefTraveler.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/constant/visitor/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/editor/AccessFixer.java +0 -180
- data/lib/proguard4.7/src/proguard/classfile/editor/AnnotationAdder.java +0 -153
- data/lib/proguard4.7/src/proguard/classfile/editor/AnnotationsAttributeEditor.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/editor/AttributeAdder.java +0 -457
- data/lib/proguard4.7/src/proguard/classfile/editor/AttributeSorter.java +0 -89
- data/lib/proguard4.7/src/proguard/classfile/editor/AttributesEditor.java +0 -269
- data/lib/proguard4.7/src/proguard/classfile/editor/BridgeMethodFixer.java +0 -117
- data/lib/proguard4.7/src/proguard/classfile/editor/ClassEditor.java +0 -255
- data/lib/proguard4.7/src/proguard/classfile/editor/ClassElementSorter.java +0 -52
- data/lib/proguard4.7/src/proguard/classfile/editor/ClassMemberSorter.java +0 -69
- data/lib/proguard4.7/src/proguard/classfile/editor/ClassReferenceFixer.java +0 -546
- data/lib/proguard4.7/src/proguard/classfile/editor/CodeAttributeComposer.java +0 -843
- data/lib/proguard4.7/src/proguard/classfile/editor/CodeAttributeEditor.java +0 -1104
- data/lib/proguard4.7/src/proguard/classfile/editor/CodeAttributeEditorResetter.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/editor/ComparableConstant.java +0 -249
- data/lib/proguard4.7/src/proguard/classfile/editor/ConstantAdder.java +0 -239
- data/lib/proguard4.7/src/proguard/classfile/editor/ConstantPoolEditor.java +0 -782
- data/lib/proguard4.7/src/proguard/classfile/editor/ConstantPoolRemapper.java +0 -662
- data/lib/proguard4.7/src/proguard/classfile/editor/ConstantPoolShrinker.java +0 -578
- data/lib/proguard4.7/src/proguard/classfile/editor/ConstantPoolSorter.java +0 -123
- data/lib/proguard4.7/src/proguard/classfile/editor/ElementValueAdder.java +0 -217
- data/lib/proguard4.7/src/proguard/classfile/editor/ElementValuesEditor.java +0 -238
- data/lib/proguard4.7/src/proguard/classfile/editor/ExceptionAdder.java +0 -65
- data/lib/proguard4.7/src/proguard/classfile/editor/ExceptionInfoAdder.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/editor/ExceptionsAttributeEditor.java +0 -68
- data/lib/proguard4.7/src/proguard/classfile/editor/InnerClassesAccessFixer.java +0 -83
- data/lib/proguard4.7/src/proguard/classfile/editor/InstructionAdder.java +0 -76
- data/lib/proguard4.7/src/proguard/classfile/editor/InstructionWriter.java +0 -278
- data/lib/proguard4.7/src/proguard/classfile/editor/InterfaceAdder.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/editor/InterfaceSorter.java +0 -152
- data/lib/proguard4.7/src/proguard/classfile/editor/InterfacesEditor.java +0 -122
- data/lib/proguard4.7/src/proguard/classfile/editor/LineNumberInfoAdder.java +0 -59
- data/lib/proguard4.7/src/proguard/classfile/editor/LineNumberTableAttributeEditor.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/editor/LocalVariableInfoAdder.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/editor/LocalVariableTableAttributeEditor.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/editor/LocalVariableTypeInfoAdder.java +0 -68
- data/lib/proguard4.7/src/proguard/classfile/editor/LocalVariableTypeTableAttributeEditor.java +0 -68
- data/lib/proguard4.7/src/proguard/classfile/editor/MemberAdder.java +0 -288
- data/lib/proguard4.7/src/proguard/classfile/editor/MemberReferenceFixer.java +0 -447
- data/lib/proguard4.7/src/proguard/classfile/editor/MethodInvocationFixer.java +0 -243
- data/lib/proguard4.7/src/proguard/classfile/editor/NameAndTypeShrinker.java +0 -188
- data/lib/proguard4.7/src/proguard/classfile/editor/NamedAttributeDeleter.java +0 -54
- data/lib/proguard4.7/src/proguard/classfile/editor/ParameterAnnotationsAttributeEditor.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/editor/StackSizeUpdater.java +0 -54
- data/lib/proguard4.7/src/proguard/classfile/editor/SubclassAdder.java +0 -59
- data/lib/proguard4.7/src/proguard/classfile/editor/SubclassToAdder.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/editor/Utf8Shrinker.java +0 -455
- data/lib/proguard4.7/src/proguard/classfile/editor/VariableCleaner.java +0 -267
- data/lib/proguard4.7/src/proguard/classfile/editor/VariableEditor.java +0 -130
- data/lib/proguard4.7/src/proguard/classfile/editor/VariableRemapper.java +0 -156
- data/lib/proguard4.7/src/proguard/classfile/editor/VariableSizeUpdater.java +0 -105
- data/lib/proguard4.7/src/proguard/classfile/editor/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/instruction/BranchInstruction.java +0 -180
- data/lib/proguard4.7/src/proguard/classfile/instruction/ConstantInstruction.java +0 -309
- data/lib/proguard4.7/src/proguard/classfile/instruction/Instruction.java +0 -920
- data/lib/proguard4.7/src/proguard/classfile/instruction/InstructionConstants.java +0 -449
- data/lib/proguard4.7/src/proguard/classfile/instruction/InstructionFactory.java +0 -300
- data/lib/proguard4.7/src/proguard/classfile/instruction/InstructionUtil.java +0 -67
- data/lib/proguard4.7/src/proguard/classfile/instruction/LookUpSwitchInstruction.java +0 -135
- data/lib/proguard4.7/src/proguard/classfile/instruction/SimpleInstruction.java +0 -255
- data/lib/proguard4.7/src/proguard/classfile/instruction/SwitchInstruction.java +0 -83
- data/lib/proguard4.7/src/proguard/classfile/instruction/TableSwitchInstruction.java +0 -139
- data/lib/proguard4.7/src/proguard/classfile/instruction/VariableInstruction.java +0 -372
- data/lib/proguard4.7/src/proguard/classfile/instruction/package.html +0 -9
- data/lib/proguard4.7/src/proguard/classfile/instruction/visitor/AllInstructionVisitor.java +0 -56
- data/lib/proguard4.7/src/proguard/classfile/instruction/visitor/InstructionCounter.java +0 -59
- data/lib/proguard4.7/src/proguard/classfile/instruction/visitor/InstructionVisitor.java +0 -42
- data/lib/proguard4.7/src/proguard/classfile/instruction/visitor/MultiInstructionVisitor.java +0 -131
- data/lib/proguard4.7/src/proguard/classfile/instruction/visitor/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/io/LibraryClassReader.java +0 -383
- data/lib/proguard4.7/src/proguard/classfile/io/ProgramClassReader.java +0 -919
- data/lib/proguard4.7/src/proguard/classfile/io/ProgramClassWriter.java +0 -735
- data/lib/proguard4.7/src/proguard/classfile/io/RuntimeDataInput.java +0 -223
- data/lib/proguard4.7/src/proguard/classfile/io/RuntimeDataOutput.java +0 -224
- data/lib/proguard4.7/src/proguard/classfile/io/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/package.html +0 -15
- data/lib/proguard4.7/src/proguard/classfile/util/AccessUtil.java +0 -105
- data/lib/proguard4.7/src/proguard/classfile/util/ClassReferenceInitializer.java +0 -559
- data/lib/proguard4.7/src/proguard/classfile/util/ClassSubHierarchyInitializer.java +0 -77
- data/lib/proguard4.7/src/proguard/classfile/util/ClassSuperHierarchyInitializer.java +0 -163
- data/lib/proguard4.7/src/proguard/classfile/util/ClassUtil.java +0 -1227
- data/lib/proguard4.7/src/proguard/classfile/util/DescriptorClassEnumeration.java +0 -236
- data/lib/proguard4.7/src/proguard/classfile/util/DynamicClassReferenceInitializer.java +0 -485
- data/lib/proguard4.7/src/proguard/classfile/util/DynamicMemberReferenceInitializer.java +0 -944
- data/lib/proguard4.7/src/proguard/classfile/util/ExternalTypeEnumeration.java +0 -106
- data/lib/proguard4.7/src/proguard/classfile/util/InstructionSequenceMatcher.java +0 -754
- data/lib/proguard4.7/src/proguard/classfile/util/InternalTypeEnumeration.java +0 -204
- data/lib/proguard4.7/src/proguard/classfile/util/MemberFinder.java +0 -197
- data/lib/proguard4.7/src/proguard/classfile/util/MethodLinker.java +0 -160
- data/lib/proguard4.7/src/proguard/classfile/util/SimplifiedVisitor.java +0 -834
- data/lib/proguard4.7/src/proguard/classfile/util/StringReferenceInitializer.java +0 -90
- data/lib/proguard4.7/src/proguard/classfile/util/StringSharer.java +0 -172
- data/lib/proguard4.7/src/proguard/classfile/util/WarningPrinter.java +0 -136
- data/lib/proguard4.7/src/proguard/classfile/util/package.html +0 -3
- data/lib/proguard4.7/src/proguard/classfile/visitor/AllClassVisitor.java +0 -47
- data/lib/proguard4.7/src/proguard/classfile/visitor/AllFieldVisitor.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/visitor/AllMemberVisitor.java +0 -57
- data/lib/proguard4.7/src/proguard/classfile/visitor/AllMethodVisitor.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/visitor/BottomClassFilter.java +0 -69
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassAccessFilter.java +0 -88
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassCleaner.java +0 -275
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassCollector.java +0 -58
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassCounter.java +0 -56
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassHierarchyTraveler.java +0 -91
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassNameFilter.java +0 -112
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassPoolFiller.java +0 -55
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassPoolVisitor.java +0 -37
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassPresenceFilter.java +0 -93
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassPrinter.java +0 -1011
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassVersionFilter.java +0 -85
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassVersionSetter.java +0 -83
- data/lib/proguard4.7/src/proguard/classfile/visitor/ClassVisitor.java +0 -36
- data/lib/proguard4.7/src/proguard/classfile/visitor/ConcreteClassDownTraveler.java +0 -100
- data/lib/proguard4.7/src/proguard/classfile/visitor/DotClassClassVisitor.java +0 -89
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptClassFilter.java +0 -69
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptClassesFilter.java +0 -90
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionCounter.java +0 -52
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionExcludedOffsetFilter.java +0 -64
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionHandlerConstantVisitor.java +0 -62
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionHandlerFilter.java +0 -70
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionOffsetFilter.java +0 -64
- data/lib/proguard4.7/src/proguard/classfile/visitor/ExceptionRangeFilter.java +0 -68
- data/lib/proguard4.7/src/proguard/classfile/visitor/ImplementedClassConstantFilter.java +0 -69
- data/lib/proguard4.7/src/proguard/classfile/visitor/ImplementedClassFilter.java +0 -71
- data/lib/proguard4.7/src/proguard/classfile/visitor/ImplementingClassConstantFilter.java +0 -70
- data/lib/proguard4.7/src/proguard/classfile/visitor/LibraryClassFilter.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/visitor/LibraryMemberFilter.java +0 -73
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberAccessFilter.java +0 -122
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberClassAccessFilter.java +0 -106
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberCollector.java +0 -59
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberCounter.java +0 -72
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberDescriptorFilter.java +0 -113
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberNameFilter.java +0 -113
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberToClassVisitor.java +0 -90
- data/lib/proguard4.7/src/proguard/classfile/visitor/MemberVisitor.java +0 -40
- data/lib/proguard4.7/src/proguard/classfile/visitor/MethodImplementationFilter.java +0 -70
- data/lib/proguard4.7/src/proguard/classfile/visitor/MethodImplementationTraveler.java +0 -128
- data/lib/proguard4.7/src/proguard/classfile/visitor/MultiClassPoolVisitor.java +0 -88
- data/lib/proguard4.7/src/proguard/classfile/visitor/MultiClassVisitor.java +0 -97
- data/lib/proguard4.7/src/proguard/classfile/visitor/MultiMemberVisitor.java +0 -113
- data/lib/proguard4.7/src/proguard/classfile/visitor/NamedClassVisitor.java +0 -49
- data/lib/proguard4.7/src/proguard/classfile/visitor/NamedFieldVisitor.java +0 -61
- data/lib/proguard4.7/src/proguard/classfile/visitor/NamedMethodVisitor.java +0 -61
- data/lib/proguard4.7/src/proguard/classfile/visitor/ProgramClassFilter.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/visitor/ProgramMemberFilter.java +0 -73
- data/lib/proguard4.7/src/proguard/classfile/visitor/ReferencedClassVisitor.java +0 -255
- data/lib/proguard4.7/src/proguard/classfile/visitor/ReferencedMemberVisitor.java +0 -73
- data/lib/proguard4.7/src/proguard/classfile/visitor/SimilarMemberVisitor.java +0 -125
- data/lib/proguard4.7/src/proguard/classfile/visitor/SimpleClassPrinter.java +0 -167
- data/lib/proguard4.7/src/proguard/classfile/visitor/SubclassFilter.java +0 -91
- data/lib/proguard4.7/src/proguard/classfile/visitor/SubclassTraveler.java +0 -60
- data/lib/proguard4.7/src/proguard/classfile/visitor/VariableClassVisitor.java +0 -78
- data/lib/proguard4.7/src/proguard/classfile/visitor/VariableMemberVisitor.java +0 -96
- data/lib/proguard4.7/src/proguard/classfile/visitor/package.html +0 -40
- data/lib/proguard4.7/src/proguard/evaluation/BasicBranchUnit.java +0 -126
- data/lib/proguard4.7/src/proguard/evaluation/BasicInvocationUnit.java +0 -425
- data/lib/proguard4.7/src/proguard/evaluation/BranchUnit.java +0 -63
- data/lib/proguard4.7/src/proguard/evaluation/ClassConstantValueFactory.java +0 -53
- data/lib/proguard4.7/src/proguard/evaluation/ConstantValueFactory.java +0 -113
- data/lib/proguard4.7/src/proguard/evaluation/InvocationUnit.java +0 -62
- data/lib/proguard4.7/src/proguard/evaluation/Processor.java +0 -908
- data/lib/proguard4.7/src/proguard/evaluation/Stack.java +0 -560
- data/lib/proguard4.7/src/proguard/evaluation/TracedStack.java +0 -342
- data/lib/proguard4.7/src/proguard/evaluation/TracedVariables.java +0 -199
- data/lib/proguard4.7/src/proguard/evaluation/Variables.java +0 -347
- data/lib/proguard4.7/src/proguard/evaluation/value/Category1Value.java +0 -41
- data/lib/proguard4.7/src/proguard/evaluation/value/Category2Value.java +0 -41
- data/lib/proguard4.7/src/proguard/evaluation/value/ComparisonValue.java +0 -69
- data/lib/proguard4.7/src/proguard/evaluation/value/CompositeDoubleValue.java +0 -81
- data/lib/proguard4.7/src/proguard/evaluation/value/CompositeFloatValue.java +0 -81
- data/lib/proguard4.7/src/proguard/evaluation/value/CompositeIntegerValue.java +0 -87
- data/lib/proguard4.7/src/proguard/evaluation/value/CompositeLongValue.java +0 -87
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedByteValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedCharacterValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedDoubleValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedFloatValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedIntegerValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedLongValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/ConvertedShortValue.java +0 -64
- data/lib/proguard4.7/src/proguard/evaluation/value/DoubleValue.java +0 -359
- data/lib/proguard4.7/src/proguard/evaluation/value/FloatValue.java +0 -359
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedDoubleValue.java +0 -67
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedFloatValue.java +0 -67
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedIntegerValue.java +0 -67
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedLongValue.java +0 -67
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedReferenceValue.java +0 -102
- data/lib/proguard4.7/src/proguard/evaluation/value/IdentifiedValueFactory.java +0 -75
- data/lib/proguard4.7/src/proguard/evaluation/value/InstructionOffsetValue.java +0 -307
- data/lib/proguard4.7/src/proguard/evaluation/value/IntegerValue.java +0 -1002
- data/lib/proguard4.7/src/proguard/evaluation/value/LongValue.java +0 -554
- data/lib/proguard4.7/src/proguard/evaluation/value/NegatedDoubleValue.java +0 -71
- data/lib/proguard4.7/src/proguard/evaluation/value/NegatedFloatValue.java +0 -71
- data/lib/proguard4.7/src/proguard/evaluation/value/NegatedIntegerValue.java +0 -71
- data/lib/proguard4.7/src/proguard/evaluation/value/NegatedLongValue.java +0 -71
- data/lib/proguard4.7/src/proguard/evaluation/value/ParticularDoubleValue.java +0 -216
- data/lib/proguard4.7/src/proguard/evaluation/value/ParticularFloatValue.java +0 -216
- data/lib/proguard4.7/src/proguard/evaluation/value/ParticularIntegerValue.java +0 -383
- data/lib/proguard4.7/src/proguard/evaluation/value/ParticularLongValue.java +0 -271
- data/lib/proguard4.7/src/proguard/evaluation/value/ReferenceValue.java +0 -540
- data/lib/proguard4.7/src/proguard/evaluation/value/SpecificDoubleValue.java +0 -186
- data/lib/proguard4.7/src/proguard/evaluation/value/SpecificFloatValue.java +0 -186
- data/lib/proguard4.7/src/proguard/evaluation/value/SpecificIntegerValue.java +0 -354
- data/lib/proguard4.7/src/proguard/evaluation/value/SpecificLongValue.java +0 -259
- data/lib/proguard4.7/src/proguard/evaluation/value/SpecificValueFactory.java +0 -97
- data/lib/proguard4.7/src/proguard/evaluation/value/TopValue.java +0 -79
- data/lib/proguard4.7/src/proguard/evaluation/value/UnknownDoubleValue.java +0 -125
- data/lib/proguard4.7/src/proguard/evaluation/value/UnknownFloatValue.java +0 -125
- data/lib/proguard4.7/src/proguard/evaluation/value/UnknownIntegerValue.java +0 -216
- data/lib/proguard4.7/src/proguard/evaluation/value/UnknownLongValue.java +0 -160
- data/lib/proguard4.7/src/proguard/evaluation/value/Value.java +0 -169
- data/lib/proguard4.7/src/proguard/evaluation/value/ValueFactory.java +0 -193
- data/lib/proguard4.7/src/proguard/evaluation/value/package.html +0 -3
- data/lib/proguard4.7/src/proguard/gui/ClassPathPanel.java +0 -441
- data/lib/proguard4.7/src/proguard/gui/ClassSpecificationDialog.java +0 -546
- data/lib/proguard4.7/src/proguard/gui/ClassSpecificationsPanel.java +0 -231
- data/lib/proguard4.7/src/proguard/gui/ExtensionFileFilter.java +0 -78
- data/lib/proguard4.7/src/proguard/gui/FilterBuilder.java +0 -208
- data/lib/proguard4.7/src/proguard/gui/FilterDialog.java +0 -320
- data/lib/proguard4.7/src/proguard/gui/GUIResources.java +0 -56
- data/lib/proguard4.7/src/proguard/gui/GUIResources.properties +0 -643
- data/lib/proguard4.7/src/proguard/gui/KeepSpecificationsPanel.java +0 -81
- data/lib/proguard4.7/src/proguard/gui/ListPanel.java +0 -341
- data/lib/proguard4.7/src/proguard/gui/MANIFEST.MF +0 -3
- data/lib/proguard4.7/src/proguard/gui/MemberSpecificationDialog.java +0 -509
- data/lib/proguard4.7/src/proguard/gui/MemberSpecificationsPanel.java +0 -304
- data/lib/proguard4.7/src/proguard/gui/MessageDialogRunnable.java +0 -90
- data/lib/proguard4.7/src/proguard/gui/OptimizationsDialog.java +0 -251
- data/lib/proguard4.7/src/proguard/gui/ProGuardGUI.java +0 -1777
- data/lib/proguard4.7/src/proguard/gui/ProGuardRunnable.java +0 -154
- data/lib/proguard4.7/src/proguard/gui/ReTraceRunnable.java +0 -149
- data/lib/proguard4.7/src/proguard/gui/SwingUtil.java +0 -82
- data/lib/proguard4.7/src/proguard/gui/TabbedPane.java +0 -229
- data/lib/proguard4.7/src/proguard/gui/TextAreaOutputStream.java +0 -81
- data/lib/proguard4.7/src/proguard/gui/arrow.gif +0 -0
- data/lib/proguard4.7/src/proguard/gui/boilerplate.pro +0 -410
- data/lib/proguard4.7/src/proguard/gui/default.pro +0 -318
- data/lib/proguard4.7/src/proguard/gui/package.html +0 -3
- data/lib/proguard4.7/src/proguard/gui/splash/BufferedSprite.java +0 -145
- data/lib/proguard4.7/src/proguard/gui/splash/CircleSprite.java +0 -74
- data/lib/proguard4.7/src/proguard/gui/splash/ClipSprite.java +0 -85
- data/lib/proguard4.7/src/proguard/gui/splash/ColorSprite.java +0 -65
- data/lib/proguard4.7/src/proguard/gui/splash/CompositeSprite.java +0 -56
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantColor.java +0 -51
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantDouble.java +0 -49
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantFont.java +0 -46
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantInt.java +0 -49
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantString.java +0 -49
- data/lib/proguard4.7/src/proguard/gui/splash/ConstantTiming.java +0 -57
- data/lib/proguard4.7/src/proguard/gui/splash/FontSprite.java +0 -65
- data/lib/proguard4.7/src/proguard/gui/splash/ImageSprite.java +0 -76
- data/lib/proguard4.7/src/proguard/gui/splash/LinearColor.java +0 -72
- data/lib/proguard4.7/src/proguard/gui/splash/LinearDouble.java +0 -55
- data/lib/proguard4.7/src/proguard/gui/splash/LinearInt.java +0 -55
- data/lib/proguard4.7/src/proguard/gui/splash/LinearTiming.java +0 -55
- data/lib/proguard4.7/src/proguard/gui/splash/OverrideGraphics2D.java +0 -598
- data/lib/proguard4.7/src/proguard/gui/splash/RectangleSprite.java +0 -114
- data/lib/proguard4.7/src/proguard/gui/splash/SawToothTiming.java +0 -53
- data/lib/proguard4.7/src/proguard/gui/splash/ShadowedSprite.java +0 -109
- data/lib/proguard4.7/src/proguard/gui/splash/SineTiming.java +0 -53
- data/lib/proguard4.7/src/proguard/gui/splash/SmoothTiming.java +0 -66
- data/lib/proguard4.7/src/proguard/gui/splash/SplashPanel.java +0 -235
- data/lib/proguard4.7/src/proguard/gui/splash/Sprite.java +0 -41
- data/lib/proguard4.7/src/proguard/gui/splash/TextSprite.java +0 -89
- data/lib/proguard4.7/src/proguard/gui/splash/TimeSwitchSprite.java +0 -75
- data/lib/proguard4.7/src/proguard/gui/splash/Timing.java +0 -34
- data/lib/proguard4.7/src/proguard/gui/splash/TypeWriterString.java +0 -71
- data/lib/proguard4.7/src/proguard/gui/splash/VariableColor.java +0 -36
- data/lib/proguard4.7/src/proguard/gui/splash/VariableDouble.java +0 -34
- data/lib/proguard4.7/src/proguard/gui/splash/VariableFont.java +0 -36
- data/lib/proguard4.7/src/proguard/gui/splash/VariableInt.java +0 -34
- data/lib/proguard4.7/src/proguard/gui/splash/VariableSizeFont.java +0 -65
- data/lib/proguard4.7/src/proguard/gui/splash/VariableString.java +0 -34
- data/lib/proguard4.7/src/proguard/gui/splash/package.html +0 -4
- data/lib/proguard4.7/src/proguard/gui/vtitle.png +0 -0
- data/lib/proguard4.7/src/proguard/io/CascadingDataEntryWriter.java +0 -94
- data/lib/proguard4.7/src/proguard/io/ClassFilter.java +0 -59
- data/lib/proguard4.7/src/proguard/io/ClassReader.java +0 -115
- data/lib/proguard4.7/src/proguard/io/ClassRewriter.java +0 -80
- data/lib/proguard4.7/src/proguard/io/DataEntry.java +0 -62
- data/lib/proguard4.7/src/proguard/io/DataEntryClassWriter.java +0 -85
- data/lib/proguard4.7/src/proguard/io/DataEntryCopier.java +0 -247
- data/lib/proguard4.7/src/proguard/io/DataEntryDirectoryFilter.java +0 -40
- data/lib/proguard4.7/src/proguard/io/DataEntryFilter.java +0 -38
- data/lib/proguard4.7/src/proguard/io/DataEntryNameFilter.java +0 -54
- data/lib/proguard4.7/src/proguard/io/DataEntryObfuscator.java +0 -150
- data/lib/proguard4.7/src/proguard/io/DataEntryParentFilter.java +0 -51
- data/lib/proguard4.7/src/proguard/io/DataEntryPump.java +0 -43
- data/lib/proguard4.7/src/proguard/io/DataEntryReader.java +0 -38
- data/lib/proguard4.7/src/proguard/io/DataEntryRenamer.java +0 -104
- data/lib/proguard4.7/src/proguard/io/DataEntryRewriter.java +0 -148
- data/lib/proguard4.7/src/proguard/io/DataEntryWriter.java +0 -73
- data/lib/proguard4.7/src/proguard/io/DirectoryFilter.java +0 -58
- data/lib/proguard4.7/src/proguard/io/DirectoryPump.java +0 -78
- data/lib/proguard4.7/src/proguard/io/DirectoryWriter.java +0 -165
- data/lib/proguard4.7/src/proguard/io/FileDataEntry.java +0 -96
- data/lib/proguard4.7/src/proguard/io/FilteredDataEntryReader.java +0 -90
- data/lib/proguard4.7/src/proguard/io/FilteredDataEntryWriter.java +0 -125
- data/lib/proguard4.7/src/proguard/io/Finisher.java +0 -37
- data/lib/proguard4.7/src/proguard/io/JarReader.java +0 -75
- data/lib/proguard4.7/src/proguard/io/JarWriter.java +0 -235
- data/lib/proguard4.7/src/proguard/io/ManifestRewriter.java +0 -216
- data/lib/proguard4.7/src/proguard/io/NameFilter.java +0 -83
- data/lib/proguard4.7/src/proguard/io/ParentDataEntryWriter.java +0 -75
- data/lib/proguard4.7/src/proguard/io/RenamedDataEntry.java +0 -83
- data/lib/proguard4.7/src/proguard/io/ZipDataEntry.java +0 -98
- data/lib/proguard4.7/src/proguard/io/package.html +0 -4
- data/lib/proguard4.7/src/proguard/obfuscate/AttributeShrinker.java +0 -120
- data/lib/proguard4.7/src/proguard/obfuscate/AttributeUsageMarker.java +0 -71
- data/lib/proguard4.7/src/proguard/obfuscate/ClassObfuscator.java +0 -533
- data/lib/proguard4.7/src/proguard/obfuscate/ClassRenamer.java +0 -109
- data/lib/proguard4.7/src/proguard/obfuscate/DictionaryNameFactory.java +0 -189
- data/lib/proguard4.7/src/proguard/obfuscate/MapCleaner.java +0 -57
- data/lib/proguard4.7/src/proguard/obfuscate/MappingKeeper.java +0 -177
- data/lib/proguard4.7/src/proguard/obfuscate/MappingPrinter.java +0 -147
- data/lib/proguard4.7/src/proguard/obfuscate/MappingProcessor.java +0 -79
- data/lib/proguard4.7/src/proguard/obfuscate/MappingReader.java +0 -199
- data/lib/proguard4.7/src/proguard/obfuscate/MemberNameCleaner.java +0 -60
- data/lib/proguard4.7/src/proguard/obfuscate/MemberNameCollector.java +0 -106
- data/lib/proguard4.7/src/proguard/obfuscate/MemberNameConflictFixer.java +0 -159
- data/lib/proguard4.7/src/proguard/obfuscate/MemberNameFilter.java +0 -120
- data/lib/proguard4.7/src/proguard/obfuscate/MemberObfuscator.java +0 -230
- data/lib/proguard4.7/src/proguard/obfuscate/MemberSpecialNameFilter.java +0 -101
- data/lib/proguard4.7/src/proguard/obfuscate/MultiMappingProcessor.java +0 -96
- data/lib/proguard4.7/src/proguard/obfuscate/NameFactory.java +0 -34
- data/lib/proguard4.7/src/proguard/obfuscate/NameFactoryResetter.java +0 -59
- data/lib/proguard4.7/src/proguard/obfuscate/NameMarker.java +0 -166
- data/lib/proguard4.7/src/proguard/obfuscate/NumericNameFactory.java +0 -49
- data/lib/proguard4.7/src/proguard/obfuscate/Obfuscator.java +0 -445
- data/lib/proguard4.7/src/proguard/obfuscate/ParameterNameMarker.java +0 -128
- data/lib/proguard4.7/src/proguard/obfuscate/SimpleNameFactory.java +0 -156
- data/lib/proguard4.7/src/proguard/obfuscate/SourceFileRenamer.java +0 -84
- data/lib/proguard4.7/src/proguard/obfuscate/SpecialNameFactory.java +0 -83
- data/lib/proguard4.7/src/proguard/obfuscate/package.html +0 -3
- data/lib/proguard4.7/src/proguard/optimize/BootstrapMethodArgumentShrinker.java +0 -103
- data/lib/proguard4.7/src/proguard/optimize/ChangedCodePrinter.java +0 -297
- data/lib/proguard4.7/src/proguard/optimize/ConstantMemberFilter.java +0 -77
- data/lib/proguard4.7/src/proguard/optimize/ConstantParameterFilter.java +0 -79
- data/lib/proguard4.7/src/proguard/optimize/DuplicateInitializerFixer.java +0 -215
- data/lib/proguard4.7/src/proguard/optimize/DuplicateInitializerInvocationFixer.java +0 -161
- data/lib/proguard4.7/src/proguard/optimize/KeepMarker.java +0 -95
- data/lib/proguard4.7/src/proguard/optimize/KeptClassFilter.java +0 -69
- data/lib/proguard4.7/src/proguard/optimize/KeptMemberFilter.java +0 -88
- data/lib/proguard4.7/src/proguard/optimize/MemberDescriptorSpecializer.java +0 -138
- data/lib/proguard4.7/src/proguard/optimize/MethodDescriptorShrinker.java +0 -317
- data/lib/proguard4.7/src/proguard/optimize/MethodStaticizer.java +0 -87
- data/lib/proguard4.7/src/proguard/optimize/OptimizationInfoMemberFilter.java +0 -94
- data/lib/proguard4.7/src/proguard/optimize/Optimizer.java +0 -963
- data/lib/proguard4.7/src/proguard/optimize/ParameterShrinker.java +0 -146
- data/lib/proguard4.7/src/proguard/optimize/TailRecursionSimplifier.java +0 -356
- data/lib/proguard4.7/src/proguard/optimize/WriteOnlyFieldFilter.java +0 -65
- data/lib/proguard4.7/src/proguard/optimize/evaluation/EvaluationShrinker.java +0 -2082
- data/lib/proguard4.7/src/proguard/optimize/evaluation/EvaluationSimplifier.java +0 -973
- data/lib/proguard4.7/src/proguard/optimize/evaluation/LivenessAnalyzer.java +0 -526
- data/lib/proguard4.7/src/proguard/optimize/evaluation/LoadingInvocationUnit.java +0 -195
- data/lib/proguard4.7/src/proguard/optimize/evaluation/PartialEvaluator.java +0 -1282
- data/lib/proguard4.7/src/proguard/optimize/evaluation/StoringInvocationUnit.java +0 -207
- data/lib/proguard4.7/src/proguard/optimize/evaluation/TracedBranchUnit.java +0 -59
- data/lib/proguard4.7/src/proguard/optimize/evaluation/VariableOptimizer.java +0 -345
- data/lib/proguard4.7/src/proguard/optimize/evaluation/package.html +0 -4
- data/lib/proguard4.7/src/proguard/optimize/info/AccessMethodMarker.java +0 -202
- data/lib/proguard4.7/src/proguard/optimize/info/BackwardBranchMarker.java +0 -90
- data/lib/proguard4.7/src/proguard/optimize/info/CatchExceptionMarker.java +0 -69
- data/lib/proguard4.7/src/proguard/optimize/info/CaughtClassFilter.java +0 -63
- data/lib/proguard4.7/src/proguard/optimize/info/CaughtClassMarker.java +0 -64
- data/lib/proguard4.7/src/proguard/optimize/info/ClassOptimizationInfo.java +0 -165
- data/lib/proguard4.7/src/proguard/optimize/info/ClassOptimizationInfoSetter.java +0 -47
- data/lib/proguard4.7/src/proguard/optimize/info/DotClassFilter.java +0 -63
- data/lib/proguard4.7/src/proguard/optimize/info/DotClassMarker.java +0 -96
- data/lib/proguard4.7/src/proguard/optimize/info/ExceptionInstructionChecker.java +0 -193
- data/lib/proguard4.7/src/proguard/optimize/info/FieldOptimizationInfo.java +0 -204
- data/lib/proguard4.7/src/proguard/optimize/info/InstanceofClassFilter.java +0 -63
- data/lib/proguard4.7/src/proguard/optimize/info/InstanceofClassMarker.java +0 -93
- data/lib/proguard4.7/src/proguard/optimize/info/InstantiationClassFilter.java +0 -62
- data/lib/proguard4.7/src/proguard/optimize/info/InstantiationClassMarker.java +0 -93
- data/lib/proguard4.7/src/proguard/optimize/info/MemberOptimizationInfoSetter.java +0 -59
- data/lib/proguard4.7/src/proguard/optimize/info/MethodInvocationMarker.java +0 -107
- data/lib/proguard4.7/src/proguard/optimize/info/MethodOptimizationInfo.java +0 -302
- data/lib/proguard4.7/src/proguard/optimize/info/NoSideEffectMethodMarker.java +0 -91
- data/lib/proguard4.7/src/proguard/optimize/info/NonPrivateMemberMarker.java +0 -171
- data/lib/proguard4.7/src/proguard/optimize/info/PackageVisibleMemberContainingClassMarker.java +0 -85
- data/lib/proguard4.7/src/proguard/optimize/info/PackageVisibleMemberInvokingClassMarker.java +0 -129
- data/lib/proguard4.7/src/proguard/optimize/info/ParameterUsageMarker.java +0 -285
- data/lib/proguard4.7/src/proguard/optimize/info/ReadWriteFieldMarker.java +0 -163
- data/lib/proguard4.7/src/proguard/optimize/info/SideEffectInstructionChecker.java +0 -245
- data/lib/proguard4.7/src/proguard/optimize/info/SideEffectMethodMarker.java +0 -175
- data/lib/proguard4.7/src/proguard/optimize/info/StaticInitializerContainingClassFilter.java +0 -62
- data/lib/proguard4.7/src/proguard/optimize/info/StaticInitializerContainingClassMarker.java +0 -65
- data/lib/proguard4.7/src/proguard/optimize/info/SuperInvocationMarker.java +0 -93
- data/lib/proguard4.7/src/proguard/optimize/info/VariableUsageMarker.java +0 -96
- data/lib/proguard4.7/src/proguard/optimize/info/package.html +0 -4
- data/lib/proguard4.7/src/proguard/optimize/package.html +0 -4
- data/lib/proguard4.7/src/proguard/optimize/peephole/BranchTargetFinder.java +0 -687
- data/lib/proguard4.7/src/proguard/optimize/peephole/ClassFinalizer.java +0 -84
- data/lib/proguard4.7/src/proguard/optimize/peephole/ClassMerger.java +0 -576
- data/lib/proguard4.7/src/proguard/optimize/peephole/GotoCommonCodeReplacer.java +0 -266
- data/lib/proguard4.7/src/proguard/optimize/peephole/GotoGotoReplacer.java +0 -115
- data/lib/proguard4.7/src/proguard/optimize/peephole/GotoReturnReplacer.java +0 -115
- data/lib/proguard4.7/src/proguard/optimize/peephole/HorizontalClassMerger.java +0 -90
- data/lib/proguard4.7/src/proguard/optimize/peephole/InstructionSequenceConstants.java +0 -4424
- data/lib/proguard4.7/src/proguard/optimize/peephole/InstructionSequenceReplacer.java +0 -420
- data/lib/proguard4.7/src/proguard/optimize/peephole/InstructionSequencesReplacer.java +0 -138
- data/lib/proguard4.7/src/proguard/optimize/peephole/MemberPrivatizer.java +0 -103
- data/lib/proguard4.7/src/proguard/optimize/peephole/MethodFinalizer.java +0 -93
- data/lib/proguard4.7/src/proguard/optimize/peephole/MethodInliner.java +0 -597
- data/lib/proguard4.7/src/proguard/optimize/peephole/NopRemover.java +0 -89
- data/lib/proguard4.7/src/proguard/optimize/peephole/PeepholeOptimizer.java +0 -103
- data/lib/proguard4.7/src/proguard/optimize/peephole/ReachableCodeMarker.java +0 -262
- data/lib/proguard4.7/src/proguard/optimize/peephole/RetargetedInnerClassAttributeRemover.java +0 -170
- data/lib/proguard4.7/src/proguard/optimize/peephole/TargetClassChanger.java +0 -455
- data/lib/proguard4.7/src/proguard/optimize/peephole/UnreachableCodeRemover.java +0 -143
- data/lib/proguard4.7/src/proguard/optimize/peephole/UnreachableExceptionRemover.java +0 -163
- data/lib/proguard4.7/src/proguard/optimize/peephole/VariableShrinker.java +0 -129
- data/lib/proguard4.7/src/proguard/optimize/peephole/VerticalClassMerger.java +0 -88
- data/lib/proguard4.7/src/proguard/optimize/peephole/package.html +0 -3
- data/lib/proguard4.7/src/proguard/package.html +0 -5
- data/lib/proguard4.7/src/proguard/preverify/CodePreverifier.java +0 -611
- data/lib/proguard4.7/src/proguard/preverify/CodeSubroutineInliner.java +0 -406
- data/lib/proguard4.7/src/proguard/preverify/Preverifier.java +0 -73
- data/lib/proguard4.7/src/proguard/preverify/SubroutineInliner.java +0 -73
- data/lib/proguard4.7/src/proguard/retrace/MANIFEST.MF +0 -3
- data/lib/proguard4.7/src/proguard/retrace/ReTrace.java +0 -749
- data/lib/proguard4.7/src/proguard/retrace/package.html +0 -4
- data/lib/proguard4.7/src/proguard/shrink/AnnotationUsageMarker.java +0 -333
- data/lib/proguard4.7/src/proguard/shrink/ClassShrinker.java +0 -458
- data/lib/proguard4.7/src/proguard/shrink/InnerUsageMarker.java +0 -174
- data/lib/proguard4.7/src/proguard/shrink/InterfaceUsageMarker.java +0 -152
- data/lib/proguard4.7/src/proguard/shrink/ShortestUsageMark.java +0 -183
- data/lib/proguard4.7/src/proguard/shrink/ShortestUsageMarker.java +0 -277
- data/lib/proguard4.7/src/proguard/shrink/ShortestUsagePrinter.java +0 -210
- data/lib/proguard4.7/src/proguard/shrink/Shrinker.java +0 -181
- data/lib/proguard4.7/src/proguard/shrink/UsageMarker.java +0 -1036
- data/lib/proguard4.7/src/proguard/shrink/UsagePrinter.java +0 -177
- data/lib/proguard4.7/src/proguard/shrink/UsedClassFilter.java +0 -74
- data/lib/proguard4.7/src/proguard/shrink/UsedMemberFilter.java +0 -93
- data/lib/proguard4.7/src/proguard/shrink/package.html +0 -3
- data/lib/proguard4.7/src/proguard/util/AndMatcher.java +0 -49
- data/lib/proguard4.7/src/proguard/util/ClassNameParser.java +0 -216
- data/lib/proguard4.7/src/proguard/util/ConstantMatcher.java +0 -48
- data/lib/proguard4.7/src/proguard/util/EmptyStringMatcher.java +0 -36
- data/lib/proguard4.7/src/proguard/util/ExtensionMatcher.java +0 -63
- data/lib/proguard4.7/src/proguard/util/FileNameParser.java +0 -121
- data/lib/proguard4.7/src/proguard/util/FixedStringMatcher.java +0 -56
- data/lib/proguard4.7/src/proguard/util/ListMatcher.java +0 -69
- data/lib/proguard4.7/src/proguard/util/ListParser.java +0 -137
- data/lib/proguard4.7/src/proguard/util/ListUtil.java +0 -180
- data/lib/proguard4.7/src/proguard/util/NameParser.java +0 -106
- data/lib/proguard4.7/src/proguard/util/NotMatcher.java +0 -46
- data/lib/proguard4.7/src/proguard/util/OrMatcher.java +0 -49
- data/lib/proguard4.7/src/proguard/util/SettableMatcher.java +0 -46
- data/lib/proguard4.7/src/proguard/util/StringMatcher.java +0 -38
- data/lib/proguard4.7/src/proguard/util/StringParser.java +0 -35
- data/lib/proguard4.7/src/proguard/util/VariableStringMatcher.java +0 -126
- data/lib/proguard4.7/src/proguard/util/package.html +0 -3
- data/lib/proguard4.7/src/proguard/wtk/ProGuardObfuscator.java +0 -141
- data/lib/proguard4.7/src/proguard/wtk/default.pro +0 -114
- data/lib/proguard4.7/src/proguard/wtk/package.html +0 -3
@@ -1,181 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
* ProGuard -- shrinking, optimization, obfuscation, and preverification
|
3
|
-
* of Java bytecode.
|
4
|
-
*
|
5
|
-
* Copyright (c) 2002-2011 Eric Lafortune (eric@graphics.cornell.edu)
|
6
|
-
*
|
7
|
-
* This program is free software; you can redistribute it and/or modify it
|
8
|
-
* under the terms of the GNU General Public License as published by the Free
|
9
|
-
* Software Foundation; either version 2 of the License, or (at your option)
|
10
|
-
* any later version.
|
11
|
-
*
|
12
|
-
* This program is distributed in the hope that it will be useful, but WITHOUT
|
13
|
-
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
14
|
-
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
15
|
-
* more details.
|
16
|
-
*
|
17
|
-
* You should have received a copy of the GNU General Public License along
|
18
|
-
* with this program; if not, write to the Free Software Foundation, Inc.,
|
19
|
-
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
20
|
-
*/
|
21
|
-
package proguard.shrink;
|
22
|
-
|
23
|
-
import proguard.*;
|
24
|
-
import proguard.classfile.*;
|
25
|
-
import proguard.classfile.attribute.visitor.*;
|
26
|
-
import proguard.classfile.visitor.*;
|
27
|
-
|
28
|
-
import java.io.*;
|
29
|
-
|
30
|
-
/**
|
31
|
-
* This class shrinks class pools according to a given configuration.
|
32
|
-
*
|
33
|
-
* @author Eric Lafortune
|
34
|
-
*/
|
35
|
-
public class Shrinker
|
36
|
-
{
|
37
|
-
private final Configuration configuration;
|
38
|
-
|
39
|
-
|
40
|
-
/**
|
41
|
-
* Creates a new Shrinker.
|
42
|
-
*/
|
43
|
-
public Shrinker(Configuration configuration)
|
44
|
-
{
|
45
|
-
this.configuration = configuration;
|
46
|
-
}
|
47
|
-
|
48
|
-
|
49
|
-
/**
|
50
|
-
* Performs shrinking of the given program class pool.
|
51
|
-
*/
|
52
|
-
public ClassPool execute(ClassPool programClassPool,
|
53
|
-
ClassPool libraryClassPool) throws IOException
|
54
|
-
{
|
55
|
-
// Check if we have at least some keep commands.
|
56
|
-
if (configuration.keep == null)
|
57
|
-
{
|
58
|
-
throw new IOException("You have to specify '-keep' options for the shrinking step.");
|
59
|
-
}
|
60
|
-
|
61
|
-
// Clean up any old visitor info.
|
62
|
-
programClassPool.classesAccept(new ClassCleaner());
|
63
|
-
libraryClassPool.classesAccept(new ClassCleaner());
|
64
|
-
|
65
|
-
// Create a visitor for marking the seeds.
|
66
|
-
UsageMarker usageMarker = configuration.whyAreYouKeeping == null ?
|
67
|
-
new UsageMarker() :
|
68
|
-
new ShortestUsageMarker();
|
69
|
-
|
70
|
-
// Automatically mark the parameterless constructors of seed classes,
|
71
|
-
// mainly for convenience and for backward compatibility.
|
72
|
-
ClassVisitor classUsageMarker =
|
73
|
-
new MultiClassVisitor(new ClassVisitor[]
|
74
|
-
{
|
75
|
-
usageMarker,
|
76
|
-
new NamedMethodVisitor(ClassConstants.INTERNAL_METHOD_NAME_INIT,
|
77
|
-
ClassConstants.INTERNAL_METHOD_TYPE_INIT,
|
78
|
-
usageMarker)
|
79
|
-
});
|
80
|
-
|
81
|
-
ClassPoolVisitor classPoolvisitor =
|
82
|
-
ClassSpecificationVisitorFactory.createClassPoolVisitor(configuration.keep,
|
83
|
-
classUsageMarker,
|
84
|
-
usageMarker,
|
85
|
-
true,
|
86
|
-
false,
|
87
|
-
false);
|
88
|
-
// Mark the seeds.
|
89
|
-
programClassPool.accept(classPoolvisitor);
|
90
|
-
libraryClassPool.accept(classPoolvisitor);
|
91
|
-
|
92
|
-
// Mark interfaces that have to be kept.
|
93
|
-
programClassPool.classesAccept(new InterfaceUsageMarker(usageMarker));
|
94
|
-
|
95
|
-
// Mark the inner class and annotation information that has to be kept.
|
96
|
-
programClassPool.classesAccept(
|
97
|
-
new UsedClassFilter(usageMarker,
|
98
|
-
new AllAttributeVisitor(true,
|
99
|
-
new MultiAttributeVisitor(new AttributeVisitor[]
|
100
|
-
{
|
101
|
-
new InnerUsageMarker(usageMarker),
|
102
|
-
new AnnotationUsageMarker(usageMarker),
|
103
|
-
}))));
|
104
|
-
|
105
|
-
// Should we explain ourselves?
|
106
|
-
if (configuration.whyAreYouKeeping != null)
|
107
|
-
{
|
108
|
-
System.out.println();
|
109
|
-
|
110
|
-
// Create a visitor for explaining classes and class members.
|
111
|
-
ShortestUsagePrinter shortestUsagePrinter =
|
112
|
-
new ShortestUsagePrinter((ShortestUsageMarker)usageMarker,
|
113
|
-
configuration.verbose);
|
114
|
-
|
115
|
-
ClassPoolVisitor whyClassPoolvisitor =
|
116
|
-
ClassSpecificationVisitorFactory.createClassPoolVisitor(configuration.whyAreYouKeeping,
|
117
|
-
shortestUsagePrinter,
|
118
|
-
shortestUsagePrinter);
|
119
|
-
|
120
|
-
// Mark the seeds.
|
121
|
-
programClassPool.accept(whyClassPoolvisitor);
|
122
|
-
libraryClassPool.accept(whyClassPoolvisitor);
|
123
|
-
}
|
124
|
-
|
125
|
-
if (configuration.printUsage != null)
|
126
|
-
{
|
127
|
-
PrintStream ps = isFile(configuration.printUsage) ?
|
128
|
-
new PrintStream(new BufferedOutputStream(new FileOutputStream(configuration.printUsage))) :
|
129
|
-
System.out;
|
130
|
-
|
131
|
-
// Print out items that will be removed.
|
132
|
-
programClassPool.classesAcceptAlphabetically(
|
133
|
-
new UsagePrinter(usageMarker, true, ps));
|
134
|
-
|
135
|
-
if (ps != System.out)
|
136
|
-
{
|
137
|
-
ps.close();
|
138
|
-
}
|
139
|
-
}
|
140
|
-
|
141
|
-
// Discard unused program classes.
|
142
|
-
int originalProgramClassPoolSize = programClassPool.size();
|
143
|
-
|
144
|
-
ClassPool newProgramClassPool = new ClassPool();
|
145
|
-
programClassPool.classesAccept(
|
146
|
-
new UsedClassFilter(usageMarker,
|
147
|
-
new MultiClassVisitor(
|
148
|
-
new ClassVisitor[] {
|
149
|
-
new ClassShrinker(usageMarker),
|
150
|
-
new ClassPoolFiller(newProgramClassPool)
|
151
|
-
})));
|
152
|
-
|
153
|
-
programClassPool.clear();
|
154
|
-
|
155
|
-
// Check if we have at least some output classes.
|
156
|
-
int newProgramClassPoolSize = newProgramClassPool.size();
|
157
|
-
if (newProgramClassPoolSize == 0)
|
158
|
-
{
|
159
|
-
throw new IOException("The output jar is empty. Did you specify the proper '-keep' options?");
|
160
|
-
}
|
161
|
-
|
162
|
-
if (configuration.verbose)
|
163
|
-
{
|
164
|
-
System.out.println("Removing unused program classes and class elements...");
|
165
|
-
System.out.println(" Original number of program classes: " + originalProgramClassPoolSize);
|
166
|
-
System.out.println(" Final number of program classes: " + newProgramClassPoolSize);
|
167
|
-
}
|
168
|
-
|
169
|
-
return newProgramClassPool;
|
170
|
-
}
|
171
|
-
|
172
|
-
|
173
|
-
/**
|
174
|
-
* Returns whether the given file is actually a file, or just a placeholder
|
175
|
-
* for the standard output.
|
176
|
-
*/
|
177
|
-
private boolean isFile(File file)
|
178
|
-
{
|
179
|
-
return file.getPath().length() > 0;
|
180
|
-
}
|
181
|
-
}
|
@@ -1,1036 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
* ProGuard -- shrinking, optimization, obfuscation, and preverification
|
3
|
-
* of Java bytecode.
|
4
|
-
*
|
5
|
-
* Copyright (c) 2002-2011 Eric Lafortune (eric@graphics.cornell.edu)
|
6
|
-
*
|
7
|
-
* This program is free software; you can redistribute it and/or modify it
|
8
|
-
* under the terms of the GNU General Public License as published by the Free
|
9
|
-
* Software Foundation; either version 2 of the License, or (at your option)
|
10
|
-
* any later version.
|
11
|
-
*
|
12
|
-
* This program is distributed in the hope that it will be useful, but WITHOUT
|
13
|
-
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
14
|
-
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
15
|
-
* more details.
|
16
|
-
*
|
17
|
-
* You should have received a copy of the GNU General Public License along
|
18
|
-
* with this program; if not, write to the Free Software Foundation, Inc.,
|
19
|
-
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
20
|
-
*/
|
21
|
-
package proguard.shrink;
|
22
|
-
|
23
|
-
import proguard.classfile.*;
|
24
|
-
import proguard.classfile.attribute.*;
|
25
|
-
import proguard.classfile.attribute.annotation.*;
|
26
|
-
import proguard.classfile.attribute.preverification.*;
|
27
|
-
import proguard.classfile.attribute.preverification.visitor.*;
|
28
|
-
import proguard.classfile.attribute.visitor.*;
|
29
|
-
import proguard.classfile.constant.*;
|
30
|
-
import proguard.classfile.constant.visitor.*;
|
31
|
-
import proguard.classfile.instruction.*;
|
32
|
-
import proguard.classfile.instruction.visitor.InstructionVisitor;
|
33
|
-
import proguard.classfile.util.*;
|
34
|
-
import proguard.classfile.visitor.*;
|
35
|
-
|
36
|
-
|
37
|
-
/**
|
38
|
-
* This ClassVisitor and MemberVisitor recursively marks all classes and class
|
39
|
-
* elements that are being used.
|
40
|
-
*
|
41
|
-
* @see ClassShrinker
|
42
|
-
*
|
43
|
-
* @author Eric Lafortune
|
44
|
-
*/
|
45
|
-
class UsageMarker
|
46
|
-
extends SimplifiedVisitor
|
47
|
-
implements ClassVisitor,
|
48
|
-
MemberVisitor,
|
49
|
-
ConstantVisitor,
|
50
|
-
AttributeVisitor,
|
51
|
-
InnerClassesInfoVisitor,
|
52
|
-
ExceptionInfoVisitor,
|
53
|
-
StackMapFrameVisitor,
|
54
|
-
VerificationTypeVisitor,
|
55
|
-
LocalVariableInfoVisitor,
|
56
|
-
LocalVariableTypeInfoVisitor,
|
57
|
-
// AnnotationVisitor,
|
58
|
-
// ElementValueVisitor,
|
59
|
-
InstructionVisitor
|
60
|
-
{
|
61
|
-
// A visitor info flag to indicate the ProgramMember object is being used,
|
62
|
-
// if its Clazz can be determined as being used as well.
|
63
|
-
private static final Object POSSIBLY_USED = new Object();
|
64
|
-
// A visitor info flag to indicate the visitor accepter is being used.
|
65
|
-
private static final Object USED = new Object();
|
66
|
-
|
67
|
-
|
68
|
-
private final MyInterfaceUsageMarker interfaceUsageMarker = new MyInterfaceUsageMarker();
|
69
|
-
private final MyPossiblyUsedMemberUsageMarker possiblyUsedMemberUsageMarker = new MyPossiblyUsedMemberUsageMarker();
|
70
|
-
private final MemberVisitor nonEmptyMethodUsageMarker = new AllAttributeVisitor(
|
71
|
-
new MyNonEmptyMethodUsageMarker());
|
72
|
-
private final ConstantVisitor parameterlessConstructorMarker = new ConstantTagFilter(new int[] { ClassConstants.CONSTANT_String, ClassConstants.CONSTANT_Class },
|
73
|
-
new ReferencedClassVisitor(
|
74
|
-
new NamedMethodVisitor(ClassConstants.INTERNAL_METHOD_NAME_INIT,
|
75
|
-
ClassConstants.INTERNAL_METHOD_TYPE_INIT,
|
76
|
-
this)));
|
77
|
-
|
78
|
-
// Implementations for ClassVisitor.
|
79
|
-
|
80
|
-
public void visitProgramClass(ProgramClass programClass)
|
81
|
-
{
|
82
|
-
if (shouldBeMarkedAsUsed(programClass))
|
83
|
-
{
|
84
|
-
// Mark this class.
|
85
|
-
markAsUsed(programClass);
|
86
|
-
|
87
|
-
markProgramClassBody(programClass);
|
88
|
-
}
|
89
|
-
}
|
90
|
-
|
91
|
-
|
92
|
-
protected void markProgramClassBody(ProgramClass programClass)
|
93
|
-
{
|
94
|
-
// Mark this class's name.
|
95
|
-
markConstant(programClass, programClass.u2thisClass);
|
96
|
-
|
97
|
-
// Mark the superclass.
|
98
|
-
if (programClass.u2superClass != 0)
|
99
|
-
{
|
100
|
-
markConstant(programClass, programClass.u2superClass);
|
101
|
-
}
|
102
|
-
|
103
|
-
// Give the interfaces preliminary marks.
|
104
|
-
programClass.hierarchyAccept(false, false, true, false,
|
105
|
-
interfaceUsageMarker);
|
106
|
-
|
107
|
-
// Explicitly mark the <clinit> method, if it's not empty.
|
108
|
-
programClass.methodAccept(ClassConstants.INTERNAL_METHOD_NAME_CLINIT,
|
109
|
-
ClassConstants.INTERNAL_METHOD_TYPE_CLINIT,
|
110
|
-
nonEmptyMethodUsageMarker);
|
111
|
-
|
112
|
-
// Process all class members that have already been marked as possibly used.
|
113
|
-
programClass.fieldsAccept(possiblyUsedMemberUsageMarker);
|
114
|
-
programClass.methodsAccept(possiblyUsedMemberUsageMarker);
|
115
|
-
|
116
|
-
// Mark the attributes.
|
117
|
-
programClass.attributesAccept(this);
|
118
|
-
}
|
119
|
-
|
120
|
-
|
121
|
-
public void visitLibraryClass(LibraryClass libraryClass)
|
122
|
-
{
|
123
|
-
if (shouldBeMarkedAsUsed(libraryClass))
|
124
|
-
{
|
125
|
-
markAsUsed(libraryClass);
|
126
|
-
|
127
|
-
// We're not going to analyze all library code. We're assuming that
|
128
|
-
// if this class is being used, all of its methods will be used as
|
129
|
-
// well. We'll mark them as such (here and in all subclasses).
|
130
|
-
|
131
|
-
// Mark the superclass.
|
132
|
-
Clazz superClass = libraryClass.superClass;
|
133
|
-
if (superClass != null)
|
134
|
-
{
|
135
|
-
superClass.accept(this);
|
136
|
-
}
|
137
|
-
|
138
|
-
// Mark the interfaces.
|
139
|
-
Clazz[] interfaceClasses = libraryClass.interfaceClasses;
|
140
|
-
if (interfaceClasses != null)
|
141
|
-
{
|
142
|
-
for (int index = 0; index < interfaceClasses.length; index++)
|
143
|
-
{
|
144
|
-
if (interfaceClasses[index] != null)
|
145
|
-
{
|
146
|
-
interfaceClasses[index].accept(this);
|
147
|
-
}
|
148
|
-
}
|
149
|
-
}
|
150
|
-
|
151
|
-
// Mark all methods.
|
152
|
-
libraryClass.methodsAccept(this);
|
153
|
-
}
|
154
|
-
}
|
155
|
-
|
156
|
-
|
157
|
-
/**
|
158
|
-
* This ClassVisitor marks ProgramClass objects as possibly used,
|
159
|
-
* and it visits LibraryClass objects with its outer UsageMarker.
|
160
|
-
*/
|
161
|
-
private class MyInterfaceUsageMarker
|
162
|
-
implements ClassVisitor
|
163
|
-
{
|
164
|
-
public void visitProgramClass(ProgramClass programClass)
|
165
|
-
{
|
166
|
-
if (shouldBeMarkedAsPossiblyUsed(programClass))
|
167
|
-
{
|
168
|
-
// We can't process the interface yet, because it might not
|
169
|
-
// be required. Give it a preliminary mark.
|
170
|
-
markAsPossiblyUsed(programClass);
|
171
|
-
}
|
172
|
-
}
|
173
|
-
|
174
|
-
public void visitLibraryClass(LibraryClass libraryClass)
|
175
|
-
{
|
176
|
-
// Make sure all library interface methods are marked.
|
177
|
-
UsageMarker.this.visitLibraryClass(libraryClass);
|
178
|
-
}
|
179
|
-
}
|
180
|
-
|
181
|
-
|
182
|
-
/**
|
183
|
-
* This MemberVisitor marks ProgramField and ProgramMethod objects that
|
184
|
-
* have already been marked as possibly used.
|
185
|
-
*/
|
186
|
-
private class MyPossiblyUsedMemberUsageMarker
|
187
|
-
extends SimplifiedVisitor
|
188
|
-
implements MemberVisitor
|
189
|
-
{
|
190
|
-
// Implementations for MemberVisitor.
|
191
|
-
|
192
|
-
public void visitProgramField(ProgramClass programClass, ProgramField programField)
|
193
|
-
{
|
194
|
-
// Has the method already been referenced?
|
195
|
-
if (isPossiblyUsed(programField))
|
196
|
-
{
|
197
|
-
markAsUsed(programField);
|
198
|
-
|
199
|
-
// Mark the name and descriptor.
|
200
|
-
markConstant(programClass, programField.u2nameIndex);
|
201
|
-
markConstant(programClass, programField.u2descriptorIndex);
|
202
|
-
|
203
|
-
// Mark the attributes.
|
204
|
-
programField.attributesAccept(programClass, UsageMarker.this);
|
205
|
-
|
206
|
-
// Mark the classes referenced in the descriptor string.
|
207
|
-
programField.referencedClassesAccept(UsageMarker.this);
|
208
|
-
}
|
209
|
-
}
|
210
|
-
|
211
|
-
|
212
|
-
public void visitProgramMethod(ProgramClass programClass, ProgramMethod programMethod)
|
213
|
-
{
|
214
|
-
// Has the method already been referenced?
|
215
|
-
if (isPossiblyUsed(programMethod))
|
216
|
-
{
|
217
|
-
markAsUsed(programMethod);
|
218
|
-
|
219
|
-
// Mark the method body.
|
220
|
-
markProgramMethodBody(programClass, programMethod);
|
221
|
-
|
222
|
-
// Note that, if the method has been marked as possibly used,
|
223
|
-
// the method hierarchy has already been marked (cfr. below).
|
224
|
-
}
|
225
|
-
}
|
226
|
-
}
|
227
|
-
|
228
|
-
|
229
|
-
/**
|
230
|
-
* This AttributeVisitor marks ProgramMethod objects of non-empty methods.
|
231
|
-
*/
|
232
|
-
private class MyNonEmptyMethodUsageMarker
|
233
|
-
extends SimplifiedVisitor
|
234
|
-
implements AttributeVisitor
|
235
|
-
{
|
236
|
-
// Implementations for AttributeVisitor.
|
237
|
-
|
238
|
-
public void visitAnyAttribute(Clazz clazz, Attribute attribute) {}
|
239
|
-
|
240
|
-
|
241
|
-
public void visitCodeAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute)
|
242
|
-
{
|
243
|
-
if (codeAttribute.u4codeLength > 1)
|
244
|
-
{
|
245
|
-
method.accept(clazz, UsageMarker.this);
|
246
|
-
}
|
247
|
-
}
|
248
|
-
}
|
249
|
-
|
250
|
-
|
251
|
-
// Implementations for MemberVisitor.
|
252
|
-
|
253
|
-
public void visitProgramField(ProgramClass programClass, ProgramField programField)
|
254
|
-
{
|
255
|
-
if (shouldBeMarkedAsUsed(programField))
|
256
|
-
{
|
257
|
-
// Is the field's class used?
|
258
|
-
if (isUsed(programClass))
|
259
|
-
{
|
260
|
-
markAsUsed(programField);
|
261
|
-
|
262
|
-
// Mark the field body.
|
263
|
-
markProgramFieldBody(programClass, programField);
|
264
|
-
}
|
265
|
-
|
266
|
-
// Hasn't the field been marked as possibly being used yet?
|
267
|
-
else if (shouldBeMarkedAsPossiblyUsed(programField))
|
268
|
-
{
|
269
|
-
// We can't process the field yet, because the class isn't
|
270
|
-
// marked as being used (yet). Give it a preliminary mark.
|
271
|
-
markAsPossiblyUsed(programField);
|
272
|
-
}
|
273
|
-
}
|
274
|
-
}
|
275
|
-
|
276
|
-
|
277
|
-
public void visitProgramMethod(ProgramClass programClass, ProgramMethod programMethod)
|
278
|
-
{
|
279
|
-
if (shouldBeMarkedAsUsed(programMethod))
|
280
|
-
{
|
281
|
-
// Is the method's class used?
|
282
|
-
if (isUsed(programClass))
|
283
|
-
{
|
284
|
-
markAsUsed(programMethod);
|
285
|
-
|
286
|
-
// Mark the method body.
|
287
|
-
markProgramMethodBody(programClass, programMethod);
|
288
|
-
|
289
|
-
// Mark the method hierarchy.
|
290
|
-
markMethodHierarchy(programClass, programMethod);
|
291
|
-
}
|
292
|
-
|
293
|
-
// Hasn't the method been marked as possibly being used yet?
|
294
|
-
else if (shouldBeMarkedAsPossiblyUsed(programMethod))
|
295
|
-
{
|
296
|
-
// We can't process the method yet, because the class isn't
|
297
|
-
// marked as being used (yet). Give it a preliminary mark.
|
298
|
-
markAsPossiblyUsed(programMethod);
|
299
|
-
|
300
|
-
// Mark the method hierarchy.
|
301
|
-
markMethodHierarchy(programClass, programMethod);
|
302
|
-
}
|
303
|
-
}
|
304
|
-
}
|
305
|
-
|
306
|
-
|
307
|
-
public void visitLibraryField(LibraryClass programClass, LibraryField programField) {}
|
308
|
-
|
309
|
-
|
310
|
-
public void visitLibraryMethod(LibraryClass libraryClass, LibraryMethod libraryMethod)
|
311
|
-
{
|
312
|
-
if (shouldBeMarkedAsUsed(libraryMethod))
|
313
|
-
{
|
314
|
-
markAsUsed(libraryMethod);
|
315
|
-
|
316
|
-
// Mark the method hierarchy.
|
317
|
-
markMethodHierarchy(libraryClass, libraryMethod);
|
318
|
-
}
|
319
|
-
}
|
320
|
-
|
321
|
-
|
322
|
-
protected void markProgramFieldBody(ProgramClass programClass, ProgramField programField)
|
323
|
-
{
|
324
|
-
// Mark the name and descriptor.
|
325
|
-
markConstant(programClass, programField.u2nameIndex);
|
326
|
-
markConstant(programClass, programField.u2descriptorIndex);
|
327
|
-
|
328
|
-
// Mark the attributes.
|
329
|
-
programField.attributesAccept(programClass, this);
|
330
|
-
|
331
|
-
// Mark the classes referenced in the descriptor string.
|
332
|
-
programField.referencedClassesAccept(this);
|
333
|
-
}
|
334
|
-
|
335
|
-
|
336
|
-
protected void markProgramMethodBody(ProgramClass programClass, ProgramMethod programMethod)
|
337
|
-
{
|
338
|
-
// Mark the name and descriptor.
|
339
|
-
markConstant(programClass, programMethod.u2nameIndex);
|
340
|
-
markConstant(programClass, programMethod.u2descriptorIndex);
|
341
|
-
|
342
|
-
// Mark the attributes.
|
343
|
-
programMethod.attributesAccept(programClass, this);
|
344
|
-
|
345
|
-
// Mark the classes referenced in the descriptor string.
|
346
|
-
programMethod.referencedClassesAccept(this);
|
347
|
-
}
|
348
|
-
|
349
|
-
|
350
|
-
/**
|
351
|
-
* Marks the hierarchy of implementing or overriding methods corresponding
|
352
|
-
* to the given method, if any.
|
353
|
-
*/
|
354
|
-
protected void markMethodHierarchy(Clazz clazz, Method method)
|
355
|
-
{
|
356
|
-
if ((method.getAccessFlags() &
|
357
|
-
(ClassConstants.INTERNAL_ACC_PRIVATE |
|
358
|
-
ClassConstants.INTERNAL_ACC_STATIC)) == 0 &&
|
359
|
-
!ClassUtil.isInitializer(method.getName(clazz)))
|
360
|
-
{
|
361
|
-
clazz.accept(new ConcreteClassDownTraveler(
|
362
|
-
new ClassHierarchyTraveler(true, true, false, true,
|
363
|
-
new NamedMethodVisitor(method.getName(clazz),
|
364
|
-
method.getDescriptor(clazz),
|
365
|
-
new MemberAccessFilter(0, ClassConstants.INTERNAL_ACC_PRIVATE | ClassConstants.INTERNAL_ACC_STATIC | ClassConstants.INTERNAL_ACC_ABSTRACT,
|
366
|
-
this)))));
|
367
|
-
}
|
368
|
-
}
|
369
|
-
|
370
|
-
|
371
|
-
// Implementations for ConstantVisitor.
|
372
|
-
|
373
|
-
public void visitIntegerConstant(Clazz clazz, IntegerConstant integerConstant)
|
374
|
-
{
|
375
|
-
if (shouldBeMarkedAsUsed(integerConstant))
|
376
|
-
{
|
377
|
-
markAsUsed(integerConstant);
|
378
|
-
}
|
379
|
-
}
|
380
|
-
|
381
|
-
|
382
|
-
public void visitLongConstant(Clazz clazz, LongConstant longConstant)
|
383
|
-
{
|
384
|
-
if (shouldBeMarkedAsUsed(longConstant))
|
385
|
-
{
|
386
|
-
markAsUsed(longConstant);
|
387
|
-
}
|
388
|
-
}
|
389
|
-
|
390
|
-
|
391
|
-
public void visitFloatConstant(Clazz clazz, FloatConstant floatConstant)
|
392
|
-
{
|
393
|
-
if (shouldBeMarkedAsUsed(floatConstant))
|
394
|
-
{
|
395
|
-
markAsUsed(floatConstant);
|
396
|
-
}
|
397
|
-
}
|
398
|
-
|
399
|
-
|
400
|
-
public void visitDoubleConstant(Clazz clazz, DoubleConstant doubleConstant)
|
401
|
-
{
|
402
|
-
if (shouldBeMarkedAsUsed(doubleConstant))
|
403
|
-
{
|
404
|
-
markAsUsed(doubleConstant);
|
405
|
-
}
|
406
|
-
}
|
407
|
-
|
408
|
-
|
409
|
-
public void visitStringConstant(Clazz clazz, StringConstant stringConstant)
|
410
|
-
{
|
411
|
-
if (shouldBeMarkedAsUsed(stringConstant))
|
412
|
-
{
|
413
|
-
markAsUsed(stringConstant);
|
414
|
-
|
415
|
-
markConstant(clazz, stringConstant.u2stringIndex);
|
416
|
-
|
417
|
-
// Mark the referenced class and class member, if any.
|
418
|
-
stringConstant.referencedClassAccept(this);
|
419
|
-
stringConstant.referencedMemberAccept(this);
|
420
|
-
}
|
421
|
-
}
|
422
|
-
|
423
|
-
|
424
|
-
public void visitUtf8Constant(Clazz clazz, Utf8Constant utf8Constant)
|
425
|
-
{
|
426
|
-
if (shouldBeMarkedAsUsed(utf8Constant))
|
427
|
-
{
|
428
|
-
markAsUsed(utf8Constant);
|
429
|
-
}
|
430
|
-
}
|
431
|
-
|
432
|
-
|
433
|
-
public void visitInvokeDynamicConstant(Clazz clazz, InvokeDynamicConstant invokeDynamicConstant)
|
434
|
-
{
|
435
|
-
if (shouldBeMarkedAsUsed(invokeDynamicConstant))
|
436
|
-
{
|
437
|
-
markAsUsed(invokeDynamicConstant);
|
438
|
-
|
439
|
-
markConstant(clazz, invokeDynamicConstant.u2nameAndTypeIndex);
|
440
|
-
|
441
|
-
// Mark the bootstrap methods attribute.
|
442
|
-
clazz.attributesAccept(new MyBootStrapMethodUsageMarker(invokeDynamicConstant.u2bootstrapMethodAttributeIndex));
|
443
|
-
}
|
444
|
-
}
|
445
|
-
|
446
|
-
|
447
|
-
public void visitMethodHandleConstant(Clazz clazz, MethodHandleConstant methodHandleConstant)
|
448
|
-
{
|
449
|
-
if (shouldBeMarkedAsUsed(methodHandleConstant))
|
450
|
-
{
|
451
|
-
markAsUsed(methodHandleConstant);
|
452
|
-
|
453
|
-
markConstant(clazz, methodHandleConstant.u2referenceIndex);
|
454
|
-
}
|
455
|
-
}
|
456
|
-
|
457
|
-
|
458
|
-
public void visitAnyRefConstant(Clazz clazz, RefConstant refConstant)
|
459
|
-
{
|
460
|
-
if (shouldBeMarkedAsUsed(refConstant))
|
461
|
-
{
|
462
|
-
markAsUsed(refConstant);
|
463
|
-
|
464
|
-
markConstant(clazz, refConstant.u2classIndex);
|
465
|
-
markConstant(clazz, refConstant.u2nameAndTypeIndex);
|
466
|
-
|
467
|
-
// When compiled with "-target 1.2" or higher, the class or
|
468
|
-
// interface actually containing the referenced class member may
|
469
|
-
// be higher up the hierarchy. Make sure it's marked, in case it
|
470
|
-
// isn't used elsewhere.
|
471
|
-
refConstant.referencedClassAccept(this);
|
472
|
-
|
473
|
-
// Mark the referenced class member itself.
|
474
|
-
refConstant.referencedMemberAccept(this);
|
475
|
-
}
|
476
|
-
}
|
477
|
-
|
478
|
-
|
479
|
-
public void visitClassConstant(Clazz clazz, ClassConstant classConstant)
|
480
|
-
{
|
481
|
-
if (shouldBeMarkedAsUsed(classConstant))
|
482
|
-
{
|
483
|
-
markAsUsed(classConstant);
|
484
|
-
|
485
|
-
markConstant(clazz, classConstant.u2nameIndex);
|
486
|
-
|
487
|
-
// Mark the referenced class itself.
|
488
|
-
classConstant.referencedClassAccept(this);
|
489
|
-
}
|
490
|
-
}
|
491
|
-
|
492
|
-
|
493
|
-
public void visitMethodTypeConstant(Clazz clazz, MethodTypeConstant methodTypeConstant)
|
494
|
-
{
|
495
|
-
if (shouldBeMarkedAsUsed(methodTypeConstant))
|
496
|
-
{
|
497
|
-
markAsUsed(methodTypeConstant);
|
498
|
-
|
499
|
-
markConstant(clazz, methodTypeConstant.u2descriptorIndex);
|
500
|
-
}
|
501
|
-
}
|
502
|
-
|
503
|
-
|
504
|
-
public void visitNameAndTypeConstant(Clazz clazz, NameAndTypeConstant nameAndTypeConstant)
|
505
|
-
{
|
506
|
-
if (shouldBeMarkedAsUsed(nameAndTypeConstant))
|
507
|
-
{
|
508
|
-
markAsUsed(nameAndTypeConstant);
|
509
|
-
|
510
|
-
markConstant(clazz, nameAndTypeConstant.u2nameIndex);
|
511
|
-
markConstant(clazz, nameAndTypeConstant.u2descriptorIndex);
|
512
|
-
}
|
513
|
-
}
|
514
|
-
|
515
|
-
|
516
|
-
/**
|
517
|
-
* This AttributeVisitor marks the bootstrap methods attributes, their
|
518
|
-
* method entries, their method handles, and their arguments.
|
519
|
-
*/
|
520
|
-
private class MyBootStrapMethodUsageMarker
|
521
|
-
extends SimplifiedVisitor
|
522
|
-
implements AttributeVisitor,
|
523
|
-
BootstrapMethodInfoVisitor
|
524
|
-
{
|
525
|
-
private int bootstrapMethodIndex;
|
526
|
-
|
527
|
-
|
528
|
-
private MyBootStrapMethodUsageMarker(int bootstrapMethodIndex)
|
529
|
-
{
|
530
|
-
this.bootstrapMethodIndex = bootstrapMethodIndex;
|
531
|
-
}
|
532
|
-
|
533
|
-
|
534
|
-
// Implementations for AttributeVisitor.
|
535
|
-
|
536
|
-
public void visitAnyAttribute(Clazz clazz, Attribute attribute) {}
|
537
|
-
|
538
|
-
|
539
|
-
public void visitBootstrapMethodsAttribute(Clazz clazz, BootstrapMethodsAttribute bootstrapMethodsAttribute)
|
540
|
-
{
|
541
|
-
if (shouldBeMarkedAsUsed(bootstrapMethodsAttribute))
|
542
|
-
{
|
543
|
-
markAsUsed(bootstrapMethodsAttribute);
|
544
|
-
|
545
|
-
markConstant(clazz, bootstrapMethodsAttribute.u2attributeNameIndex);
|
546
|
-
|
547
|
-
bootstrapMethodsAttribute.bootstrapMethodEntryAccept(clazz,
|
548
|
-
bootstrapMethodIndex,
|
549
|
-
this);
|
550
|
-
}
|
551
|
-
}
|
552
|
-
|
553
|
-
|
554
|
-
// Implementations for BootstrapMethodInfoVisitor.
|
555
|
-
|
556
|
-
public void visitBootstrapMethodInfo(Clazz clazz, BootstrapMethodInfo bootstrapMethodInfo)
|
557
|
-
{
|
558
|
-
markAsUsed(bootstrapMethodInfo);
|
559
|
-
|
560
|
-
markConstant(clazz, bootstrapMethodInfo.u2methodHandleIndex);
|
561
|
-
|
562
|
-
// Mark the constant pool entries referenced by the arguments.
|
563
|
-
bootstrapMethodInfo.methodArgumentsAccept(clazz, UsageMarker.this);
|
564
|
-
}
|
565
|
-
}
|
566
|
-
|
567
|
-
|
568
|
-
// Implementations for AttributeVisitor.
|
569
|
-
// Note that attributes are typically only referenced once, so we don't
|
570
|
-
// test if they have been marked already.
|
571
|
-
|
572
|
-
public void visitUnknownAttribute(Clazz clazz, UnknownAttribute unknownAttribute)
|
573
|
-
{
|
574
|
-
// This is the best we can do for unknown attributes.
|
575
|
-
markAsUsed(unknownAttribute);
|
576
|
-
|
577
|
-
markConstant(clazz, unknownAttribute.u2attributeNameIndex);
|
578
|
-
}
|
579
|
-
|
580
|
-
|
581
|
-
public void visitBootstrapMethodsAttribute(Clazz clazz, BootstrapMethodsAttribute bootstrapMethodsAttribute)
|
582
|
-
{
|
583
|
-
// Don't mark the attribute and its name here. We may mark it in
|
584
|
-
// MyBootStrapMethodsAttributeUsageMarker.
|
585
|
-
}
|
586
|
-
|
587
|
-
|
588
|
-
public void visitSourceFileAttribute(Clazz clazz, SourceFileAttribute sourceFileAttribute)
|
589
|
-
{
|
590
|
-
markAsUsed(sourceFileAttribute);
|
591
|
-
|
592
|
-
markConstant(clazz, sourceFileAttribute.u2attributeNameIndex);
|
593
|
-
markConstant(clazz, sourceFileAttribute.u2sourceFileIndex);
|
594
|
-
}
|
595
|
-
|
596
|
-
|
597
|
-
public void visitSourceDirAttribute(Clazz clazz, SourceDirAttribute sourceDirAttribute)
|
598
|
-
{
|
599
|
-
markAsUsed(sourceDirAttribute);
|
600
|
-
|
601
|
-
markConstant(clazz, sourceDirAttribute.u2attributeNameIndex);
|
602
|
-
markConstant(clazz, sourceDirAttribute.u2sourceDirIndex);
|
603
|
-
}
|
604
|
-
|
605
|
-
|
606
|
-
public void visitInnerClassesAttribute(Clazz clazz, InnerClassesAttribute innerClassesAttribute)
|
607
|
-
{
|
608
|
-
// Don't mark the attribute and its name yet. We may mark it later, in
|
609
|
-
// InnerUsageMarker.
|
610
|
-
//markAsUsed(innerClassesAttribute);
|
611
|
-
|
612
|
-
//markConstant(clazz, innerClassesAttribute.u2attrNameIndex);
|
613
|
-
|
614
|
-
// Do mark the outer class entries.
|
615
|
-
innerClassesAttribute.innerClassEntriesAccept(clazz, this);
|
616
|
-
}
|
617
|
-
|
618
|
-
|
619
|
-
public void visitEnclosingMethodAttribute(Clazz clazz, EnclosingMethodAttribute enclosingMethodAttribute)
|
620
|
-
{
|
621
|
-
markAsUsed(enclosingMethodAttribute);
|
622
|
-
|
623
|
-
markConstant(clazz, enclosingMethodAttribute.u2attributeNameIndex);
|
624
|
-
markConstant(clazz, enclosingMethodAttribute.u2classIndex);
|
625
|
-
|
626
|
-
if (enclosingMethodAttribute.u2nameAndTypeIndex != 0)
|
627
|
-
{
|
628
|
-
markConstant(clazz, enclosingMethodAttribute.u2nameAndTypeIndex);
|
629
|
-
}
|
630
|
-
}
|
631
|
-
|
632
|
-
|
633
|
-
public void visitDeprecatedAttribute(Clazz clazz, DeprecatedAttribute deprecatedAttribute)
|
634
|
-
{
|
635
|
-
markAsUsed(deprecatedAttribute);
|
636
|
-
|
637
|
-
markConstant(clazz, deprecatedAttribute.u2attributeNameIndex);
|
638
|
-
}
|
639
|
-
|
640
|
-
|
641
|
-
public void visitSyntheticAttribute(Clazz clazz, SyntheticAttribute syntheticAttribute)
|
642
|
-
{
|
643
|
-
markAsUsed(syntheticAttribute);
|
644
|
-
|
645
|
-
markConstant(clazz, syntheticAttribute.u2attributeNameIndex);
|
646
|
-
}
|
647
|
-
|
648
|
-
|
649
|
-
public void visitSignatureAttribute(Clazz clazz, SignatureAttribute signatureAttribute)
|
650
|
-
{
|
651
|
-
markAsUsed(signatureAttribute);
|
652
|
-
|
653
|
-
markConstant(clazz, signatureAttribute.u2attributeNameIndex);
|
654
|
-
markConstant(clazz, signatureAttribute.u2signatureIndex);
|
655
|
-
}
|
656
|
-
|
657
|
-
|
658
|
-
public void visitConstantValueAttribute(Clazz clazz, Field field, ConstantValueAttribute constantValueAttribute)
|
659
|
-
{
|
660
|
-
markAsUsed(constantValueAttribute);
|
661
|
-
|
662
|
-
markConstant(clazz, constantValueAttribute.u2attributeNameIndex);
|
663
|
-
markConstant(clazz, constantValueAttribute.u2constantValueIndex);
|
664
|
-
}
|
665
|
-
|
666
|
-
|
667
|
-
public void visitExceptionsAttribute(Clazz clazz, Method method, ExceptionsAttribute exceptionsAttribute)
|
668
|
-
{
|
669
|
-
markAsUsed(exceptionsAttribute);
|
670
|
-
|
671
|
-
markConstant(clazz, exceptionsAttribute.u2attributeNameIndex);
|
672
|
-
|
673
|
-
// Mark the constant pool entries referenced by the exceptions.
|
674
|
-
exceptionsAttribute.exceptionEntriesAccept((ProgramClass)clazz, this);
|
675
|
-
}
|
676
|
-
|
677
|
-
|
678
|
-
public void visitCodeAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute)
|
679
|
-
{
|
680
|
-
markAsUsed(codeAttribute);
|
681
|
-
|
682
|
-
markConstant(clazz, codeAttribute.u2attributeNameIndex);
|
683
|
-
|
684
|
-
// Mark the constant pool entries referenced by the instructions,
|
685
|
-
// by the exceptions, and by the attributes.
|
686
|
-
codeAttribute.instructionsAccept(clazz, method, this);
|
687
|
-
codeAttribute.exceptionsAccept(clazz, method, this);
|
688
|
-
codeAttribute.attributesAccept(clazz, method, this);
|
689
|
-
}
|
690
|
-
|
691
|
-
|
692
|
-
public void visitStackMapAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute, StackMapAttribute stackMapAttribute)
|
693
|
-
{
|
694
|
-
markAsUsed(stackMapAttribute);
|
695
|
-
|
696
|
-
markConstant(clazz, stackMapAttribute.u2attributeNameIndex);
|
697
|
-
|
698
|
-
// Mark the constant pool entries referenced by the stack map frames.
|
699
|
-
stackMapAttribute.stackMapFramesAccept(clazz, method, codeAttribute, this);
|
700
|
-
}
|
701
|
-
|
702
|
-
|
703
|
-
public void visitStackMapTableAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute, StackMapTableAttribute stackMapTableAttribute)
|
704
|
-
{
|
705
|
-
markAsUsed(stackMapTableAttribute);
|
706
|
-
|
707
|
-
markConstant(clazz, stackMapTableAttribute.u2attributeNameIndex);
|
708
|
-
|
709
|
-
// Mark the constant pool entries referenced by the stack map frames.
|
710
|
-
stackMapTableAttribute.stackMapFramesAccept(clazz, method, codeAttribute, this);
|
711
|
-
}
|
712
|
-
|
713
|
-
|
714
|
-
public void visitLineNumberTableAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute, LineNumberTableAttribute lineNumberTableAttribute)
|
715
|
-
{
|
716
|
-
markAsUsed(lineNumberTableAttribute);
|
717
|
-
|
718
|
-
markConstant(clazz, lineNumberTableAttribute.u2attributeNameIndex);
|
719
|
-
}
|
720
|
-
|
721
|
-
|
722
|
-
public void visitLocalVariableTableAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute, LocalVariableTableAttribute localVariableTableAttribute)
|
723
|
-
{
|
724
|
-
markAsUsed(localVariableTableAttribute);
|
725
|
-
|
726
|
-
markConstant(clazz, localVariableTableAttribute.u2attributeNameIndex);
|
727
|
-
|
728
|
-
// Mark the constant pool entries referenced by the local variables.
|
729
|
-
localVariableTableAttribute.localVariablesAccept(clazz, method, codeAttribute, this);
|
730
|
-
}
|
731
|
-
|
732
|
-
|
733
|
-
public void visitLocalVariableTypeTableAttribute(Clazz clazz, Method method, CodeAttribute codeAttribute, LocalVariableTypeTableAttribute localVariableTypeTableAttribute)
|
734
|
-
{
|
735
|
-
markAsUsed(localVariableTypeTableAttribute);
|
736
|
-
|
737
|
-
markConstant(clazz, localVariableTypeTableAttribute.u2attributeNameIndex);
|
738
|
-
|
739
|
-
// Mark the constant pool entries referenced by the local variable types.
|
740
|
-
localVariableTypeTableAttribute.localVariablesAccept(clazz, method, codeAttribute, this);
|
741
|
-
}
|
742
|
-
|
743
|
-
|
744
|
-
public void visitAnyAnnotationsAttribute(Clazz clazz, AnnotationsAttribute annotationsAttribute)
|
745
|
-
{
|
746
|
-
// Don't mark the attribute and its contents yet. We may mark them later,
|
747
|
-
// in AnnotationUsageMarker.
|
748
|
-
// markAsUsed(annotationsAttribute);
|
749
|
-
//
|
750
|
-
// markConstant(clazz, annotationsAttribute.u2attributeNameIndex);
|
751
|
-
//
|
752
|
-
// // Mark the constant pool entries referenced by the annotations.
|
753
|
-
// annotationsAttribute.annotationsAccept(clazz, this);
|
754
|
-
}
|
755
|
-
|
756
|
-
|
757
|
-
public void visitAnyParameterAnnotationsAttribute(Clazz clazz, Method method, ParameterAnnotationsAttribute parameterAnnotationsAttribute)
|
758
|
-
{
|
759
|
-
// Don't mark the attribute and its contents yet. We may mark them later,
|
760
|
-
// in AnnotationUsageMarker.
|
761
|
-
// markAsUsed(parameterAnnotationsAttribute);
|
762
|
-
//
|
763
|
-
// markConstant(clazz, parameterAnnotationsAttribute.u2attributeNameIndex);
|
764
|
-
//
|
765
|
-
// // Mark the constant pool entries referenced by the annotations.
|
766
|
-
// parameterAnnotationsAttribute.annotationsAccept(clazz, method, this);
|
767
|
-
}
|
768
|
-
|
769
|
-
|
770
|
-
public void visitAnnotationDefaultAttribute(Clazz clazz, Method method, AnnotationDefaultAttribute annotationDefaultAttribute)
|
771
|
-
{
|
772
|
-
// Don't mark the attribute and its contents yet. We may mark them later,
|
773
|
-
// in AnnotationUsageMarker.
|
774
|
-
// markAsUsed(annotationDefaultAttribute);
|
775
|
-
//
|
776
|
-
// markConstant(clazz, annotationDefaultAttribute.u2attributeNameIndex);
|
777
|
-
//
|
778
|
-
// // Mark the constant pool entries referenced by the element value.
|
779
|
-
// annotationDefaultAttribute.defaultValueAccept(clazz, this);
|
780
|
-
}
|
781
|
-
|
782
|
-
|
783
|
-
// Implementations for ExceptionInfoVisitor.
|
784
|
-
|
785
|
-
public void visitExceptionInfo(Clazz clazz, Method method, CodeAttribute codeAttribute, ExceptionInfo exceptionInfo)
|
786
|
-
{
|
787
|
-
markAsUsed(exceptionInfo);
|
788
|
-
|
789
|
-
if (exceptionInfo.u2catchType != 0)
|
790
|
-
{
|
791
|
-
markConstant(clazz, exceptionInfo.u2catchType);
|
792
|
-
}
|
793
|
-
}
|
794
|
-
|
795
|
-
|
796
|
-
// Implementations for InnerClassesInfoVisitor.
|
797
|
-
|
798
|
-
public void visitInnerClassesInfo(Clazz clazz, InnerClassesInfo innerClassesInfo)
|
799
|
-
{
|
800
|
-
// At this point, we only mark outer classes of this class.
|
801
|
-
// Inner class can be marked later, by InnerUsageMarker.
|
802
|
-
if (innerClassesInfo.u2innerClassIndex != 0 &&
|
803
|
-
clazz.getName().equals(clazz.getClassName(innerClassesInfo.u2innerClassIndex)))
|
804
|
-
{
|
805
|
-
markAsUsed(innerClassesInfo);
|
806
|
-
|
807
|
-
innerClassesInfo.innerClassConstantAccept(clazz, this);
|
808
|
-
innerClassesInfo.outerClassConstantAccept(clazz, this);
|
809
|
-
innerClassesInfo.innerNameConstantAccept(clazz, this);
|
810
|
-
}
|
811
|
-
}
|
812
|
-
|
813
|
-
|
814
|
-
// Implementations for StackMapFrameVisitor.
|
815
|
-
|
816
|
-
public void visitAnyStackMapFrame(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, StackMapFrame stackMapFrame) {}
|
817
|
-
|
818
|
-
|
819
|
-
public void visitSameOneFrame(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, SameOneFrame sameOneFrame)
|
820
|
-
{
|
821
|
-
// Mark the constant pool entries referenced by the verification types.
|
822
|
-
sameOneFrame.stackItemAccept(clazz, method, codeAttribute, offset, this);
|
823
|
-
}
|
824
|
-
|
825
|
-
|
826
|
-
public void visitMoreZeroFrame(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, MoreZeroFrame moreZeroFrame)
|
827
|
-
{
|
828
|
-
// Mark the constant pool entries referenced by the verification types.
|
829
|
-
moreZeroFrame.additionalVariablesAccept(clazz, method, codeAttribute, offset, this);
|
830
|
-
}
|
831
|
-
|
832
|
-
|
833
|
-
public void visitFullFrame(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, FullFrame fullFrame)
|
834
|
-
{
|
835
|
-
// Mark the constant pool entries referenced by the verification types.
|
836
|
-
fullFrame.variablesAccept(clazz, method, codeAttribute, offset, this);
|
837
|
-
fullFrame.stackAccept(clazz, method, codeAttribute, offset, this);
|
838
|
-
}
|
839
|
-
|
840
|
-
|
841
|
-
// Implementations for VerificationTypeVisitor.
|
842
|
-
|
843
|
-
public void visitAnyVerificationType(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, VerificationType verificationType) {}
|
844
|
-
|
845
|
-
|
846
|
-
public void visitObjectType(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, ObjectType objectType)
|
847
|
-
{
|
848
|
-
markConstant(clazz, objectType.u2classIndex);
|
849
|
-
}
|
850
|
-
|
851
|
-
|
852
|
-
// Implementations for LocalVariableInfoVisitor.
|
853
|
-
|
854
|
-
public void visitLocalVariableInfo(Clazz clazz, Method method, CodeAttribute codeAttribute, LocalVariableInfo localVariableInfo)
|
855
|
-
{
|
856
|
-
markConstant(clazz, localVariableInfo.u2nameIndex);
|
857
|
-
markConstant(clazz, localVariableInfo.u2descriptorIndex);
|
858
|
-
}
|
859
|
-
|
860
|
-
|
861
|
-
// Implementations for LocalVariableTypeInfoVisitor.
|
862
|
-
|
863
|
-
public void visitLocalVariableTypeInfo(Clazz clazz, Method method, CodeAttribute codeAttribute, LocalVariableTypeInfo localVariableTypeInfo)
|
864
|
-
{
|
865
|
-
markConstant(clazz, localVariableTypeInfo.u2nameIndex);
|
866
|
-
markConstant(clazz, localVariableTypeInfo.u2signatureIndex);
|
867
|
-
}
|
868
|
-
|
869
|
-
|
870
|
-
// // Implementations for AnnotationVisitor.
|
871
|
-
//
|
872
|
-
// public void visitAnnotation(Clazz clazz, Annotation annotation)
|
873
|
-
// {
|
874
|
-
// markConstant(clazz, annotation.u2typeIndex);
|
875
|
-
//
|
876
|
-
// // Mark the constant pool entries referenced by the element values.
|
877
|
-
// annotation.elementValuesAccept(clazz, this);
|
878
|
-
// }
|
879
|
-
//
|
880
|
-
//
|
881
|
-
// // Implementations for ElementValueVisitor.
|
882
|
-
//
|
883
|
-
// public void visitConstantElementValue(Clazz clazz, Annotation annotation, ConstantElementValue constantElementValue)
|
884
|
-
// {
|
885
|
-
// if (constantElementValue.u2elementNameIndex != 0)
|
886
|
-
// {
|
887
|
-
// markConstant(clazz, constantElementValue.u2elementNameIndex);
|
888
|
-
// }
|
889
|
-
//
|
890
|
-
// markConstant(clazz, constantElementValue.u2constantValueIndex);
|
891
|
-
// }
|
892
|
-
//
|
893
|
-
//
|
894
|
-
// public void visitEnumConstantElementValue(Clazz clazz, Annotation annotation, EnumConstantElementValue enumConstantElementValue)
|
895
|
-
// {
|
896
|
-
// if (enumConstantElementValue.u2elementNameIndex != 0)
|
897
|
-
// {
|
898
|
-
// markConstant(clazz, enumConstantElementValue.u2elementNameIndex);
|
899
|
-
// }
|
900
|
-
//
|
901
|
-
// markConstant(clazz, enumConstantElementValue.u2typeNameIndex);
|
902
|
-
// markConstant(clazz, enumConstantElementValue.u2constantNameIndex);
|
903
|
-
// }
|
904
|
-
//
|
905
|
-
//
|
906
|
-
// public void visitClassElementValue(Clazz clazz, Annotation annotation, ClassElementValue classElementValue)
|
907
|
-
// {
|
908
|
-
// if (classElementValue.u2elementNameIndex != 0)
|
909
|
-
// {
|
910
|
-
// markConstant(clazz, classElementValue.u2elementNameIndex);
|
911
|
-
// }
|
912
|
-
//
|
913
|
-
// // Mark the referenced class constant pool entry.
|
914
|
-
// markConstant(clazz, classElementValue.u2classInfoIndex);
|
915
|
-
// }
|
916
|
-
//
|
917
|
-
//
|
918
|
-
// public void visitAnnotationElementValue(Clazz clazz, Annotation annotation, AnnotationElementValue annotationElementValue)
|
919
|
-
// {
|
920
|
-
// if (annotationElementValue.u2elementNameIndex != 0)
|
921
|
-
// {
|
922
|
-
// markConstant(clazz, annotationElementValue.u2elementNameIndex);
|
923
|
-
// }
|
924
|
-
//
|
925
|
-
// // Mark the constant pool entries referenced by the annotation.
|
926
|
-
// annotationElementValue.annotationAccept(clazz, this);
|
927
|
-
// }
|
928
|
-
//
|
929
|
-
//
|
930
|
-
// public void visitArrayElementValue(Clazz clazz, Annotation annotation, ArrayElementValue arrayElementValue)
|
931
|
-
// {
|
932
|
-
// if (arrayElementValue.u2elementNameIndex != 0)
|
933
|
-
// {
|
934
|
-
// markConstant(clazz, arrayElementValue.u2elementNameIndex);
|
935
|
-
// }
|
936
|
-
//
|
937
|
-
// // Mark the constant pool entries referenced by the element values.
|
938
|
-
// arrayElementValue.elementValuesAccept(clazz, annotation, this);
|
939
|
-
// }
|
940
|
-
|
941
|
-
|
942
|
-
// Implementations for InstructionVisitor.
|
943
|
-
|
944
|
-
public void visitAnyInstruction(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, Instruction instruction) {}
|
945
|
-
|
946
|
-
|
947
|
-
public void visitConstantInstruction(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, ConstantInstruction constantInstruction)
|
948
|
-
{
|
949
|
-
markConstant(clazz, constantInstruction.constantIndex);
|
950
|
-
|
951
|
-
// Also mark the parameterless constructor of the class, in case the
|
952
|
-
// string constant or class constant is being used in a Class.forName
|
953
|
-
// or a .class construct.
|
954
|
-
clazz.constantPoolEntryAccept(constantInstruction.constantIndex,
|
955
|
-
parameterlessConstructorMarker);
|
956
|
-
}
|
957
|
-
|
958
|
-
|
959
|
-
// Small utility methods.
|
960
|
-
|
961
|
-
/**
|
962
|
-
* Marks the given visitor accepter as being used.
|
963
|
-
*/
|
964
|
-
protected void markAsUsed(VisitorAccepter visitorAccepter)
|
965
|
-
{
|
966
|
-
visitorAccepter.setVisitorInfo(USED);
|
967
|
-
}
|
968
|
-
|
969
|
-
|
970
|
-
/**
|
971
|
-
* Returns whether the given visitor accepter should still be marked as
|
972
|
-
* being used.
|
973
|
-
*/
|
974
|
-
protected boolean shouldBeMarkedAsUsed(VisitorAccepter visitorAccepter)
|
975
|
-
{
|
976
|
-
return visitorAccepter.getVisitorInfo() != USED;
|
977
|
-
}
|
978
|
-
|
979
|
-
|
980
|
-
/**
|
981
|
-
* Returns whether the given visitor accepter has been marked as being used.
|
982
|
-
*/
|
983
|
-
protected boolean isUsed(VisitorAccepter visitorAccepter)
|
984
|
-
{
|
985
|
-
return visitorAccepter.getVisitorInfo() == USED;
|
986
|
-
}
|
987
|
-
|
988
|
-
|
989
|
-
/**
|
990
|
-
* Marks the given visitor accepter as possibly being used.
|
991
|
-
*/
|
992
|
-
protected void markAsPossiblyUsed(VisitorAccepter visitorAccepter)
|
993
|
-
{
|
994
|
-
visitorAccepter.setVisitorInfo(POSSIBLY_USED);
|
995
|
-
}
|
996
|
-
|
997
|
-
|
998
|
-
/**
|
999
|
-
* Returns whether the given visitor accepter should still be marked as
|
1000
|
-
* possibly being used.
|
1001
|
-
*/
|
1002
|
-
protected boolean shouldBeMarkedAsPossiblyUsed(VisitorAccepter visitorAccepter)
|
1003
|
-
{
|
1004
|
-
return visitorAccepter.getVisitorInfo() != USED &&
|
1005
|
-
visitorAccepter.getVisitorInfo() != POSSIBLY_USED;
|
1006
|
-
}
|
1007
|
-
|
1008
|
-
|
1009
|
-
/**
|
1010
|
-
* Returns whether the given visitor accepter has been marked as possibly
|
1011
|
-
* being used.
|
1012
|
-
*/
|
1013
|
-
protected boolean isPossiblyUsed(VisitorAccepter visitorAccepter)
|
1014
|
-
{
|
1015
|
-
return visitorAccepter.getVisitorInfo() == POSSIBLY_USED;
|
1016
|
-
}
|
1017
|
-
|
1018
|
-
|
1019
|
-
/**
|
1020
|
-
* Clears any usage marks from the given visitor accepter.
|
1021
|
-
*/
|
1022
|
-
protected void markAsUnused(VisitorAccepter visitorAccepter)
|
1023
|
-
{
|
1024
|
-
visitorAccepter.setVisitorInfo(null);
|
1025
|
-
}
|
1026
|
-
|
1027
|
-
|
1028
|
-
/**
|
1029
|
-
* Marks the given constant pool entry of the given class. This includes
|
1030
|
-
* visiting any referenced objects.
|
1031
|
-
*/
|
1032
|
-
private void markConstant(Clazz clazz, int index)
|
1033
|
-
{
|
1034
|
-
clazz.constantPoolEntryAccept(index, this);
|
1035
|
-
}
|
1036
|
-
}
|