annotate graal/com.oracle.truffle.sl/src/com/oracle/truffle/sl/nodes/SLStatementNode.java @ 16958:997899955e72

Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable SL/Instrumentation: SLRootNode's now store SLContext. New method added to SLStatementNode to find the root node and get its SLContext
author David Piorkowski <david.piorkowski@oracle.com>
date Tue, 26 Aug 2014 11:00:30 -0700
parents 826c172a048f
children f0c3de09f12a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
1 /*
13821
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
2 * Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved.
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
4 *
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
7 * published by the Free Software Foundation.
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
8 *
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
13 * accompanied this code).
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
14 *
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
18 *
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
21 * questions.
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
22 */
13761
7c418666c6c9 Refactoring and cleanup of Simple Language (more to come soon)
Christian Wimmer <christian.wimmer@oracle.com>
parents: 12752
diff changeset
23 package com.oracle.truffle.sl.nodes;
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
24
16914
826c172a048f SL: fixed merge problem.
Christian Humer <christian.humer@gmail.com>
parents: 16913
diff changeset
25 import java.io.*;
826c172a048f SL: fixed merge problem.
Christian Humer <christian.humer@gmail.com>
parents: 16913
diff changeset
26
13761
7c418666c6c9 Refactoring and cleanup of Simple Language (more to come soon)
Christian Wimmer <christian.wimmer@oracle.com>
parents: 12752
diff changeset
27 import com.oracle.truffle.api.frame.*;
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
28 import com.oracle.truffle.api.instrument.*;
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
29 import com.oracle.truffle.api.nodes.*;
16512
abe7128ca473 SL: upgrade source attribution
Michael Van De Vanter <michael.van.de.vanter@oracle.com>
parents: 15776
diff changeset
30 import com.oracle.truffle.api.source.*;
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
31 import com.oracle.truffle.sl.nodes.instrument.*;
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
32 import com.oracle.truffle.sl.runtime.*;
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
33
13821
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
34 /**
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
35 * The base class of all Truffle nodes for SL. All nodes (even expressions) can be used as
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
36 * statements, i.e., without returning a value. The {@link VirtualFrame} provides access to the
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
37 * local variables.
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
38 */
15776
111bf82514ca SL: adding NodeInfo.descriptions to SL statements
Christian Wirth <christian.wirth@oracle.com>
parents: 13821
diff changeset
39 @NodeInfo(language = "Simple Language", description = "The abstract base node for all statements")
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
40 public abstract class SLStatementNode extends Node implements Instrumentable {
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
41
16512
abe7128ca473 SL: upgrade source attribution
Michael Van De Vanter <michael.van.de.vanter@oracle.com>
parents: 15776
diff changeset
42 public SLStatementNode(SourceSection src) {
abe7128ca473 SL: upgrade source attribution
Michael Van De Vanter <michael.van.de.vanter@oracle.com>
parents: 15776
diff changeset
43 super(src);
abe7128ca473 SL: upgrade source attribution
Michael Van De Vanter <michael.van.de.vanter@oracle.com>
parents: 15776
diff changeset
44 }
abe7128ca473 SL: upgrade source attribution
Michael Van De Vanter <michael.van.de.vanter@oracle.com>
parents: 15776
diff changeset
45
13821
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
46 /**
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
47 * Execute this node as as statement, where no return value is necessary.
b16ec83edc73 Documentation and more refactoring of Simple Language
Christian Wimmer <christian.wimmer@oracle.com>
parents: 13761
diff changeset
48 */
13761
7c418666c6c9 Refactoring and cleanup of Simple Language (more to come soon)
Christian Wimmer <christian.wimmer@oracle.com>
parents: 12752
diff changeset
49 public abstract void executeVoid(VirtualFrame frame);
16595
618d92152d3c SL: Added support for instrumentation.
David Piorkowski <david.piorkowski@oracle.com>
parents: 16512
diff changeset
50
618d92152d3c SL: Added support for instrumentation.
David Piorkowski <david.piorkowski@oracle.com>
parents: 16512
diff changeset
51 public SLStatementNode getNonWrapperNode() {
618d92152d3c SL: Added support for instrumentation.
David Piorkowski <david.piorkowski@oracle.com>
parents: 16512
diff changeset
52 return this;
618d92152d3c SL: Added support for instrumentation.
David Piorkowski <david.piorkowski@oracle.com>
parents: 16512
diff changeset
53 }
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
54
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
55 @Override
16913
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
56 public String toString() {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
57 return formatSourceSection(this);
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
58 }
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
59
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
60 /**
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
61 * Formats a source section of a node in human readable form. If no source section could be
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
62 * found it looks up the parent hierarchy until it finds a source section. Nodes where this was
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
63 * required append a <code>'~'</code> at the end.
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
64 *
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
65 * @param node the node to format.
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
66 * @return a formatted source section string
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
67 */
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
68 private static String formatSourceSection(Node node) {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
69 if (node == null) {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
70 return "<unknown>";
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
71 }
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
72 SourceSection section = node.getSourceSection();
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
73 boolean estimated = false;
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
74 if (section == null) {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
75 section = node.getEncapsulatingSourceSection();
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
76 estimated = true;
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
77 }
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
78
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
79 if (section == null || section.getSource() == null) {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
80 return "<unknown source>";
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
81 } else {
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
82 String sourceName = new File(section.getSource().getName()).getName();
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
83 int startLine = section.getStartLine();
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
84 return String.format("%s:%d%s", sourceName, startLine, estimated ? "~" : "");
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
85 }
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
86 }
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
87
b879421229db SL: better toString for SL nodes.
Christian Humer <christian.humer@gmail.com>
parents: 16880
diff changeset
88 @Override
16958
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
89 public Probe probe() {
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
90 Node parent = getParent();
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
91
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
92 if (parent == null)
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
93 throw new IllegalStateException("Cannot probe a node without a parent");
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
94
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
95 if (parent instanceof SLStatementWrapper)
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
96 return ((SLStatementWrapper) parent).getProbe();
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
97
16958
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
98 SLStatementWrapper wrapper = new SLStatementWrapper(getRootNodeSLContext(this), this);
16880
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
99 this.replace(wrapper);
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
100 wrapper.insertChild();
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
101 return wrapper.getProbe();
7661cc464239 Truffle/Instrumentation: Added Instrumentable interface and LineLocationToSourceSections map
David Piorkowski <david.piorkowski@oracle.com>
parents: 16595
diff changeset
102 }
16958
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
103
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
104 protected SLContext getRootNodeSLContext(Node node) {
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
105 assert node != null;
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
106
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
107 if (node instanceof SLRootNode)
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
108 return ((SLRootNode) node).getSLContext();
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
109 return getRootNodeSLContext(node.getParent());
997899955e72 Instrumentation: removed ExecutionContext parameter from probe method in Instrumentable
David Piorkowski <david.piorkowski@oracle.com>
parents: 16914
diff changeset
110 }
7503
31da1716950f Updated truffle-sl for the changed operation code generation.
Christian Humer <christian.humer@gmail.com>
parents:
diff changeset
111 }