Mercurial > hg > graal-jvmci-8
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 |
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 } |