# HG changeset patch # User forax # Date 1301694735 -7200 # Node ID 4dfa6db13f7c82110d881e8c86433abef4af5ffc # Parent d29d8ebc2c1acc42f43b12d1226651770a64fa23# Parent b4b1ddad8f7b6b1ef4937efaf552ad26f814b9fc merge diff -r d29d8ebc2c1a -r 4dfa6db13f7c src/main/java/org/icedrobot/daneel/dex/AccessFlags.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/java/org/icedrobot/daneel/dex/AccessFlags.java Fri Apr 01 23:52:15 2011 +0200 @@ -0,0 +1,80 @@ +/* + * Daneel - Dalvik to Java bytecode compiler + * Copyright (C) 2011 IcedRobot team + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + * + * This file is subject to the "Classpath" exception: + * + * Linking this library statically or dynamically with other modules is + * making a combined work based on this library. Thus, the terms and + * conditions of the GNU General Public License cover the whole + * combination. + * + * As a special exception, the copyright holders of this library give you + * permission to link this library with independent modules to produce an + * executable, regardless of the license terms of these independent + * modules, and to copy and distribute the resulting executable under terms + * of your choice, provided that you also meet, for each linked independent + * module, the terms and conditions of the license of that module. An + * independent module is a module which is not derived from or based on + * this library. If you modify this library, you may extend this exception + * to your version of the library, but you are not obligated to do so. If + * you do not wish to do so, delete this exception statement from your + * version. + */ + +package org.icedrobot.daneel.dex; + +/** + * Definition of all access flags as used in Dalvik VM executables. + */ +public class AccessFlags { + + public static final int ACC_PUBLIC = 0x1; + public static final int ACC_PRIVATE = 0x2; + public static final int ACC_PROTECTED = 0x4; + public static final int ACC_STATIC = 0x8; + public static final int ACC_FINAL = 0x10; + public static final int ACC_SYNCHRONIZED = 0x20; + public static final int ACC_VOLATILE = 0x40; + public static final int ACC_BRIDGE = 0x40; + public static final int ACC_TRANSIENT = 0x80; + public static final int ACC_VARARGS = 0x80; + public static final int ACC_NATIVE = 0x100; + public static final int ACC_INTERFACE = 0x200; + public static final int ACC_ABSTRACT = 0x400; + public static final int ACC_STRICT = 0x800; + public static final int ACC_SYNTHETIC = 0x1000; + public static final int ACC_ANNOTATION = 0x2000; + public static final int ACC_ENUM = 0x4000; + // (unused) = 0x8000 + public static final int ACC_CONSTRUCTOR = 0x10000; + public static final int ACC_DECLARED_SYNCHRONIZED = 0x20000; + + /** + * Checks whether the given access flags field has the {@link #ACC_STATIC} + * flag set or not. + * + * @param flags The given access flags field. + * @return True if access flag is set, false otherwise. + */ + public static boolean isStatic(int flags) { + return (flags & ACC_STATIC) != 0; + } + + private AccessFlags() { + // No instances of this class. + } +} diff -r d29d8ebc2c1a -r 4dfa6db13f7c src/main/java/org/icedrobot/daneel/dex/DebugInfo.java --- a/src/main/java/org/icedrobot/daneel/dex/DebugInfo.java Fri Apr 01 23:50:53 2011 +0200 +++ b/src/main/java/org/icedrobot/daneel/dex/DebugInfo.java Fri Apr 01 23:52:15 2011 +0200 @@ -179,8 +179,7 @@ regNum--; regs[regNum] = emitLocalVariable(regNum, 0, name, type, null); } - // XXX Move the check for ACC_STATIC into "AccessFlags" class. - if ((code.getFlags() & 0x8) == 0) { + if (!AccessFlags.isStatic(code.getFlags())) { String name = ""; String type = method.getClassName(); regs[regNum] = emitLocalVariable(regNum, 0, name, type, null); diff -r d29d8ebc2c1a -r 4dfa6db13f7c src/main/java/org/icedrobot/daneel/rewriter/DexRewriter.java --- a/src/main/java/org/icedrobot/daneel/rewriter/DexRewriter.java Fri Apr 01 23:50:53 2011 +0200 +++ b/src/main/java/org/icedrobot/daneel/rewriter/DexRewriter.java Fri Apr 01 23:52:15 2011 +0200 @@ -49,6 +49,7 @@ import java.util.IdentityHashMap; import java.util.Set; +import org.icedrobot.daneel.dex.AccessFlags; import org.icedrobot.daneel.dex.DexAnnotationVisitor; import org.icedrobot.daneel.dex.DexClassVisitor; import org.icedrobot.daneel.dex.DexFieldVisitor; @@ -61,7 +62,6 @@ import org.objectweb.asm.ClassWriter; import org.objectweb.asm.FieldVisitor; import org.objectweb.asm.MethodVisitor; -import org.objectweb.asm.Opcodes; import org.objectweb.asm.Type; import org.objectweb.asm.tree.AbstractInsnNode; import org.objectweb.asm.tree.InsnNode; @@ -149,7 +149,7 @@ return null; } - return new MethodRewriter(mv, (access & Opcodes.ACC_STATIC) != 0, desc); + return new MethodRewriter(mv, AccessFlags.isStatic(access), desc); } @Override