1 /* 2 * Javassist, a Java-bytecode translator toolkit. 3 * Copyright (C) 1999-2007 Shigeru Chiba. All Rights Reserved. 4 * 5 * The contents of this file are subject to the Mozilla Public License Version 6 * 1.1 (the "License"); you may not use this file except in compliance with 7 * the License. Alternatively, the contents of this file may be used under 8 * the terms of the GNU Lesser General Public License Version 2.1 or later. 9 * 10 * Software distributed under the License is distributed on an "AS IS" basis, 11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 12 * for the specific language governing rights and limitations under the 13 * License. 14 */ 15 16 package javassist.compiler.ast; 17 18 import javassist.compiler.CompileError; 19 20 /** 21 * A node of a a binary tree. This class provides concrete methods 22 * overriding abstract methods in ASTree. 23 */ 24 public class Pair extends ASTree { 25 protected ASTree left, right; 26 Pair(ASTree _left, ASTree _right)27 public Pair(ASTree _left, ASTree _right) { 28 left = _left; 29 right = _right; 30 } 31 accept(Visitor v)32 public void accept(Visitor v) throws CompileError { v.atPair(this); } 33 toString()34 public String toString() { 35 StringBuffer sbuf = new StringBuffer(); 36 sbuf.append("(<Pair> "); 37 sbuf.append(left == null ? "<null>" : left.toString()); 38 sbuf.append(" . "); 39 sbuf.append(right == null ? "<null>" : right.toString()); 40 sbuf.append(')'); 41 return sbuf.toString(); 42 } 43 getLeft()44 public ASTree getLeft() { return left; } 45 getRight()46 public ASTree getRight() { return right; } 47 setLeft(ASTree _left)48 public void setLeft(ASTree _left) { left = _left; } 49 setRight(ASTree _right)50 public void setRight(ASTree _right) { right = _right; } 51 } 52