nashorn/src/jdk/nashorn/internal/codegen/WeighNodes.java
author jlaskey
Fri, 21 Dec 2012 16:36:24 -0400
changeset 16147 e63b63819133
child 16151 97c1e756ae1e
permissions -rw-r--r--
8005403: Open-source Nashorn Reviewed-by: attila, hannesw, lagergren, sundar Contributed-by: james.laskey@oracle.com, akhil.arora@oracle.com, andreas.woess@jku.at, attila.szegedi@oracle.com, hannes.wallnoefer@oracle.com, henry.jen@oracle.com, marcus.lagergren@oracle.com, pavel.semenov@oracle.com, pavel.stepanov@oracle.com, petr.hejl@oracle.com, petr.pisl@oracle.com, sundararajan.athijegannathan@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     1
/*
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     2
 * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     4
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    10
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    15
 * accompanied this code).
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    16
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    20
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    23
 * questions.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    24
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    25
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    26
package jdk.nashorn.internal.codegen;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    27
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    28
import java.util.List;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    29
import java.util.Map;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    30
import jdk.nashorn.internal.ir.AccessNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    31
import jdk.nashorn.internal.ir.BinaryNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    32
import jdk.nashorn.internal.ir.Block;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    33
import jdk.nashorn.internal.ir.BreakNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    34
import jdk.nashorn.internal.ir.CallNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    35
import jdk.nashorn.internal.ir.CatchNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    36
import jdk.nashorn.internal.ir.ContinueNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    37
import jdk.nashorn.internal.ir.DoWhileNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    38
import jdk.nashorn.internal.ir.ExecuteNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    39
import jdk.nashorn.internal.ir.ForNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    40
import jdk.nashorn.internal.ir.FunctionNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    41
import jdk.nashorn.internal.ir.IdentNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    42
import jdk.nashorn.internal.ir.IfNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    43
import jdk.nashorn.internal.ir.IndexNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    44
import jdk.nashorn.internal.ir.LiteralNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    45
import jdk.nashorn.internal.ir.LiteralNode.ArrayLiteralNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    46
import jdk.nashorn.internal.ir.LiteralNode.ArrayLiteralNode.ArrayUnit;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    47
import jdk.nashorn.internal.ir.Node;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    48
import jdk.nashorn.internal.ir.PropertyNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    49
import jdk.nashorn.internal.ir.ReferenceNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    50
import jdk.nashorn.internal.ir.ReturnNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    51
import jdk.nashorn.internal.ir.RuntimeNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    52
import jdk.nashorn.internal.ir.SplitNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    53
import jdk.nashorn.internal.ir.SwitchNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    54
import jdk.nashorn.internal.ir.ThrowNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    55
import jdk.nashorn.internal.ir.TryNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    56
import jdk.nashorn.internal.ir.VarNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    57
import jdk.nashorn.internal.ir.WhileNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    58
import jdk.nashorn.internal.ir.WithNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    59
import jdk.nashorn.internal.ir.visitor.NodeVisitor;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    60
import jdk.nashorn.internal.parser.TokenType;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    61
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    62
/**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    63
 * Computes the "byte code" weight of an AST segment. This is used
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    64
 * for Splitting too large class files
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    65
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    66
public class WeighNodes extends NodeVisitor {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    67
    /*
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    68
     * Weight constants.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    69
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    70
            static final long FUNCTION_WEIGHT  = 40;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    71
    private static final long ACCESS_WEIGHT    = 4;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    72
    private static final long ADD_WEIGHT       = 10;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    73
    private static final long BREAK_WEIGHT     = 1;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    74
    private static final long CALL_WEIGHT      = 10;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    75
    private static final long CATCH_WEIGHT     = 10;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    76
    private static final long CONTINUE_WEIGHT  = 1;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    77
    private static final long IF_WEIGHT        = 2;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    78
    private static final long LITERAL_WEIGHT   = 10;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    79
    private static final long LOOP_WEIGHT      = 4;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    80
    private static final long REFERENCE_WEIGHT = 20;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    81
    private static final long RETURN_WEIGHT    = 2;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    82
    private static final long SPLIT_WEIGHT     = 40;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    83
    private static final long SWITCH_WEIGHT    = 8;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    84
    private static final long THROW_WEIGHT     = 2;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    85
    private static final long VAR_WEIGHT       = 40;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    86
    private static final long WITH_WEIGHT      = 8;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    87
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    88
    /** Accumulated weight. */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    89
    private long weight;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    90
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    91
    /** Optional cache for weight of block nodes. */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    92
    private final Map<Node, Long> weightCache;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    93
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    94
    /*
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    95
     * Constructor
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    96
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    97
     * @param weightCache cache of already calculated block weights
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    98
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    99
    private WeighNodes(final Map<Node, Long> weightCache) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   100
        super(null, null);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   101
        this.weightCache = weightCache;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   102
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   103
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   104
    static long weigh(final Node node) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   105
        final WeighNodes weighNodes = new WeighNodes(null);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   106
        node.accept(weighNodes);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   107
        return weighNodes.weight;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   108
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   109
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   110
    static long weigh(final Node node, final Map<Node, Long> weightCache) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   111
        final WeighNodes weighNodes = new WeighNodes(weightCache);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   112
        node.accept(weighNodes);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   113
        return weighNodes.weight;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   114
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   115
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   116
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   117
    public Node leave(final AccessNode accessNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   118
        weight += ACCESS_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   119
        return accessNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   120
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   121
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   122
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   123
    public Node leave(final BinaryNode binaryNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   124
        final TokenType tokenType = binaryNode.tokenType();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   125
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   126
        if (tokenType == TokenType.ADD || tokenType == TokenType.ASSIGN_ADD) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   127
            weight += ADD_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   128
        } else {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   129
            weight += 1;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   130
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   131
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   132
        return binaryNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   133
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   134
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   135
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   136
    public Node enter(final Block block) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   137
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   138
        if (weightCache != null && weightCache.containsKey(block)) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   139
            weight += weightCache.get(block);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   140
            return null;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   141
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   142
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   143
        return block;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   144
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   145
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   146
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   147
    public Node leave(final BreakNode breakNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   148
        weight += BREAK_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   149
        return breakNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   150
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   151
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   152
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   153
    public Node leave(final CallNode callNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   154
        weight += CALL_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   155
        return callNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   156
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   157
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   158
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   159
    public Node leave(final CatchNode catchNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   160
        weight += CATCH_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   161
        return catchNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   162
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   163
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   164
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   165
    public Node leave(final ContinueNode continueNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   166
        weight += CONTINUE_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   167
        return continueNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   168
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   169
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   170
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   171
    public Node leave(final DoWhileNode doWhileNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   172
        weight += LOOP_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   173
        return doWhileNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   174
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   175
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   176
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   177
    public Node leave(final ExecuteNode executeNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   178
        return executeNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   179
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   180
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   181
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   182
    public Node leave(final ForNode forNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   183
        weight += LOOP_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   184
        return forNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   185
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   186
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   187
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   188
    public Node enter(final FunctionNode functionNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   189
        final List<Node> statements = functionNode.getStatements();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   190
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   191
        for (final Node statement : statements) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   192
            statement.accept(this);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   193
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   194
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   195
        return null;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   196
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   197
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   198
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   199
    public Node leave(final IdentNode identNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   200
        weight += ACCESS_WEIGHT + identNode.getName().length() * 2;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   201
        return identNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   202
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   203
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   204
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   205
    public Node leave(final IfNode ifNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   206
        weight += IF_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   207
        return ifNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   208
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   209
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   210
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   211
    public Node leave(final IndexNode indexNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   212
        weight += ACCESS_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   213
        return indexNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   214
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   215
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   216
    @SuppressWarnings("rawtypes")
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   217
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   218
    public Node enter(final LiteralNode literalNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   219
        weight += LITERAL_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   220
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   221
        if (literalNode instanceof ArrayLiteralNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   222
            final ArrayLiteralNode arrayLiteralNode = (ArrayLiteralNode)literalNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   223
            final Node[]           value            = arrayLiteralNode.getValue();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   224
            final int[]            postsets         = arrayLiteralNode.getPostsets();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   225
            final List<ArrayUnit>  units            = arrayLiteralNode.getUnits();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   226
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   227
            if (units == null) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   228
                for (final int postset : postsets) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   229
                    final Node element = value[postset];
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   230
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   231
                    if (element != null) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   232
                        element.accept(this);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   233
                    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   234
                }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   235
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   236
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   237
            return null;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   238
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   239
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   240
        return literalNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   241
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   242
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   243
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   244
    public Node leave(final PropertyNode propertyNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   245
        weight += LITERAL_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   246
        return propertyNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   247
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   248
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   249
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   250
    public Node leave(final ReferenceNode referenceNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   251
        weight += REFERENCE_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   252
        return referenceNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   253
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   254
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   255
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   256
    public Node leave(final ReturnNode returnNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   257
        weight += RETURN_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   258
        return returnNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   259
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   260
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   261
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   262
    public Node leave(final RuntimeNode runtimeNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   263
        weight += CALL_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   264
        return runtimeNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   265
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   266
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   267
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   268
    public Node enter(final SplitNode splitNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   269
        weight += SPLIT_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   270
        return null;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   271
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   272
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   273
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   274
    public Node leave(final SwitchNode switchNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   275
        weight += SWITCH_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   276
        return switchNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   277
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   278
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   279
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   280
    public Node leave(final ThrowNode throwNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   281
        weight += THROW_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   282
        return throwNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   283
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   284
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   285
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   286
    public Node leave(final TryNode tryNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   287
        weight += THROW_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   288
        return tryNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   289
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   290
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   291
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   292
    public Node leave(final VarNode varNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   293
        weight += VAR_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   294
        return varNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   295
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   296
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   297
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   298
    public Node leave(final WhileNode whileNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   299
        weight += LOOP_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   300
        return whileNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   301
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   302
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   303
    @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   304
    public Node leave(final WithNode withNode) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   305
        weight += WITH_WEIGHT;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   306
        return withNode;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   307
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   308
}