Mercurial > hg > graal-jvmci-8
view c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/HotSpotSignature.java @ 1425:98fffb304868
tlab-allocated "new instance", invokespecial, support for static fields in COMPILER_CLASSES_DO
author | Lukas Stadler <lukas.stadler@oracle.com> |
---|---|
date | Tue, 17 Aug 2010 17:34:25 -0700 |
parents | 760213a60e8b |
children | efba53f86c4f |
line wrap: on
line source
/* * Copyright (c) 2009-2010 Sun Microsystems, Inc. All rights reserved. * * Sun Microsystems, Inc. has intellectual property rights relating to technology embodied in the product that is * described in this document. In particular, and without limitation, these intellectual property rights may include one * or more of the U.S. patents listed at http://www.sun.com/patents and one or more additional patents or pending patent * applications in the U.S. and in other countries. * * U.S. Government Rights - Commercial software. Government users are subject to the Sun Microsystems, Inc. standard * license agreement and applicable provisions of the FAR and its supplements. * * Use is subject to license terms. Sun, Sun Microsystems, the Sun logo, Java and Solaris are trademarks or registered * trademarks of Sun Microsystems, Inc. in the U.S. and other countries. All SPARC trademarks are used under license and * are trademarks or registered trademarks of SPARC International, Inc. in the U.S. and other countries. * * UNIX is a registered trademark in the U.S. and other countries, exclusively licensed through X/Open Company, Ltd. */ package com.sun.hotspot.c1x; import java.util.*; import com.sun.cri.ci.*; import com.sun.cri.ri.*; /** * Represents a method signature. * * @author Thomas Wuerthinger, Lukas Stadler */ public class HotSpotSignature implements RiSignature, CompilerObject { private final List<String> arguments = new ArrayList<String>(); private final String returnType; private final String originalString; public HotSpotSignature(String signature) { assert signature.length() > 0; this.originalString = signature; if (signature.charAt(0) == '(') { int cur = 1; while (cur < signature.length() && signature.charAt(cur) != ')') { int nextCur = parseSignature(signature, cur); arguments.add(signature.substring(cur, nextCur)); cur = nextCur; } cur++; int nextCur = parseSignature(signature, cur); returnType = signature.substring(cur, nextCur); assert nextCur == signature.length(); } else { returnType = null; } } private int parseSignature(String signature, int cur) { char first; do { first = signature.charAt(cur++); } while(first == '['); switch (first) { case 'L': while (signature.charAt(cur) != ';') cur++; cur++; break; case 'V': case 'I': case 'B': case 'C': case 'D': case 'F': case 'J': case 'S': case 'Z': break; default: assert false; } return cur; } @Override public int argumentCount(boolean withReceiver) { return arguments.size() + (withReceiver ? 1 : 0); } @Override public CiKind argumentKindAt(int index) { return CiKind.fromTypeString(arguments.get(index)); } @Override public int argumentSlots(boolean withReceiver) { int argSlots = 0; for (int i = 0; i < argumentCount(false); i++) { argSlots += argumentKindAt(i).sizeInSlots(); } return argSlots + (withReceiver ? 1 : 0); } @Override public RiType argumentTypeAt(int index, RiType accessingClass) { long accessor = 0; if (accessingClass instanceof HotSpotTypeResolved) { accessor = (Long) ((HotSpotTypeResolved) accessingClass).getVmId(); } return Compiler.getVMEntries().RiSignature_lookupType(arguments.get(index), accessor); } @Override public String asString() { return originalString; } @Override public CiKind returnKind() { return CiKind.fromTypeString(returnType); } @Override public RiType returnType(RiType accessingClass) { long accessor = 0; if (accessingClass instanceof HotSpotTypeResolved) { accessor = (Long) ((HotSpotTypeResolved) accessingClass).getVmId(); } return Compiler.getVMEntries().RiSignature_lookupType(returnType, accessor); } @Override public String toString() { return "HotSpotSignature<" + originalString + ">"; } }