src/jdk.internal.vm.compiler/share/classes/org.graalvm.graphio/src/org/graalvm/graphio/GraphProtocol.java
author dlong
Wed, 11 Oct 2017 17:11:28 -0700
changeset 47667 390896759aa2
parent 47216 71c04702a3d5
child 47798 9fe9292f5931
permissions -rw-r--r--
8187438: Update Graal Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46762
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     1
/*
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     2
 * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     4
 *
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     7
 * published by the Free Software Foundation.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     8
 *
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    13
 * accompanied this code).
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    14
 *
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    18
 *
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    21
 * questions.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    22
 */
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    23
package org.graalvm.graphio;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    24
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    25
import java.io.Closeable;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    26
import java.io.IOException;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    27
import java.nio.ByteBuffer;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    28
import java.nio.channels.WritableByteChannel;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    29
import java.nio.charset.Charset;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    30
import java.util.Collection;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    31
import java.util.HashMap;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    32
import java.util.LinkedHashMap;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    33
import java.util.LinkedList;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    34
import java.util.Map;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    35
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    36
abstract class GraphProtocol<Graph, Node, NodeClass, Edges, Block, ResolvedJavaMethod, ResolvedJavaField, Signature, NodeSourcePosition> implements Closeable {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    37
    private static final Charset UTF8 = Charset.forName("UTF-8");
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    38
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    39
    private static final int CONSTANT_POOL_MAX_SIZE = 8000;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    40
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    41
    private static final int BEGIN_GROUP = 0x00;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    42
    private static final int BEGIN_GRAPH = 0x01;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    43
    private static final int CLOSE_GROUP = 0x02;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    44
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    45
    private static final int POOL_NEW = 0x00;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    46
    private static final int POOL_STRING = 0x01;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    47
    private static final int POOL_ENUM = 0x02;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    48
    private static final int POOL_CLASS = 0x03;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    49
    private static final int POOL_METHOD = 0x04;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    50
    private static final int POOL_NULL = 0x05;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    51
    private static final int POOL_NODE_CLASS = 0x06;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    52
    private static final int POOL_FIELD = 0x07;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    53
    private static final int POOL_SIGNATURE = 0x08;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    54
    private static final int POOL_NODE_SOURCE_POSITION = 0x09;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    55
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    56
    private static final int PROPERTY_POOL = 0x00;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    57
    private static final int PROPERTY_INT = 0x01;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    58
    private static final int PROPERTY_LONG = 0x02;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    59
    private static final int PROPERTY_DOUBLE = 0x03;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    60
    private static final int PROPERTY_FLOAT = 0x04;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    61
    private static final int PROPERTY_TRUE = 0x05;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    62
    private static final int PROPERTY_FALSE = 0x06;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    63
    private static final int PROPERTY_ARRAY = 0x07;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    64
    private static final int PROPERTY_SUBGRAPH = 0x08;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    65
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    66
    private static final int KLASS = 0x00;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    67
    private static final int ENUM_KLASS = 0x01;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    68
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    69
    private static final byte[] MAGIC_BYTES = {'B', 'I', 'G', 'V'};
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    70
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    71
    private final ConstantPool constantPool;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    72
    private final ByteBuffer buffer;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    73
    private final WritableByteChannel channel;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    74
    private final int versionMajor;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    75
    private final int versionMinor;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    76
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    77
    protected GraphProtocol(WritableByteChannel channel) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    78
        this(channel, 4, 0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    79
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    80
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    81
    private GraphProtocol(WritableByteChannel channel, int major, int minor) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    82
        if (major > 4) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    83
            throw new IllegalArgumentException();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    84
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    85
        if (major == 4 && minor > 0) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    86
            throw new IllegalArgumentException();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    87
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    88
        this.versionMajor = major;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    89
        this.versionMinor = minor;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    90
        this.constantPool = new ConstantPool();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    91
        this.buffer = ByteBuffer.allocateDirect(256 * 1024);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    92
        this.channel = channel;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    93
        writeVersion();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    94
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    95
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    96
    @SuppressWarnings("all")
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    97
    public final void print(Graph graph, Map<? extends Object, ? extends Object> properties, int id, String format, Object... args) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    98
        writeByte(BEGIN_GRAPH);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
    99
        if (versionMajor >= 3) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   100
            writeInt(id);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   101
            writeString(format);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   102
            writeInt(args.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   103
            for (Object a : args) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   104
                writePropertyObject(graph, a);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   105
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   106
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   107
            writePoolObject(formatTitle(graph, id, format, args));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   108
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   109
        writeGraph(graph, properties);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   110
        flush();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   111
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   112
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   113
    public final void beginGroup(Graph noGraph, String name, String shortName, ResolvedJavaMethod method, int bci, Map<? extends Object, ? extends Object> properties) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   114
        writeByte(BEGIN_GROUP);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   115
        writePoolObject(name);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   116
        writePoolObject(shortName);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   117
        writePoolObject(method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   118
        writeInt(bci);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   119
        writeProperties(noGraph, properties);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   120
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   121
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   122
    public final void endGroup() throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   123
        writeByte(CLOSE_GROUP);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   124
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   125
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   126
    @Override
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   127
    public final void close() {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   128
        try {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   129
            flush();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   130
            channel.close();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   131
        } catch (IOException ex) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   132
            throw new Error(ex);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   133
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   134
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   135
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   136
    protected abstract Graph findGraph(Graph current, Object obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   137
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   138
    protected abstract ResolvedJavaMethod findMethod(Object obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   139
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   140
    protected abstract NodeClass findNodeClass(Object obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   141
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   142
    /**
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   143
     * Find a Java class. The returned object must be acceptable by
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   144
     * {@link #findJavaTypeName(java.lang.Object)} and return valid name for the class.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   145
     *
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   146
     * @param clazz node class object
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   147
     * @return object representing the class, for example {@link Class}
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   148
     */
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   149
    protected abstract Object findJavaClass(NodeClass clazz);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   150
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   151
    protected abstract Object findEnumClass(Object enumValue);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   152
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   153
    protected abstract String findNameTemplate(NodeClass clazz);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   154
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   155
    protected abstract Edges findClassEdges(NodeClass nodeClass, boolean dumpInputs);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   156
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   157
    protected abstract int findNodeId(Node n);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   158
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   159
    protected abstract void findExtraNodes(Node node, Collection<? super Node> extraNodes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   160
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   161
    protected abstract boolean hasPredecessor(Node node);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   162
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   163
    protected abstract int findNodesCount(Graph info);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   164
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   165
    protected abstract Iterable<? extends Node> findNodes(Graph info);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   166
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   167
    protected abstract void findNodeProperties(Node node, Map<String, Object> props, Graph info);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   168
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   169
    protected abstract Collection<? extends Node> findBlockNodes(Graph info, Block block);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   170
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   171
    protected abstract int findBlockId(Block sux);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   172
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   173
    protected abstract Collection<? extends Block> findBlocks(Graph graph);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   174
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   175
    protected abstract Collection<? extends Block> findBlockSuccessors(Block block);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   176
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   177
    protected abstract String formatTitle(Graph graph, int id, String format, Object... args);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   178
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   179
    protected abstract int findSize(Edges edges);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   180
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   181
    protected abstract boolean isDirect(Edges edges, int i);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   182
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   183
    protected abstract String findName(Edges edges, int i);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   184
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   185
    protected abstract Object findType(Edges edges, int i);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   186
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   187
    protected abstract Collection<? extends Node> findNodes(Graph graph, Node node, Edges edges, int i);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   188
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   189
    protected abstract int findEnumOrdinal(Object obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   190
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   191
    protected abstract String[] findEnumTypeValues(Object clazz);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   192
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   193
    protected abstract String findJavaTypeName(Object obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   194
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   195
    protected abstract byte[] findMethodCode(ResolvedJavaMethod method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   196
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   197
    protected abstract int findMethodModifiers(ResolvedJavaMethod method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   198
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   199
    protected abstract Signature findMethodSignature(ResolvedJavaMethod method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   200
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   201
    protected abstract String findMethodName(ResolvedJavaMethod method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   202
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   203
    protected abstract Object findMethodDeclaringClass(ResolvedJavaMethod method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   204
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   205
    protected abstract int findFieldModifiers(ResolvedJavaField field);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   206
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   207
    protected abstract String findFieldTypeName(ResolvedJavaField field);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   208
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   209
    protected abstract String findFieldName(ResolvedJavaField field);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   210
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   211
    protected abstract Object findFieldDeclaringClass(ResolvedJavaField field);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   212
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   213
    protected abstract ResolvedJavaField findJavaField(Object object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   214
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   215
    protected abstract Signature findSignature(Object object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   216
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   217
    protected abstract int findSignatureParameterCount(Signature signature);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   218
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   219
    protected abstract String findSignatureParameterTypeName(Signature signature, int index);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   220
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   221
    protected abstract String findSignatureReturnTypeName(Signature signature);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   222
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   223
    protected abstract NodeSourcePosition findNodeSourcePosition(Object object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   224
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   225
    protected abstract ResolvedJavaMethod findNodeSourcePositionMethod(NodeSourcePosition pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   226
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   227
    protected abstract NodeSourcePosition findNodeSourcePositionCaller(NodeSourcePosition pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   228
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   229
    protected abstract int findNodeSourcePositionBCI(NodeSourcePosition pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   230
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   231
    protected abstract StackTraceElement findMethodStackTraceElement(ResolvedJavaMethod method, int bci, NodeSourcePosition pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   232
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   233
    private void writeVersion() throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   234
        writeBytesRaw(MAGIC_BYTES);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   235
        writeByte(versionMajor);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   236
        writeByte(versionMinor);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   237
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   238
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   239
    private void flush() throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   240
        buffer.flip();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   241
        /*
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   242
         * Try not to let interrupted threads aborting the write. There's still a race here but an
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   243
         * interrupt that's been pending for a long time shouldn't stop this writing.
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   244
         */
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   245
        boolean interrupted = Thread.interrupted();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   246
        try {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   247
            channel.write(buffer);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   248
        } finally {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   249
            if (interrupted) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   250
                Thread.currentThread().interrupt();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   251
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   252
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   253
        buffer.compact();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   254
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   255
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   256
    private void ensureAvailable(int i) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   257
        assert buffer.capacity() >= i : "Can not make " + i + " bytes available, buffer is too small";
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   258
        while (buffer.remaining() < i) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   259
            flush();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   260
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   261
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   262
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   263
    private void writeByte(int b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   264
        ensureAvailable(1);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   265
        buffer.put((byte) b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   266
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   267
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   268
    private void writeInt(int b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   269
        ensureAvailable(4);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   270
        buffer.putInt(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   271
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   272
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   273
    private void writeLong(long b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   274
        ensureAvailable(8);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   275
        buffer.putLong(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   276
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   277
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   278
    private void writeDouble(double b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   279
        ensureAvailable(8);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   280
        buffer.putDouble(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   281
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   282
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   283
    private void writeFloat(float b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   284
        ensureAvailable(4);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   285
        buffer.putFloat(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   286
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   287
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   288
    private void writeShort(char b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   289
        ensureAvailable(2);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   290
        buffer.putChar(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   291
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   292
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   293
    private void writeString(String str) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   294
        byte[] bytes = str.getBytes(UTF8);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   295
        writeBytes(bytes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   296
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   297
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   298
    private void writeBytes(byte[] b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   299
        if (b == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   300
            writeInt(-1);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   301
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   302
            writeInt(b.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   303
            writeBytesRaw(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   304
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   305
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   306
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   307
    private void writeBytesRaw(byte[] b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   308
        int bytesWritten = 0;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   309
        while (bytesWritten < b.length) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   310
            int toWrite = Math.min(b.length - bytesWritten, buffer.capacity());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   311
            ensureAvailable(toWrite);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   312
            buffer.put(b, bytesWritten, toWrite);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   313
            bytesWritten += toWrite;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   314
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   315
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   316
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   317
    private void writeInts(int[] b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   318
        if (b == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   319
            writeInt(-1);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   320
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   321
            writeInt(b.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   322
            int sizeInBytes = b.length * 4;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   323
            ensureAvailable(sizeInBytes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   324
            buffer.asIntBuffer().put(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   325
            buffer.position(buffer.position() + sizeInBytes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   326
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   327
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   328
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   329
    private void writeDoubles(double[] b) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   330
        if (b == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   331
            writeInt(-1);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   332
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   333
            writeInt(b.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   334
            int sizeInBytes = b.length * 8;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   335
            ensureAvailable(sizeInBytes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   336
            buffer.asDoubleBuffer().put(b);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   337
            buffer.position(buffer.position() + sizeInBytes);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   338
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   339
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   340
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   341
    private void writePoolObject(Object object) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   342
        if (object == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   343
            writeByte(POOL_NULL);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   344
            return;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   345
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   346
        Character id = constantPool.get(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   347
        if (id == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   348
            addPoolEntry(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   349
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   350
            if (object instanceof Enum<?> || findEnumOrdinal(object) >= 0) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   351
                writeByte(POOL_ENUM);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   352
            } else if (object instanceof Class<?> || findJavaTypeName(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   353
                writeByte(POOL_CLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   354
            } else if (findJavaField(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   355
                writeByte(POOL_FIELD);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   356
            } else if (findSignature(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   357
                writeByte(POOL_SIGNATURE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   358
            } else if (versionMajor >= 4 && findNodeSourcePosition(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   359
                writeByte(POOL_NODE_SOURCE_POSITION);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   360
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   361
                if (findNodeClass(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   362
                    writeByte(POOL_NODE_CLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   363
                } else if (findMethod(object) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   364
                    writeByte(POOL_METHOD);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   365
                } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   366
                    writeByte(POOL_STRING);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   367
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   368
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   369
            writeShort(id.charValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   370
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   371
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   372
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   373
    private void writeGraph(Graph graph, Map<? extends Object, ? extends Object> properties) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   374
        writeProperties(graph, properties);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   375
        writeNodes(graph);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   376
        writeBlocks(findBlocks(graph), graph);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   377
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   378
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   379
    private void writeNodes(Graph info) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   380
        Map<String, Object> props = new HashMap<>();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   381
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   382
        final int size = findNodesCount(info);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   383
        writeInt(size);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   384
        int cnt = 0;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   385
        for (Node node : findNodes(info)) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   386
            NodeClass nodeClass = findNodeClass(node);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   387
            if (nodeClass == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   388
                throw new IOException("No class for " + node);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   389
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   390
            findNodeProperties(node, props, info);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   391
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   392
            writeInt(findNodeId(node));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   393
            writePoolObject(nodeClass);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   394
            writeByte(hasPredecessor(node) ? 1 : 0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   395
            writeProperties(info, props);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   396
            writeEdges(info, node, true);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   397
            writeEdges(info, node, false);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   398
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   399
            props.clear();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   400
            cnt++;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   401
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   402
        if (size != cnt) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   403
            throw new IOException("Expecting " + size + " nodes, but found " + cnt);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   404
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   405
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   406
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   407
    private void writeEdges(Graph graph, Node node, boolean dumpInputs) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   408
        NodeClass clazz = findNodeClass(node);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   409
        Edges edges = findClassEdges(clazz, dumpInputs);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   410
        int size = findSize(edges);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   411
        for (int i = 0; i < size; i++) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   412
            Collection<? extends Node> list = findNodes(graph, node, edges, i);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   413
            if (isDirect(edges, i)) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   414
                if (list != null && list.size() != 1) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   415
                    throw new IOException("Edge " + i + " in " + edges + " is direct, but list isn't singleton: " + list);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   416
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   417
                Node n = null;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   418
                if (list != null && !list.isEmpty()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   419
                    n = list.iterator().next();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   420
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   421
                writeNodeRef(n);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   422
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   423
                if (list == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   424
                    writeShort((char) 0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   425
                } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   426
                    int listSize = list.size();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   427
                    assert listSize == ((char) listSize);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   428
                    writeShort((char) listSize);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   429
                    for (Node edge : list) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   430
                        writeNodeRef(edge);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   431
                    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   432
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   433
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   434
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   435
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   436
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   437
    private void writeNodeRef(Node node) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   438
        writeInt(findNodeId(node));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   439
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   440
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   441
    private void writeBlocks(Collection<? extends Block> blocks, Graph info) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   442
        if (blocks != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   443
            for (Block block : blocks) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   444
                Collection<? extends Node> nodes = findBlockNodes(info, block);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   445
                if (nodes == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   446
                    writeInt(0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   447
                    return;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   448
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   449
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   450
            writeInt(blocks.size());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   451
            for (Block block : blocks) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   452
                Collection<? extends Node> nodes = findBlockNodes(info, block);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   453
                writeInt(findBlockId(block));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   454
                writeInt(nodes.size());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   455
                for (Node node : nodes) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   456
                    writeInt(findNodeId(node));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   457
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   458
                final Collection<? extends Block> successors = findBlockSuccessors(block);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   459
                writeInt(successors.size());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   460
                for (Block sux : successors) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   461
                    writeInt(findBlockId(sux));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   462
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   463
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   464
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   465
            writeInt(0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   466
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   467
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   468
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   469
    private void writeEdgesInfo(NodeClass nodeClass, boolean dumpInputs) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   470
        Edges edges = findClassEdges(nodeClass, dumpInputs);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   471
        int size = findSize(edges);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   472
        writeShort((char) size);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   473
        for (int i = 0; i < size; i++) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   474
            writeByte(isDirect(edges, i) ? 0 : 1);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   475
            writePoolObject(findName(edges, i));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   476
            if (dumpInputs) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   477
                writePoolObject(findType(edges, i));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   478
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   479
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   480
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   481
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   482
    @SuppressWarnings("all")
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   483
    private void addPoolEntry(Object object) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   484
        ResolvedJavaField field;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   485
        String typeName;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   486
        Signature signature;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   487
        NodeSourcePosition pos;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   488
        int enumOrdinal;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   489
        char index = constantPool.add(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   490
        writeByte(POOL_NEW);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   491
        writeShort(index);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   492
        if ((typeName = findJavaTypeName(object)) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   493
            writeByte(POOL_CLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   494
            writeString(typeName);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   495
            String[] enumValueNames = findEnumTypeValues(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   496
            if (enumValueNames != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   497
                writeByte(ENUM_KLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   498
                writeInt(enumValueNames.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   499
                for (String o : enumValueNames) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   500
                    writePoolObject(o);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   501
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   502
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   503
                writeByte(KLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   504
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   505
        } else if ((enumOrdinal = findEnumOrdinal(object)) >= 0) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   506
            writeByte(POOL_ENUM);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   507
            writePoolObject(findEnumClass(object));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   508
            writeInt(enumOrdinal);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   509
        } else if ((field = findJavaField(object)) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   510
            writeByte(POOL_FIELD);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   511
            writePoolObject(findFieldDeclaringClass(field));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   512
            writePoolObject(findFieldName(field));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   513
            writePoolObject(findFieldTypeName(field));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   514
            writeInt(findFieldModifiers(field));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   515
        } else if ((signature = findSignature(object)) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   516
            writeByte(POOL_SIGNATURE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   517
            int args = findSignatureParameterCount(signature);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   518
            writeShort((char) args);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   519
            for (int i = 0; i < args; i++) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   520
                writePoolObject(findSignatureParameterTypeName(signature, i));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   521
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   522
            writePoolObject(findSignatureReturnTypeName(signature));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   523
        } else if (versionMajor >= 4 && (pos = findNodeSourcePosition(object)) != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   524
            writeByte(POOL_NODE_SOURCE_POSITION);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   525
            ResolvedJavaMethod method = findNodeSourcePositionMethod(pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   526
            writePoolObject(method);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   527
            final int bci = findNodeSourcePositionBCI(pos);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   528
            writeInt(bci);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   529
            StackTraceElement ste = findMethodStackTraceElement(method, bci, pos);
47667
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   530
            if (ste != null && ste.getFileName() != null) {
46762
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   531
                writePoolObject(ste.getFileName());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   532
                writeInt(ste.getLineNumber());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   533
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   534
                writePoolObject(null);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   535
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   536
            writePoolObject(findNodeSourcePositionCaller(pos));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   537
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   538
            NodeClass nodeClass = findNodeClass(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   539
            if (nodeClass != null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   540
                writeByte(POOL_NODE_CLASS);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   541
                final Object clazz = findJavaClass(nodeClass);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   542
                if (versionMajor >= 3) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   543
                    writePoolObject(clazz);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   544
                    writeString(findNameTemplate(nodeClass));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   545
                } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   546
                    writeString(((Class<?>) clazz).getSimpleName());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   547
                    String nameTemplate = findNameTemplate(nodeClass);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   548
                    writeString(nameTemplate);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   549
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   550
                writeEdgesInfo(nodeClass, true);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   551
                writeEdgesInfo(nodeClass, false);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   552
                return;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   553
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   554
            ResolvedJavaMethod method = findMethod(object);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   555
            if (method == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   556
                writeByte(POOL_STRING);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   557
                writeString(object.toString());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   558
                return;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   559
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   560
            writeByte(POOL_METHOD);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   561
            writePoolObject(findMethodDeclaringClass(method));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   562
            writePoolObject(findMethodName(method));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   563
            writePoolObject(findMethodSignature(method));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   564
            writeInt(findMethodModifiers(method));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   565
            writeBytes(findMethodCode(method));
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   566
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   567
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   568
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   569
    private void writePropertyObject(Graph graph, Object obj) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   570
        if (obj instanceof Integer) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   571
            writeByte(PROPERTY_INT);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   572
            writeInt(((Integer) obj).intValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   573
        } else if (obj instanceof Long) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   574
            writeByte(PROPERTY_LONG);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   575
            writeLong(((Long) obj).longValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   576
        } else if (obj instanceof Double) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   577
            writeByte(PROPERTY_DOUBLE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   578
            writeDouble(((Double) obj).doubleValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   579
        } else if (obj instanceof Float) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   580
            writeByte(PROPERTY_FLOAT);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   581
            writeFloat(((Float) obj).floatValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   582
        } else if (obj instanceof Boolean) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   583
            if (((Boolean) obj).booleanValue()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   584
                writeByte(PROPERTY_TRUE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   585
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   586
                writeByte(PROPERTY_FALSE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   587
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   588
        } else if (obj != null && obj.getClass().isArray()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   589
            Class<?> componentType = obj.getClass().getComponentType();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   590
            if (componentType.isPrimitive()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   591
                if (componentType == Double.TYPE) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   592
                    writeByte(PROPERTY_ARRAY);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   593
                    writeByte(PROPERTY_DOUBLE);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   594
                    writeDoubles((double[]) obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   595
                } else if (componentType == Integer.TYPE) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   596
                    writeByte(PROPERTY_ARRAY);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   597
                    writeByte(PROPERTY_INT);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   598
                    writeInts((int[]) obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   599
                } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   600
                    writeByte(PROPERTY_POOL);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   601
                    writePoolObject(obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   602
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   603
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   604
                writeByte(PROPERTY_ARRAY);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   605
                writeByte(PROPERTY_POOL);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   606
                Object[] array = (Object[]) obj;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   607
                writeInt(array.length);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   608
                for (Object o : array) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   609
                    writePoolObject(o);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   610
                }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   611
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   612
        } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   613
            Graph g = findGraph(graph, obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   614
            if (g == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   615
                writeByte(PROPERTY_POOL);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   616
                writePoolObject(obj);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   617
            } else {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   618
                writeByte(PROPERTY_SUBGRAPH);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   619
                writeGraph(g, null);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   620
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   621
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   622
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   623
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   624
    private void writeProperties(Graph graph, Map<? extends Object, ? extends Object> props) throws IOException {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   625
        if (props == null) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   626
            writeShort((char) 0);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   627
            return;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   628
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   629
        final int size = props.size();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   630
        // properties
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   631
        writeShort((char) size);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   632
        int cnt = 0;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   633
        for (Map.Entry<? extends Object, ? extends Object> entry : props.entrySet()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   634
            String key = entry.getKey().toString();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   635
            writePoolObject(key);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   636
            writePropertyObject(graph, entry.getValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   637
            cnt++;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   638
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   639
        if (size != cnt) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   640
            throw new IOException("Expecting " + size + " properties, but found only " + cnt);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   641
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   642
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   643
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   644
    private static final class ConstantPool extends LinkedHashMap<Object, Character> {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   645
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   646
        private final LinkedList<Character> availableIds;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   647
        private char nextId;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   648
        private static final long serialVersionUID = -2676889957907285681L;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   649
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   650
        ConstantPool() {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   651
            super(50, 0.65f);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   652
            availableIds = new LinkedList<>();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   653
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   654
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   655
        @Override
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   656
        protected boolean removeEldestEntry(java.util.Map.Entry<Object, Character> eldest) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   657
            if (size() > CONSTANT_POOL_MAX_SIZE) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   658
                availableIds.addFirst(eldest.getValue());
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   659
                return true;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   660
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   661
            return false;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   662
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   663
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   664
        private Character nextAvailableId() {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   665
            if (!availableIds.isEmpty()) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   666
                return availableIds.removeFirst();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   667
            }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   668
            return nextId++;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   669
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   670
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   671
        public char add(Object obj) {
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   672
            Character id = nextAvailableId();
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   673
            put(obj, id);
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   674
            return id;
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   675
        }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   676
    }
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   677
f7defa99f173 8185829: Update Graal
dlong
parents:
diff changeset
   678
}