/* * Copyright (c) 2012, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.oracle.truffle.api.dsl.test; import static com.oracle.truffle.api.dsl.test.TestHelper.createCallTarget; import static org.junit.Assert.assertEquals; import org.junit.Test; import com.oracle.truffle.api.dsl.NodeChild; import com.oracle.truffle.api.dsl.NodeChildren; import com.oracle.truffle.api.dsl.Specialization; import com.oracle.truffle.api.dsl.test.NodeFieldTestFactory.IntFieldTestNodeFactory; import com.oracle.truffle.api.dsl.test.TypeSystemTest.ValueNode; public class NodeChildTest { @Test public void testIntField() { assertEquals(42, createCallTarget(IntFieldTestNodeFactory.create(42)).call()); } @NodeChild("child0") abstract static class Base0Node extends ValueNode { } @NodeChild(value = "child1", type = ValueNode.class) abstract static class Child0Node extends Base0Node { @Specialization int intField(int child0, int child1) { return child0 + child1; } } @NodeChildren({@NodeChild("child0")}) abstract static class Base1Node extends ValueNode { } @NodeChildren({@NodeChild(value = "child1", type = ValueNode.class)}) abstract static class Child1Node extends Base1Node { @Specialization int intField(int child0, int child1) { return child0 + child1; } } @NodeChildren({@NodeChild("child0"), @NodeChild("child1")}) abstract static class Base2Node extends ValueNode { } @ExpectError("Not enough child node declarations found. Please annotate the node class with addtional @NodeChild annotations or remove all execute methods that do not provide all evaluated values. " + "The following execute methods do not provide all evaluated values for the expected signature size 3:%") @NodeChildren({@NodeChild(value = "child2", type = ValueNode.class)}) abstract static class Child2Node extends Base1Node { @ExpectError("Method signature (int, int, int) does not match to the expected signature:%") @Specialization int intField(int child0, int child1, int child2) { return child0 + child1 + child2; } } @NodeChildren({@NodeChild(value = "receiver", type = ValueNode.class), @NodeChild(value = "arguments", type = ValueNode[].class)}) abstract static class BaseNode extends ValueNode { public abstract ValueNode getReceiver(); public abstract ValueNode[] getArguments(); } abstract static class UnaryNode extends BaseNode { @Specialization public int doIt(int value) { return value; } } abstract static class BinaryNode extends BaseNode { @Specialization public int doIt(int value0, int value1) { return value0 + value1; } } abstract static class TernaryNode extends BaseNode { @Specialization public int doIt(int value0, int value1, int value2) { return value0 + value1 + value2; } } }