diff options
author | Björn Steinbrink <B.Steinbrink@gmx.de> | 2006-02-01 12:24:10 +0000 |
---|---|---|
committer | Björn Steinbrink <B.Steinbrink@gmx.de> | 2006-02-01 12:24:10 +0000 |
commit | 4490b8643f2449da159c9284503eb2c443aa2e9e (patch) | |
tree | d859ebeb3ee69b89c471793b76f9df7fe9546137 /src/gui/ok_dialog.cpp | |
parent | 6bff53b318937999a70d775bb6ecea2b18576e0f (diff) | |
download | mana-4490b8643f2449da159c9284503eb2c443aa2e9e.tar.gz mana-4490b8643f2449da159c9284503eb2c443aa2e9e.tar.bz2 mana-4490b8643f2449da159c9284503eb2c443aa2e9e.tar.xz mana-4490b8643f2449da159c9284503eb2c443aa2e9e.zip |
Made the OkDialog and ConfirmDialog classes proxies for their buttons' events. Removed the RequestTradeWindow class, replaced with a plain ConfirmDialog. Fixed a memory leak along the way.
Diffstat (limited to 'src/gui/ok_dialog.cpp')
-rw-r--r-- | src/gui/ok_dialog.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/src/gui/ok_dialog.cpp b/src/gui/ok_dialog.cpp index 2e2594d1..8d2ebc23 100644 --- a/src/gui/ok_dialog.cpp +++ b/src/gui/ok_dialog.cpp @@ -29,7 +29,7 @@ OkDialog::OkDialog(const std::string &title, const std::string &msg, - gcn::ActionListener *listener, Window *parent): + Window *parent): Window(title, true, parent) { gcn::Label *textLabel = new gcn::Label(msg); @@ -49,9 +49,6 @@ OkDialog::OkDialog(const std::string &title, const std::string &msg, okButton->setEventId("ok"); okButton->addActionListener(this); - if (listener) { - okButton->addActionListener(listener); - } add(textLabel); add(okButton); @@ -62,6 +59,13 @@ OkDialog::OkDialog(const std::string &title, const std::string &msg, void OkDialog::action(const std::string &eventId) { + // Proxy button events to our listeners + ActionListenerIterator i; + for (i = mActionListeners.begin(); i != mActionListeners.end(); ++i) + { + (*i)->action(eventId); + } + // Can we receive anything else anyway? if (eventId == "ok") { scheduleDelete(); |