log history memory usage add fix virtual dtor for Action subclasses to be deleted from memory
This commit is contained in:
@@ -223,44 +223,44 @@
|
|||||||
AD58E0511E107411006ACC15 /* engine */ = {
|
AD58E0511E107411006ACC15 /* engine */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
AD744B6C1EBC9EF700B66E30 /* canvas_modes.cpp */,
|
|
||||||
AD744B6D1EBC9EF800B66E30 /* canvas_modes.h */,
|
|
||||||
ADB1C3DB1EA531B0009A65BD /* keymap.h */,
|
|
||||||
ADB1C3D81EA3A156009A65BD /* event.cpp */,
|
|
||||||
ADB1C3D91EA3A156009A65BD /* event.h */,
|
|
||||||
AD29CC601EA2B214008C8BFA /* action.cpp */,
|
AD29CC601EA2B214008C8BFA /* action.cpp */,
|
||||||
AD29CC611EA2B214008C8BFA /* action.h */,
|
AD29CC611EA2B214008C8BFA /* action.h */,
|
||||||
AD8CF71F1E913F0500083FFD /* log.cpp */,
|
AD58E0701E2A90EF006ACC15 /* app.cpp */,
|
||||||
AD8CF7201E913F0500083FFD /* log.h */,
|
AD58E0711E2A90EF006ACC15 /* app.h */,
|
||||||
AD4C08CF1E89BD0F0051D85F /* asset.cpp */,
|
AD4C08CF1E89BD0F0051D85F /* asset.cpp */,
|
||||||
AD4C08D01E89BD0F0051D85F /* asset.h */,
|
AD4C08D01E89BD0F0051D85F /* asset.h */,
|
||||||
AD4C08D11E89BD0F0051D85F /* bezier.cpp */,
|
AD4C08D11E89BD0F0051D85F /* bezier.cpp */,
|
||||||
AD4C08D21E89BD0F0051D85F /* bezier.h */,
|
AD4C08D21E89BD0F0051D85F /* bezier.h */,
|
||||||
AD4C08D31E89BD0F0051D85F /* brush.cpp */,
|
AD4C08D31E89BD0F0051D85F /* brush.cpp */,
|
||||||
AD4C08D41E89BD0F0051D85F /* brush.h */,
|
AD4C08D41E89BD0F0051D85F /* brush.h */,
|
||||||
|
AD744B6C1EBC9EF700B66E30 /* canvas_modes.cpp */,
|
||||||
|
AD744B6D1EBC9EF800B66E30 /* canvas_modes.h */,
|
||||||
AD4C08D51E89BD0F0051D85F /* canvas.cpp */,
|
AD4C08D51E89BD0F0051D85F /* canvas.cpp */,
|
||||||
AD4C08D61E89BD0F0051D85F /* canvas.h */,
|
AD4C08D61E89BD0F0051D85F /* canvas.h */,
|
||||||
AD4C08D71E89BD0F0051D85F /* rtt.cpp */,
|
ADB1C3D81EA3A156009A65BD /* event.cpp */,
|
||||||
AD4C08D81E89BD0F0051D85F /* rtt.h */,
|
ADB1C3D91EA3A156009A65BD /* event.h */,
|
||||||
AD95AEC31E41EDEC002DD03A /* font.cpp */,
|
AD95AEC31E41EDEC002DD03A /* font.cpp */,
|
||||||
AD95AEC41E41EDEC002DD03A /* font.h */,
|
AD95AEC41E41EDEC002DD03A /* font.h */,
|
||||||
AD95AEC51E41EDEC002DD03A /* pch.cpp */,
|
|
||||||
AD3B1EBE1E3B8B7600E918E3 /* layout.cpp */,
|
|
||||||
AD3B1EBF1E3B8B7600E918E3 /* layout.h */,
|
|
||||||
AD58E0631E2A76FD006ACC15 /* shader.cpp */,
|
|
||||||
AD58E0641E2A76FD006ACC15 /* shader.h */,
|
|
||||||
AD58E0521E107411006ACC15 /* main.cpp */,
|
|
||||||
AD58E06D1E2A80BC006ACC15 /* shape.cpp */,
|
|
||||||
AD58E06E1E2A80BC006ACC15 /* shape.h */,
|
|
||||||
AD58E0701E2A90EF006ACC15 /* app.cpp */,
|
|
||||||
AD58E0711E2A90EF006ACC15 /* app.h */,
|
|
||||||
AD58E0661E2A7741006ACC15 /* image.cpp */,
|
AD58E0661E2A7741006ACC15 /* image.cpp */,
|
||||||
AD58E0671E2A7741006ACC15 /* image.h */,
|
AD58E0671E2A7741006ACC15 /* image.h */,
|
||||||
|
ADB1C3DB1EA531B0009A65BD /* keymap.h */,
|
||||||
|
AD3B1EBE1E3B8B7600E918E3 /* layout.cpp */,
|
||||||
|
AD3B1EBF1E3B8B7600E918E3 /* layout.h */,
|
||||||
|
AD8CF71F1E913F0500083FFD /* log.cpp */,
|
||||||
|
AD8CF7201E913F0500083FFD /* log.h */,
|
||||||
|
AD58E0521E107411006ACC15 /* main.cpp */,
|
||||||
|
AD95AEC51E41EDEC002DD03A /* pch.cpp */,
|
||||||
|
AD58E06C1E2A78BD006ACC15 /* pch.h */,
|
||||||
|
AD4C08D71E89BD0F0051D85F /* rtt.cpp */,
|
||||||
|
AD4C08D81E89BD0F0051D85F /* rtt.h */,
|
||||||
|
AD58E0631E2A76FD006ACC15 /* shader.cpp */,
|
||||||
|
AD58E0641E2A76FD006ACC15 /* shader.h */,
|
||||||
|
AD58E06D1E2A80BC006ACC15 /* shape.cpp */,
|
||||||
|
AD58E06E1E2A80BC006ACC15 /* shape.h */,
|
||||||
AD58E0691E2A774F006ACC15 /* texture.cpp */,
|
AD58E0691E2A774F006ACC15 /* texture.cpp */,
|
||||||
AD58E06A1E2A774F006ACC15 /* texture.h */,
|
AD58E06A1E2A774F006ACC15 /* texture.h */,
|
||||||
ADB61C801E3D38450093280F /* util.cpp */,
|
ADB61C801E3D38450093280F /* util.cpp */,
|
||||||
ADB61C811E3D38450093280F /* util.h */,
|
ADB61C811E3D38450093280F /* util.h */,
|
||||||
AD58E06C1E2A78BD006ACC15 /* pch.h */,
|
|
||||||
);
|
);
|
||||||
path = engine;
|
path = engine;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
#include "log.h"
|
||||||
#include "action.h"
|
#include "action.h"
|
||||||
|
|
||||||
ActionManager ActionManager::I;
|
ActionManager ActionManager::I;
|
||||||
|
|||||||
@@ -5,6 +5,8 @@ class Action
|
|||||||
public:
|
public:
|
||||||
virtual void run() = 0;
|
virtual void run() = 0;
|
||||||
virtual void undo() = 0;
|
virtual void undo() = 0;
|
||||||
|
virtual size_t memory() = 0;
|
||||||
|
virtual ~Action(){};
|
||||||
};
|
};
|
||||||
|
|
||||||
class ActionManager
|
class ActionManager
|
||||||
@@ -12,13 +14,22 @@ class ActionManager
|
|||||||
public:
|
public:
|
||||||
static ActionManager I;
|
static ActionManager I;
|
||||||
std::stack<std::unique_ptr<Action>> m_actions;
|
std::stack<std::unique_ptr<Action>> m_actions;
|
||||||
|
size_t m_memory = 0;
|
||||||
static void add(Action* action)
|
static void add(Action* action)
|
||||||
{
|
{
|
||||||
I.m_actions.emplace(action);
|
I.m_actions.emplace(action);
|
||||||
|
I.m_memory += action->memory();
|
||||||
|
LOG("History: %.2f KB", I.m_memory / 1024.f);
|
||||||
}
|
}
|
||||||
static void undo()
|
static void undo()
|
||||||
{
|
{
|
||||||
I.m_actions.top()->undo();
|
I.m_actions.top()->undo();
|
||||||
|
I.m_memory -= I.m_actions.top()->memory();
|
||||||
I.m_actions.pop();
|
I.m_actions.pop();
|
||||||
|
LOG("History: %.2f KB", I.m_memory / 1024.f);
|
||||||
|
}
|
||||||
|
static bool empty()
|
||||||
|
{
|
||||||
|
return I.m_actions.empty();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -623,7 +623,8 @@ void App::initLayout()
|
|||||||
if (auto* button = layout[main_id]->find<NodeButton>("btn-undo"))
|
if (auto* button = layout[main_id]->find<NodeButton>("btn-undo"))
|
||||||
{
|
{
|
||||||
button->on_click = [this,button](Node*) {
|
button->on_click = [this,button](Node*) {
|
||||||
ActionManager::undo();
|
if (!ActionManager::empty())
|
||||||
|
ActionManager::undo();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
if (auto* button = layout[main_id]->find<NodeButton>("btn-clear"))
|
if (auto* button = layout[main_id]->find<NodeButton>("btn-clear"))
|
||||||
|
|||||||
@@ -157,6 +157,21 @@ public:
|
|||||||
m_canvas->m_layers[m_layer_idx].m_rtt[i].unbindTexture();
|
m_canvas->m_layers[m_layer_idx].m_rtt[i].unbindTexture();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
virtual size_t memory() override
|
||||||
|
{
|
||||||
|
size_t mem = 0;
|
||||||
|
for (int i = 0; i < 6; i++)
|
||||||
|
{
|
||||||
|
glm::vec2 sz = m_box[i].zw() - m_box[i].xy();
|
||||||
|
mem += sz.x * sz.y * 4 + sizeof(*this);
|
||||||
|
}
|
||||||
|
return mem;
|
||||||
|
}
|
||||||
|
virtual ~ActionStroke()
|
||||||
|
{
|
||||||
|
|
||||||
|
LOG("ActionStroke destroyed: free %zu bytes", memory());
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
NS_END
|
NS_END
|
||||||
|
|||||||
@@ -353,6 +353,7 @@ void CanvasModeFill::on_MouseEvent(MouseEvent* me, glm::vec2& loc)
|
|||||||
case kEventType::MouseCancel:
|
case kEventType::MouseCancel:
|
||||||
m_dragging = false;
|
m_dragging = false;
|
||||||
node->mouse_release();
|
node->mouse_release();
|
||||||
|
m_points.clear();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|||||||
Reference in New Issue
Block a user