diff graal/com.oracle.truffle.ruby.nodes/src/com/oracle/truffle/ruby/nodes/control/RescueNode.java @ 13514:0fbee3eb71f0

Ruby: import project.
author Chris Seaton <chris.seaton@oracle.com>
date Mon, 06 Jan 2014 17:12:09 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/graal/com.oracle.truffle.ruby.nodes/src/com/oracle/truffle/ruby/nodes/control/RescueNode.java	Mon Jan 06 17:12:09 2014 +0000
@@ -0,0 +1,43 @@
+/*
+ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. This
+ * code is released under a tri EPL/GPL/LGPL license. You can use it,
+ * redistribute it and/or modify it under the terms of the:
+ *
+ * Eclipse Public License version 1.0
+ * GNU General Public License version 2
+ * GNU Lesser General Public License version 2.1
+ */
+package com.oracle.truffle.ruby.nodes.control;
+
+import com.oracle.truffle.api.*;
+import com.oracle.truffle.api.frame.*;
+import com.oracle.truffle.ruby.nodes.*;
+import com.oracle.truffle.ruby.runtime.*;
+import com.oracle.truffle.ruby.runtime.objects.*;
+
+/**
+ * Base node for all nodes which may be able to rescue an exception. They have a test method
+ * {@link #canHandle} and a body to execute if that test passes.
+ */
+public abstract class RescueNode extends RubyNode {
+
+    @Child protected RubyNode body;
+
+    public RescueNode(RubyContext context, SourceSection sourceSection, RubyNode body) {
+        super(context, sourceSection);
+        this.body = adoptChild(body);
+    }
+
+    public abstract boolean canHandle(VirtualFrame frame, RubyBasicObject exception);
+
+    @Override
+    public Object execute(VirtualFrame frame) {
+        return body.execute(frame);
+    }
+
+    @Override
+    public void executeVoid(VirtualFrame frame) {
+        body.executeVoid(frame);
+    }
+
+}