/* * MRustC - Rust Compiler * - By John Hodge (Mutabah/thePowersGang) * * mir/mir.cpp * - MIR (Middle Intermediate Representation) definitions */ #include namespace MIR { ::std::ostream& operator<<(::std::ostream& os, const Constant& v) { TU_MATCHA( (v), (e), (Int, os << (e < 0 ? "-" : "+"); os << (e < 0 ? -e : e); ), (Uint, os << e; ), (Float, os << e; ), (Bool, os << (e ? "true" : "false"); ), (Bytes, os << "["; os << ::std::hex; for(auto v : e) os << static_cast(v) << " "; os << ::std::dec; os << "]"; ), (StaticString, os << "\""; for(auto v : e) { if( ' ' <= v && v < 0x7F && v != '"' && v != '\\' ) os << v; else os << "\\u{" << FMT(::std::hex << (unsigned int)v) << "}"; } os << "\""; ), (Const, os << e.p; ), (ItemAddr, os << "&" << e; ) ) return os; } ::std::ostream& operator<<(::std::ostream& os, const LValue& x) { TU_MATCHA( (x), (e), (Variable, os << "Variable(" << e << ")"; ), (Temporary, os << "Temporary(" << e.idx << ")"; ), (Argument, os << "Argument(" << e.idx << ")"; ), (Static, os << "Static(" << e << ")"; ), (Return, os << "Return"; ), (Field, os << "Field(" << e.field_index << ", " << *e.val << ")"; ), (Deref, os << "Deref(" << *e.val << ")"; ), (Index, os << "Deref(" << *e.val << ", " << *e.idx << ")"; ), (Downcast, os << "Downcast(" << e.variant_index << ", " << *e.val << ")"; ) ) return os; } ::std::ostream& operator<<(::std::ostream& os, const RValue& x) { TU_MATCHA( (x), (e), (Use, os << "Use(" << e << ")"; ), (Constant, os << "Constant(" << e << ")"; ), (SizedArray, os << "SizedArray(" << e.val << "; " << e.count << ")"; ), (Borrow, os << "Borrow(" << e.region << ", " << e.type << ", " << e.val << ")"; ), (Cast, os << "Cast(" << e.val << " as " << e.type << ")"; ), (BinOp, os << "BinOp(" << e.val_l << " "; switch(e.op) { case ::MIR::eBinOp::ADD: os << "ADD"; break; case ::MIR::eBinOp::SUB: os << "SUB"; break; case ::MIR::eBinOp::MUL: os << "MUL"; break; case ::MIR::eBinOp::DIV: os << "DIV"; break; case ::MIR::eBinOp::MOD: os << "MOD"; break; case ::MIR::eBinOp::ADD_OV: os << "ADD_OV"; break; case ::MIR::eBinOp::SUB_OV: os << "SUB_OV"; break; case ::MIR::eBinOp::MUL_OV: os << "MUL_OV"; break; case ::MIR::eBinOp::DIV_OV: os << "DIV_OV"; break; case ::MIR::eBinOp::BIT_OR : os << "BIT_OR" ; break; case ::MIR::eBinOp::BIT_AND: os << "BIT_AND"; break; case ::MIR::eBinOp::BIT_XOR: os << "BIT_XOR"; break; case ::MIR::eBinOp::BIT_SHL: os << "BIT_SHL"; break; case ::MIR::eBinOp::BIT_SHR: os << "BIT_SHR"; break; case ::MIR::eBinOp::EQ: os << "EQ"; break; case ::MIR::eBinOp::NE: os << "NE"; break; case ::MIR::eBinOp::GT: os << "GT"; break; case ::MIR::eBinOp::GE: os << "GE"; break; case ::MIR::eBinOp::LT: os << "LT"; break; case ::MIR::eBinOp::LE: os << "LE"; break; } os << " " << e.val_r << ")"; ), (UniOp, os << "UniOp(" << e.val << " " << static_cast(e.op) << ")"; ), (DstMeta, os << "DstMeta(" << e.val << ")"; ), (DstPtr, os << "DstPtr(" << e.val << ")"; ), (MakeDst, os << "MakeDst(" << e.ptr_val << ", " << e.meta_val << ")"; ), (Tuple, os << "Tuple(" << e.vals << ")"; ), (Array, os << "Array(" << e.vals << ")"; ), (Variant, os << "Variant(" << e.path << " #" << e.index << ", " << e.val << ")"; ), (Struct, os << "Struct(" << e.path << ", {" << e.vals << "})"; ) ) return os; } ::std::ostream& operator<<(::std::ostream& os, const Terminator& x) { TU_MATCHA( (x), (e), (Incomplete, os << "Invalid"; ), (Return, os << "Return"; ), (Diverge, os << "Diverge"; ), (Goto, os << "Goto(" << e << ")"; ), (Panic, os << "Panic(" << e.dst << ";)"; ), (If, os << "If( " << e.cond << " : " << e.bb0 << ", " << e.bb1 << ")"; ), (Switch, os << "Switch( " << e.val << " : "; for(unsigned int j = 0; j < e.targets.size(); j ++) os << j << " => bb" << e.targets[j] << ", "; os << ")"; ), (Call, os << "Call( " << e.ret_val << " = "; TU_MATCHA( (e.fcn), (e2), (Value, os << "(" << e2 << ")"; ), (Path, os << e2; ), (Intrinsic, os << "\"" << e2.name << "\"::" << e2.params; ) ) os << "( "; for(const auto& arg : e.args) os << arg << ", "; os << "), bb" << e.ret_block << ", bb" << e.panic_block << ")"; ) ) return os; } } ::MIR::LValue MIR::LValue::clone() const { TU_MATCHA( (*this), (e), (Variable, return LValue(e); ), (Temporary, return LValue(e); ), (Argument, return LValue(e); ), (Static, return LValue(e.clone()); ), (Return, return LValue(e); ), (Field, return LValue::make_Field({ box$( e.val->clone() ), e.field_index }); ), (Deref, return LValue::make_Deref({ box$( e.val->clone() ) }); ), (Index, return LValue::make_Index({ box$( e.val->clone() ), box$( e.idx->clone() ) }); ), (Downcast, return LValue::make_Downcast({ box$( e.val->clone() ), e.variant_index }); ) ) throw ""; }