Add a callback mechanism to the options dialog so that other parts of vncviewer
can pick up on changes.
git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4421 3789f03b-4d11-0410-bbf8-ca57d06f2519
diff --git a/vncviewer/OptionsDialog.cxx b/vncviewer/OptionsDialog.cxx
index f69a299..8fe7eec 100644
--- a/vncviewer/OptionsDialog.cxx
+++ b/vncviewer/OptionsDialog.cxx
@@ -42,6 +42,8 @@
using namespace rdr;
using namespace rfb;
+std::map<OptionsCallback*, void*> OptionsDialog::callbacks;
+
OptionsDialog::OptionsDialog()
: Fl_Window(450, 450, _("VNC Viewer: Connection Options"))
{
@@ -101,6 +103,18 @@
}
+void OptionsDialog::addCallback(OptionsCallback *cb, void *data)
+{
+ callbacks[cb] = data;
+}
+
+
+void OptionsDialog::removeCallback(OptionsCallback *cb)
+{
+ callbacks.erase(cb);
+}
+
+
void OptionsDialog::show(void)
{
loadOptions();
@@ -333,6 +347,11 @@
fullScreen.setParam(fullScreenCheckbox->value());
useLocalCursor.setParam(localCursorCheckbox->value());
dotWhenNoCursor.setParam(dotCursorCheckbox->value());
+
+ std::map<OptionsCallback*, void*>::const_iterator iter;
+
+ for (iter = callbacks.begin();iter != callbacks.end();++iter)
+ iter->first(iter->second);
}
diff --git a/vncviewer/OptionsDialog.h b/vncviewer/OptionsDialog.h
index cb18bcd..ea95859 100644
--- a/vncviewer/OptionsDialog.h
+++ b/vncviewer/OptionsDialog.h
@@ -19,12 +19,16 @@
#ifndef __OPTIONSDIALOG_H__
#define __OPTIONSDIALOG_H__
+#include <map>
+
#include <FL/Fl_Window.H>
#include <FL/Fl_Group.H>
#include <FL/Fl_Check_Button.H>
#include <FL/Fl_Round_Button.H>
#include <FL/Fl_Int_Input.H>
+typedef void (OptionsCallback)(void*);
+
class OptionsDialog : public Fl_Window {
protected:
OptionsDialog();
@@ -33,6 +37,9 @@
public:
static void showDialog(void);
+ static void addCallback(OptionsCallback *cb, void *data = NULL);
+ static void removeCallback(OptionsCallback *cb);
+
void show(void);
protected:
@@ -55,6 +62,8 @@
static void handleOK(Fl_Widget *widget, void *data);
protected:
+ static std::map<OptionsCallback*, void*> callbacks;
+
/* Compression */
Fl_Check_Button *autoselectCheckbox;