/*
* This file is part of the Jikes RVM project (http://jikesrvm.org).
*
* This file is licensed to You under the Eclipse Public License (EPL);
* You may not use this file except in compliance with the License. You
* may obtain a copy of the License at
*
* http://www.opensource.org/licenses/eclipse-1.0.php
*
* See the COPYRIGHT.txt file distributed with this work for information
* regarding copyright ownership.
*/
package org.jikesrvm.compilers.opt.ir.operand;
import org.jikesrvm.classloader.TypeReference;
/**
* This operand represents the null constant.
*
* @see Operand
*/
public final class NullConstantOperand extends ConstantOperand {
/**
* Return a new operand that is semantically equivalent to <code>this</code>.
*
* @return a copy of <code>this</code>
*/
public Operand copy() {
return new NullConstantOperand();
}
/**
* Return the {@link TypeReference} of the value represented by the operand.
*
* @return TypeReference.NULL_TYPE
*/
public TypeReference getType() {
return TypeReference.NULL_TYPE;
}
/**
* Does the operand represent a value of the reference data type?
*
* @return <code>true</code>
*/
public boolean isRef() {
return true;
}
/**
* Does the operand definitely represent <code>null</code>?
*
* @return <code>true</code>
*/
public boolean isDefinitelyNull() {
return true;
}
/**
* Are two operands semantically equivalent?
*
* @param op other operand
* @return <code>true</code> if <code>this</code> and <code>op</code>
* are semantically equivalent or <code>false</code>
* if they are not.
*/
public boolean similar(Operand op) {
return op instanceof NullConstantOperand;
}
/**
* Returns the string representation of this operand.
*
* @return a string representation of this operand.
*/
public String toString() {
return "<null>";
}
}