view src/main/java/org/icedrobot/daneel/dex/MethodId.java @ 119:8c0170381072

Adapted parser interface for annotations. * dex/AnnotationsDirectory.java: Implemented annotation parameter visiting. * dex/Code.java (acceptInsns): Switched to new method description getter. * dex/DexAnnotationVisitor.java: Defined rest of the interface. * dex/EncodedValue.java (parse): Implemented for type, field and method refs. * dex/MethodId.java (getMethodDesc): Added new method description getter.
author Michael Starzinger <michi@complang.tuwien.ac.at>
date Mon, 04 Apr 2011 23:21:45 +0200
parents a166ad506192
children
line wrap: on
line source

/*
 * 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 <http://www.gnu.org/licenses/>.
 *
 * 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;

import java.nio.ByteBuffer;

import org.icedrobot.daneel.util.TypeUtil;

/**
 * A parser class capable of parsing {@code method_id_item} structures as part
 * of DEX files. Keep package-private to hide internal API.
 */
class MethodId {

    /**
     * Parses a {@code method_id_item} structure in a DEX file at the buffer's
     * current position.
     * 
     * @param buffer The byte buffer to read from.
     * @param dex The DEX file currently being parsed.
     * @return An object representing the parsed data.
     */
    public static MethodId parse(ByteBuffer buffer, DexFile dex) {
        return new MethodId(buffer, dex);
    }

    private final String className;

    private final ProtoId protoId;

    private final String name;

    private MethodId(ByteBuffer buffer, DexFile dex) {
        int classIdx = buffer.getShort();
        int protoIdx = buffer.getShort();
        int nameIdx = buffer.getInt();

        // Resolve string, type and prototype id indices.
        className = dex.getTypeDescriptor(classIdx);
        protoId = dex.getProtoId(protoIdx);
        name = dex.getString(nameIdx);
    }

    public String getClassName() {
        return className;
    }

    public ProtoId getProtoId() {
        return protoId;
    }

    public String getName() {
        return name;
    }

    /**
     * Returns the method descriptor for this method. That descriptor is
     * computed from various parts of the prototype identifier.
     * 
     * @return The method descriptor.
     */
    public String getMethodDesc() {
        return TypeUtil.convertProtoToDesc(protoId.getReturnType(), protoId
                .getParameters());
    }
}