summaryrefslogtreecommitdiff
path: root/src/dialogues/ErrorMessage.cpp
diff options
context:
space:
mode:
authorSimon Robertshaw <simon@hardwired.org.uk>2012-08-18 21:08:20 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2012-08-18 21:08:20 (GMT)
commit740f0d30c3d5badc10da09af875b47d67128048b (patch)
tree2c9ce272c8a9afb75c55ef5a3d73973143cd89a8 /src/dialogues/ErrorMessage.cpp
parent63da7a4afec50035c6aa37a29a8d60d38cab969f (diff)
downloadpowder-740f0d30c3d5badc10da09af875b47d67128048b.zip
powder-740f0d30c3d5badc10da09af875b47d67128048b.tar.gz
Blocking Confirm/Error/Input prompts (EngineProcess creates a new event loop which can be broken out of with Engine::Break())
Diffstat (limited to 'src/dialogues/ErrorMessage.cpp')
-rw-r--r--src/dialogues/ErrorMessage.cpp26
1 files changed, 23 insertions, 3 deletions
diff --git a/src/dialogues/ErrorMessage.cpp b/src/dialogues/ErrorMessage.cpp
index 9bff8fb..083e541 100644
--- a/src/dialogues/ErrorMessage.cpp
+++ b/src/dialogues/ErrorMessage.cpp
@@ -9,9 +9,11 @@
#include "ErrorMessage.h"
#include "interface/Button.h"
#include "interface/Label.h"
+#include "PowderToy.h"
-ErrorMessage::ErrorMessage(std::string title, std::string message):
- ui::Window(ui::Point(-1, -1), ui::Point(200, 75))
+ErrorMessage::ErrorMessage(std::string title, std::string message, ErrorMessageCallback * callback_):
+ ui::Window(ui::Point(-1, -1), ui::Point(200, 75)),
+ callback(callback_)
{
ui::Label * titleLabel = new ui::Label(ui::Point(4, 5), ui::Point(Size.X-8, 16), title);
titleLabel->SetTextColour(style::Colour::ErrorTitle);
@@ -32,7 +34,9 @@ ErrorMessage::ErrorMessage(std::string title, std::string message):
void ActionCallback(ui::Button * sender)
{
ui::Engine::Ref().CloseWindow();
- message->SelfDestruct(); //TODO: Fix component disposal
+ if(message->callback)
+ message->callback->DismissCallback();
+ message->SelfDestruct();
}
};
@@ -48,6 +52,20 @@ ErrorMessage::ErrorMessage(std::string title, std::string message):
ui::Engine::Ref().ShowWindow(this);
}
+void ErrorMessage::Blocking(std::string title, std::string message)
+{
+ class BlockingDismissCallback: public ErrorMessageCallback {
+ public:
+ BlockingDismissCallback() {}
+ virtual void DismissCallback() {
+ ui::Engine::Ref().Break();
+ }
+ virtual ~BlockingDismissCallback() { }
+ };
+ new ErrorMessage(title, message, new BlockingDismissCallback());
+ EngineProcess();
+}
+
void ErrorMessage::OnDraw()
{
Graphics * g = ui::Engine::Ref().g;
@@ -57,5 +75,7 @@ void ErrorMessage::OnDraw()
}
ErrorMessage::~ErrorMessage() {
+ if(callback)
+ delete callback;
}