blob: f684ffa8e021b89e8a481a8067f88c757357bb2c [file] [log] [blame]
//===- BinaryOp.h ---------------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MCLD_SCRIPT_BINARYOP_H_
#define MCLD_SCRIPT_BINARYOP_H_
#include "mcld/Script/Operator.h"
#include <cstddef>
namespace mcld {
class Operand;
class IntOperand;
class Module;
class TargetLDBackend;
/** \class BinaryOP
* \brief This class defines the interfaces to an binary operator token.
*/
template <Operator::Type TYPE>
class BinaryOp : public Operator {
private:
friend class Operator;
BinaryOp() : Operator(Operator::BINARY, TYPE), m_Size(0) {
m_pOperand[0] = m_pOperand[1] = NULL;
}
public:
~BinaryOp() {}
IntOperand* eval(const Module& pModule, const TargetLDBackend& pBackend);
void appendOperand(Operand* pOperand) {
m_pOperand[m_Size++] = pOperand;
if (m_Size == 2)
m_Size = 0;
}
private:
size_t m_Size;
Operand* m_pOperand[2];
};
template <>
IntOperand* BinaryOp<Operator::MUL>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::DIV>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::MOD>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::ADD>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::SUB>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::LSHIFT>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::RSHIFT>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::LT>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::LE>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::GT>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::GE>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::EQ>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::NE>::eval(const Module&, const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::BITWISE_AND>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::BITWISE_XOR>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::BITWISE_OR>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::LOGICAL_AND>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::LOGICAL_OR>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::ALIGN>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::DATA_SEGMENT_RELRO_END>::eval(
const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::MAX>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::MIN>::eval(const Module&,
const TargetLDBackend&);
template <>
IntOperand* BinaryOp<Operator::SEGMENT_START>::eval(const Module&,
const TargetLDBackend&);
} // namespace mcld
#endif // MCLD_SCRIPT_BINARYOP_H_