mirror of
https://github.com/Mr-X-GTA/YimMenu.git
synced 2025-01-07 09:53:50 +08:00
fix(BytePatch): To ensure proper cleanup make use of unique_ptr (#491)
This commit is contained in:
parent
a11e7e0aff
commit
de15a7c280
@ -10,32 +10,24 @@ namespace memory
|
||||
memcpy(m_address, m_original_bytes.data(), m_original_bytes.size());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// To guarantee proper restoration of bytes all shared_ptr instances will be invalidated that point to this object.
|
||||
/// </summary>
|
||||
void restore() const
|
||||
{
|
||||
if (const auto it = std::find(m_patches.begin(), m_patches.end(), this); it != m_patches.end())
|
||||
{
|
||||
it->reset();
|
||||
m_patches.erase(it);
|
||||
}
|
||||
}
|
||||
|
||||
template <typename TAddr>
|
||||
static std::shared_ptr<byte_patch> make(TAddr address, std::remove_pointer_t<std::remove_reference_t<TAddr>> value)
|
||||
static const std::unique_ptr<byte_patch>& make(TAddr address, std::remove_pointer_t<std::remove_reference_t<TAddr>> value)
|
||||
{
|
||||
auto patch = std::shared_ptr<byte_patch>(new byte_patch(address, value));
|
||||
m_patches.emplace_back(patch);
|
||||
return patch;
|
||||
return m_patches.emplace_back(
|
||||
std::unique_ptr<byte_patch>(new byte_patch(address, value)));
|
||||
}
|
||||
|
||||
static void restore_all()
|
||||
{
|
||||
for (const auto& patch : m_patches)
|
||||
{
|
||||
patch->restore();
|
||||
}
|
||||
m_patches.clear();
|
||||
}
|
||||
|
||||
private:
|
||||
@ -51,16 +43,16 @@ namespace memory
|
||||
}
|
||||
|
||||
protected:
|
||||
static inline std::vector<std::shared_ptr<byte_patch>> m_patches;
|
||||
static inline std::vector<std::unique_ptr<byte_patch>> m_patches;
|
||||
|
||||
private:
|
||||
void* m_address;
|
||||
std::vector<uint8_t> m_original_bytes;
|
||||
|
||||
friend bool operator== (const std::shared_ptr<byte_patch> a, const byte_patch* b);
|
||||
friend bool operator== (const std::unique_ptr<byte_patch>& a, const byte_patch* b);
|
||||
};
|
||||
|
||||
bool operator== (const std::shared_ptr<byte_patch> a, const byte_patch* b)
|
||||
bool operator== (const std::unique_ptr<byte_patch>& a, const byte_patch* b)
|
||||
{
|
||||
return a->m_address == b->m_address;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user