1
0
Fork 0
mirror of https://git.suyu.dev/suyu/sirit.git synced 2025-01-03 09:26:03 +00:00

op: Replace owning star pointers with unique_ptr

This commit is contained in:
ReinUsesLisp 2019-11-01 05:33:53 -03:00
parent ef47087d88
commit de91660f3c
3 changed files with 10 additions and 19 deletions

View file

@ -7,6 +7,7 @@
#pragma once #pragma once
#include <cstring> #include <cstring>
#include <memory>
#include <typeindex> #include <typeindex>
#include "operand.h" #include "operand.h"
#include "stream.h" #include "stream.h"
@ -24,10 +25,10 @@ public:
bool operator==(const Operand& other) const override; bool operator==(const Operand& other) const override;
template <typename T> template <typename T>
static LiteralNumber* Create(T value) { static std::unique_ptr<LiteralNumber> Create(T value) {
static_assert(sizeof(T) == 4 || sizeof(T) == 8); static_assert(sizeof(T) == 4 || sizeof(T) == 8);
LiteralNumber* number = new LiteralNumber(std::type_index(typeid(T))); auto number = std::make_unique<LiteralNumber>(std::type_index(typeid(T)));
number->is_32 = sizeof(T) == 4; number->is_32 = sizeof(T) == 4;
std::memcpy(&number->raw, &value, sizeof(T)); std::memcpy(&number->raw, &value, sizeof(T));
return number; return number;

View file

@ -62,20 +62,13 @@ void Op::Write(Stream& stream) const {
} }
} }
void Op::Sink(Operand* operand) { void Op::Sink(std::unique_ptr<Operand> operand) {
assert(operand); Add(static_cast<const Operand*>(operand.get()));
Add(static_cast<const Operand*>(operand)); operand_store.push_back(std::move(operand));
operand_store.push_back(std::unique_ptr<Operand>(operand));
}
void Op::Sink(const std::vector<Operand*>& operands_) {
for (auto* operand : operands_) {
Sink(operand);
}
} }
void Op::Add(const Literal& literal) { void Op::Add(const Literal& literal) {
Operand* operand = [&]() { Sink([&] {
switch (literal.index()) { switch (literal.index()) {
case 0: case 0:
return LiteralNumber::Create(std::get<0>(literal)); return LiteralNumber::Create(std::get<0>(literal));
@ -93,8 +86,7 @@ void Op::Add(const Literal& literal) {
assert(!"Invalid literal type"); assert(!"Invalid literal type");
abort(); abort();
} }
}(); }());
Sink(operand);
} }
void Op::Add(const std::vector<Literal>& literals) { void Op::Add(const std::vector<Literal>& literals) {
@ -113,7 +105,7 @@ void Op::Add(u32 integer) {
} }
void Op::Add(std::string string) { void Op::Add(std::string string) {
Sink(new LiteralString(std::move(string))); Sink(std::make_unique<LiteralString>(std::move(string)));
} }
void Op::Add(const std::vector<Id>& ids) { void Op::Add(const std::vector<Id>& ids) {

View file

@ -26,9 +26,7 @@ public:
void Write(Stream& stream) const; void Write(Stream& stream) const;
void Sink(Operand* operand); void Sink(std::unique_ptr<Operand> operand);
void Sink(const std::vector<Operand*>& operands_);
void Add(const Literal& literal); void Add(const Literal& literal);