Mercurial > hg > truffle
annotate truffle/com.oracle.truffle.sl/src/com/oracle/truffle/sl/nodes/controlflow/SLRepeatingNode.java @ 22065:503529c65456
Remove trailing whitespace from UPL license
author | Tom Rodriguez <tom.rodriguez@oracle.com> |
---|---|
date | Wed, 05 Aug 2015 10:19:41 -0700 |
parents | c07e64ecb528 |
children | dc83cc1f94f2 |
rev | line source |
---|---|
16917
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
1 /* |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
2 * Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
4 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
5 * The Universal Permissive License (UPL), Version 1.0 |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
6 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
7 * Subject to the condition set forth below, permission is hereby granted to any |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
8 * person obtaining a copy of this software, associated documentation and/or |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
9 * data (collectively the "Software"), free of charge and under any and all |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
10 * copyright rights in the Software, and any and all patent rights owned or |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
11 * freely licensable by each licensor hereunder covering either (i) the |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
12 * unmodified Software as contributed to or provided by such licensor, or (ii) |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
13 * the Larger Works (as defined below), to deal in both |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
14 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
15 * (a) the Software, and |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
16 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
17 * (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
18 * one is included with the Software each a "Larger Work" to which the Software |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
19 * is contributed by such licensors), |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
20 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
21 * without restriction, including without limitation the rights to copy, create |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
22 * derivative works of, display, perform, and distribute the Software and make, |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
23 * use, sell, offer for sale, import, export, have made, and have sold the |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
24 * Software and the Larger Work(s), and to sublicense the foregoing rights on |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
25 * either these or other terms. |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
26 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
27 * This license is subject to the following condition: |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
28 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
29 * The above copyright notice and either this complete permission notice or at a |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
30 * minimum a reference to the UPL must be included in all copies or substantial |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
31 * portions of the Software. |
22065
503529c65456
Remove trailing whitespace from UPL license
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
21997
diff
changeset
|
32 * |
21997
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
33 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
34 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
35 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
36 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
37 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
38 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
c07e64ecb528
Update SL copyright headers to use UPL
Gilles Duboscq <gilles.m.duboscq@oracle.com>
parents:
21951
diff
changeset
|
39 * SOFTWARE. |
16917
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
40 */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
41 package com.oracle.truffle.sl.nodes.controlflow; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
42 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
43 import com.oracle.truffle.api.dsl.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
44 import com.oracle.truffle.api.frame.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
45 import com.oracle.truffle.api.nodes.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
46 import com.oracle.truffle.api.source.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
47 import com.oracle.truffle.api.utilities.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
48 import com.oracle.truffle.sl.nodes.*; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
49 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
50 public final class SLRepeatingNode extends Node implements RepeatingNode { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
51 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
52 /** |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
53 * The condition of the loop. This in a {@link SLExpressionNode} because we require a result |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
54 * value. We do not have a node type that can only return a {@code boolean} value, so |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
55 * {@link #evaluateCondition executing the condition} can lead to a type error. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
56 */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
57 @Child private SLExpressionNode conditionNode; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
58 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
59 /** Statement (or {@link SLBlockNode block}) executed as long as the condition is true. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
60 @Child private SLStatementNode bodyNode; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
61 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
62 /** |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
63 * Profiling information, collected by the interpreter, capturing whether a {@code continue} |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
64 * statement was used in this loop. This allows the compiler to generate better code for loops |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
65 * without a {@code continue}. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
66 */ |
17421
87ea195b66ff
Truffle: Make BranchProfile constructor private and introduce a factory Method BranchProfile.create().
Christian Humer <christian.humer@gmail.com>
parents:
16917
diff
changeset
|
67 private final BranchProfile continueTaken = BranchProfile.create(); |
87ea195b66ff
Truffle: Make BranchProfile constructor private and introduce a factory Method BranchProfile.create().
Christian Humer <christian.humer@gmail.com>
parents:
16917
diff
changeset
|
68 private final BranchProfile breakTaken = BranchProfile.create(); |
16917
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
69 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
70 public SLRepeatingNode(SourceSection src, SLExpressionNode conditionNode, SLStatementNode bodyNode) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
71 super(src); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
72 this.conditionNode = conditionNode; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
73 this.bodyNode = bodyNode; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
74 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
75 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
76 public boolean executeRepeating(VirtualFrame frame) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
77 if (evaluateCondition(frame)) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
78 try { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
79 /* Execute the loop body. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
80 bodyNode.executeVoid(frame); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
81 } catch (SLContinueException ex) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
82 /* In the interpreter, record profiling information that the loop uses continue. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
83 continueTaken.enter(); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
84 /* Fall through to next loop iteration. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
85 } catch (SLBreakException ex) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
86 /* In the interpreter, record profiling information that the loop uses break. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
87 breakTaken.enter(); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
88 /* Done executing this loop, exit method to execute statement following the loop. */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
89 return false; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
90 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
91 return true; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
92 } else { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
93 return false; |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
94 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
95 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
96 |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
97 private boolean evaluateCondition(VirtualFrame frame) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
98 try { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
99 /* |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
100 * The condition must evaluate to a boolean value, so we call the boolean-specialized |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
101 * execute method. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
102 */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
103 return (conditionNode.executeBoolean(frame)); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
104 } catch (UnexpectedResultException ex) { |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
105 /* |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
106 * The condition evaluated to a non-boolean result. This is a type error in the SL |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
107 * program. We report it with the same exception that Truffle DSL generated nodes use to |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
108 * report type errors. |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
109 */ |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
110 throw new UnsupportedSpecializationException(this, new Node[]{conditionNode}, ex.getResult()); |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
111 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
112 } |
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
113 |
20096
3844fb65016c
SL: repeating node should implement SLStatementNode for a proper toString implementation.
Christian Humer <christian.humer@gmail.com>
parents:
17421
diff
changeset
|
114 @Override |
3844fb65016c
SL: repeating node should implement SLStatementNode for a proper toString implementation.
Christian Humer <christian.humer@gmail.com>
parents:
17421
diff
changeset
|
115 public String toString() { |
3844fb65016c
SL: repeating node should implement SLStatementNode for a proper toString implementation.
Christian Humer <christian.humer@gmail.com>
parents:
17421
diff
changeset
|
116 return SLStatementNode.formatSourceSection(this); |
3844fb65016c
SL: repeating node should implement SLStatementNode for a proper toString implementation.
Christian Humer <christian.humer@gmail.com>
parents:
17421
diff
changeset
|
117 } |
3844fb65016c
SL: repeating node should implement SLStatementNode for a proper toString implementation.
Christian Humer <christian.humer@gmail.com>
parents:
17421
diff
changeset
|
118 |
16917
6af9d523222a
SL: use new LoopNode API.
Christian Humer <christian.humer@gmail.com>
parents:
diff
changeset
|
119 } |