mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-26 09:25:59 +01:00
fixed ASSERT and last commit's oopsie
This commit is contained in:
parent
de8d2fd136
commit
144a79ee00
3 changed files with 19 additions and 3 deletions
|
@ -26,6 +26,10 @@
|
||||||
|
|
||||||
#define HYPRATOM(name) {name, 0}
|
#define HYPRATOM(name) {name, 0}
|
||||||
|
|
||||||
#define RASSERT(expr, reason) if (expr) { Debug::log(CRIT, "\n==========================================================================================\nASSERTION FAILED! \n\n%s\n\nat: line %s in %s", reason, __LINE__, __FILE__); RIP("Assertion failed! See the log in /tmp/hypr/hyprland.log for more info.");}
|
#define RASSERT(expr, reason) \
|
||||||
|
if (!expr) { \
|
||||||
|
Debug::log(CRIT, "\n==========================================================================================\nASSERTION FAILED! \n\n%s\n\nat: line %d in %s", std::string(reason).c_str(), __LINE__, ([]() constexpr->std::string { return std::string(__FILE__).substr(std::string(__FILE__).find_last_of('/') + 1); })().c_str()); \
|
||||||
|
RIP("Assertion failed! See the log in /tmp/hypr/hyprland.log for more info."); \
|
||||||
|
}
|
||||||
|
|
||||||
#define ASSERT(expr) RASSERT(expr, "?")
|
#define ASSERT(expr) RASSERT(expr, "?")
|
|
@ -141,7 +141,9 @@ void Events::listener_unmapWindow(wl_listener* listener, void* data) {
|
||||||
// refocus on a new window
|
// refocus on a new window
|
||||||
g_pInputManager->refocus();
|
g_pInputManager->refocus();
|
||||||
|
|
||||||
|
|
||||||
SubsurfaceTree::destroySurfaceTree(PWINDOW->m_pSurfaceTree);
|
SubsurfaceTree::destroySurfaceTree(PWINDOW->m_pSurfaceTree);
|
||||||
|
|
||||||
PWINDOW->m_pSurfaceTree = nullptr;
|
PWINDOW->m_pSurfaceTree = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -56,6 +56,16 @@ SSurfaceTreeNode* SubsurfaceTree::createTreeRoot(wlr_surface* pSurface, applyGlo
|
||||||
void destroySubsurface(SSubsurface* pSubsurface);
|
void destroySubsurface(SSubsurface* pSubsurface);
|
||||||
|
|
||||||
void SubsurfaceTree::destroySurfaceTree(SSurfaceTreeNode* pNode) {
|
void SubsurfaceTree::destroySurfaceTree(SSurfaceTreeNode* pNode) {
|
||||||
|
bool exists = false;
|
||||||
|
for (auto& n : surfaceTreeNodes) {
|
||||||
|
if (&n == pNode) {
|
||||||
|
exists = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RASSERT(exists, "Tried to delete a surfaceTreeNode that doesn't exist!");
|
||||||
|
|
||||||
for (auto& c : pNode->childSubsurfaces)
|
for (auto& c : pNode->childSubsurfaces)
|
||||||
destroySubsurface(&c);
|
destroySubsurface(&c);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue