1
0
Fork 0
mirror of https://git.suyu.dev/suyu/sirit.git synced 2025-01-08 19:56:06 +00:00

operand: Move operand_type initialization to constructor

This commit is contained in:
ReinUsesLisp 2019-11-01 05:52:49 -03:00
parent 53d572ae7d
commit 4c2981eab5
5 changed files with 11 additions and 15 deletions

View file

@ -9,9 +9,8 @@
namespace Sirit { namespace Sirit {
LiteralNumber::LiteralNumber(u64 raw, bool is_32) : raw{raw}, is_32{is_32} { LiteralNumber::LiteralNumber(u64 raw, bool is_32)
operand_type = OperandType::Number; : Operand{OperandType::Number}, raw{raw}, is_32{is_32} {}
}
LiteralNumber::~LiteralNumber() = default; LiteralNumber::~LiteralNumber() = default;
@ -28,7 +27,7 @@ u16 LiteralNumber::GetWordCount() const {
} }
bool LiteralNumber::operator==(const Operand& other) const { bool LiteralNumber::operator==(const Operand& other) const {
if (operand_type == other.GetType()) { if (GetType() == other.GetType()) {
const auto& o{static_cast<const LiteralNumber&>(other)}; const auto& o{static_cast<const LiteralNumber&>(other)};
return o.raw == raw && o.is_32 == is_32; return o.raw == raw && o.is_32 == is_32;
} }

View file

@ -10,9 +10,8 @@
namespace Sirit { namespace Sirit {
LiteralString::LiteralString(std::string string) : string{std::move(string)} { LiteralString::LiteralString(std::string string)
operand_type = OperandType::String; : Operand{OperandType::String}, string{std::move(string)} {}
}
LiteralString::~LiteralString() = default; LiteralString::~LiteralString() = default;
@ -25,7 +24,7 @@ u16 LiteralString::GetWordCount() const {
} }
bool LiteralString::operator==(const Operand& other) const { bool LiteralString::operator==(const Operand& other) const {
if (operand_type == other.GetType()) { if (GetType() == other.GetType()) {
return static_cast<const LiteralString&>(other).string == string; return static_cast<const LiteralString&>(other).string == string;
} }
return false; return false;

View file

@ -16,9 +16,7 @@
namespace Sirit { namespace Sirit {
Op::Op(spv::Op opcode, std::optional<u32> id, Id result_type) Op::Op(spv::Op opcode, std::optional<u32> id, Id result_type)
: opcode(opcode), result_type(result_type), id(id) { : Operand{OperandType::Op}, opcode(opcode), result_type(result_type), id(id) {}
operand_type = OperandType::Op;
}
Op::~Op() = default; Op::~Op() = default;
@ -32,7 +30,7 @@ u16 Op::GetWordCount() const {
} }
bool Op::operator==(const Operand& other) const { bool Op::operator==(const Operand& other) const {
if (operand_type != other.GetType()) { if (GetType() != other.GetType()) {
return false; return false;
} }
const auto& op = static_cast<const Op&>(other); const auto& op = static_cast<const Op&>(other);

View file

@ -9,7 +9,7 @@
namespace Sirit { namespace Sirit {
Operand::Operand() = default; Operand::Operand(OperandType operand_type) : operand_type{operand_type} {}
Operand::~Operand() = default; Operand::~Operand() = default;

View file

@ -14,7 +14,7 @@ enum class OperandType { Invalid, Op, Number, String };
class Operand { class Operand {
public: public:
Operand(); explicit Operand(OperandType operand_type);
virtual ~Operand(); virtual ~Operand();
virtual void Fetch(Stream& stream) const; virtual void Fetch(Stream& stream) const;
@ -25,7 +25,7 @@ public:
OperandType GetType() const; OperandType GetType() const;
protected: private:
OperandType operand_type{}; OperandType operand_type{};
}; };