]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - radiant/dialog.h
Introduce Property<T> to simplify preferences system
[xonotic/netradiant.git] / radiant / dialog.h
index cf2b2362d809ccd483abf66098e3b1864e41d1c5..0147eb2cddffae9df6c5ca32e9c333f7087726e2 100644 (file)
 
 #include <list>
 #include <uilib/uilib.h>
+#include "property.h"
 
 #include "generic/callback.h"
 #include "gtkutil/dialog.h"
 #include "generic/callback.h"
 #include "string/string.h"
 
-template<class Self, class T = Self>
-struct impexp {
-    static void Import(Self &self, T value) {
-        self = value;
-    }
-
-    static void Export(Self &self, const Callback<void(T)> &importCallback) {
-        importCallback(self);
-    }
-};
-
-template<class Self, class T = Self>
-ImportExportCallback<T> mkImportExportCallback(Self &self) {
-    return {
-            ReferenceCaller<Self, void(T), impexp<Self, T>::Import>(self),
-            ReferenceCaller<Self, void(const Callback<void(T)> &), impexp<Self, T>::Export>(self)
-    };
-}
-
-#define BoolImport impexp<bool>::Import
-#define BoolExport impexp<bool>::Export
-
-typedef ReferenceCaller<bool, void(const Callback<void(bool)> &), BoolExport> BoolExportCaller;
-
-#define IntImport impexp<int>::Import
-#define IntExport impexp<int>::Export
-
-typedef ReferenceCaller<int, void(const Callback<void(int)> &), IntExport> IntExportCaller;
-
-#define SizeImport impexp<std::size_t>::Import
-#define SizeExport impexp<std::size_t>::Export
-
-
-#define FloatImport impexp<float>::Import
-#define FloatExport impexp<float>::Export
-
-typedef ReferenceCaller<float, void(const Callback<void(float)> &), FloatExport> FloatExportCaller;
-
-#define StringImport impexp<CopiedString, const char *>::Import
-#define StringExport impexp<CopiedString, const char *>::Export
-
-template<>
-struct impexp<CopiedString, const char *> {
-    static void Import(CopiedString &self, const char *value) {
-        self = value;
-    }
-
-    static void Export(CopiedString &self, const Callback<void(const char *)> &importCallback) {
-        importCallback(self.c_str());
-    }
-};
-
-typedef ReferenceCaller<CopiedString, void(const Callback<void(const char *)> &), StringExport> StringExportCaller;
-
-
 struct DLG_DATA
 {
        virtual ~DLG_DATA() = default;
@@ -132,66 +78,66 @@ const ui::Window GetWidget() const {
        return m_window;
 }
 
-    ui::CheckButton addCheckBox(ui::VBox vbox, const char *name, const char *flag, ImportExportCallback<bool> const &cb);
+    ui::CheckButton addCheckBox(ui::VBox vbox, const char *name, const char *flag, Property<bool> const &cb);
 ui::CheckButton addCheckBox( ui::VBox vbox, const char* name, const char* flag, bool& data );
 
-    void addCombo(ui::VBox vbox, const char *name, StringArrayRange values, ImportExportCallback<int> const &cb);
+    void addCombo(ui::VBox vbox, const char *name, StringArrayRange values, Property<int> const &cb);
 void addCombo( ui::VBox vbox, const char* name, int& data, StringArrayRange values );
 void addSlider( ui::VBox vbox, const char* name, int& data, gboolean draw_value, const char* low, const char* high, double value, double lower, double upper, double step_increment, double page_increment );
 
-    void addRadio(ui::VBox vbox, const char *name, StringArrayRange names, ImportExportCallback<int> const &cb);
+    void addRadio(ui::VBox vbox, const char *name, StringArrayRange names, Property<int> const &cb);
 void addRadio( ui::VBox vbox, const char* name, int& data, StringArrayRange names );
 
-    void addRadioIcons(ui::VBox vbox, const char *name, StringArrayRange icons, ImportExportCallback<int> const &cb);
+    void addRadioIcons(ui::VBox vbox, const char *name, StringArrayRange icons, Property<int> const &cb);
 void addRadioIcons( ui::VBox vbox, const char* name, int& data, StringArrayRange icons );
 
-    ui::Widget addIntEntry(ui::VBox vbox, const char *name, ImportExportCallback<int> const &cb);
+    ui::Widget addIntEntry(ui::VBox vbox, const char *name, Property<int> const &cb);
 ui::Widget addEntry( ui::VBox vbox, const char* name, int& data ){
-    return addIntEntry(vbox, name, mkImportExportCallback(data));
+    return addIntEntry(vbox, name, make_property(data));
 }
 
-    ui::Widget addSizeEntry(ui::VBox vbox, const char *name, ImportExportCallback<std::size_t> const &cb);
+    ui::Widget addSizeEntry(ui::VBox vbox, const char *name, Property<std::size_t> const &cb);
 ui::Widget addEntry( ui::VBox vbox, const char* name, std::size_t& data ){
-    return addSizeEntry(vbox, name, mkImportExportCallback(data));
+    return addSizeEntry(vbox, name, make_property(data));
 }
 
-    ui::Widget addFloatEntry(ui::VBox vbox, const char *name, ImportExportCallback<float> const &cb);
+    ui::Widget addFloatEntry(ui::VBox vbox, const char *name, Property<float> const &cb);
 ui::Widget addEntry( ui::VBox vbox, const char* name, float& data ){
-    return addFloatEntry(vbox, name, mkImportExportCallback(data));
+    return addFloatEntry(vbox, name, make_property(data));
 }
 
     ui::Widget
-    addPathEntry(ui::VBox vbox, const char *name, bool browse_directory, ImportExportCallback<const char *> const &cb);
+    addPathEntry(ui::VBox vbox, const char *name, bool browse_directory, Property<const char *> const &cb);
 ui::Widget addPathEntry( ui::VBox vbox, const char* name, CopiedString& data, bool directory );
 ui::SpinButton addSpinner( ui::VBox vbox, const char* name, int& data, double value, double lower, double upper );
 
     ui::SpinButton
-    addSpinner(ui::VBox vbox, const char *name, double value, double lower, double upper, ImportExportCallback<int> const &cb);
+    addSpinner(ui::VBox vbox, const char *name, double value, double lower, double upper, Property<int> const &cb);
 
     ui::SpinButton addSpinner(ui::VBox vbox, const char *name, double value, double lower, double upper,
-                              ImportExportCallback<float> const &cb);
+                              Property<float> const &cb);
 
 protected:
 
-    void AddBoolToggleData(struct _GtkToggleButton &object, ImportExportCallback<bool> const &cb);
+    void AddBoolToggleData(struct _GtkToggleButton &object, Property<bool> const &cb);
 
-    void AddIntRadioData(struct _GtkRadioButton &object, ImportExportCallback<int> const &cb);
+    void AddIntRadioData(struct _GtkRadioButton &object, Property<int> const &cb);
 
-    void AddTextEntryData(struct _GtkEntry &object, ImportExportCallback<const char *> const &cb);
+    void AddTextEntryData(struct _GtkEntry &object, Property<const char *> const &cb);
 
-    void AddIntEntryData(struct _GtkEntry &object, ImportExportCallback<int> const &cb);
+    void AddIntEntryData(struct _GtkEntry &object, Property<int> const &cb);
 
-    void AddSizeEntryData(struct _GtkEntry &object, ImportExportCallback<std::size_t> const &cb);
+    void AddSizeEntryData(struct _GtkEntry &object, Property<std::size_t> const &cb);
 
-    void AddFloatEntryData(struct _GtkEntry &object, ImportExportCallback<float> const &cb);
+    void AddFloatEntryData(struct _GtkEntry &object, Property<float> const &cb);
 
-    void AddFloatSpinnerData(struct _GtkSpinButton &object, ImportExportCallback<float> const &cb);
+    void AddFloatSpinnerData(struct _GtkSpinButton &object, Property<float> const &cb);
 
-    void AddIntSpinnerData(struct _GtkSpinButton &object, ImportExportCallback<int> const &cb);
+    void AddIntSpinnerData(struct _GtkSpinButton &object, Property<int> const &cb);
 
-    void AddIntAdjustmentData(struct _GtkAdjustment &object, ImportExportCallback<int> const &cb);
+    void AddIntAdjustmentData(struct _GtkAdjustment &object, Property<int> const &cb);
 
-    void AddIntComboData(struct _GtkComboBox &object, ImportExportCallback<int> const &cb);
+    void AddIntComboData(struct _GtkComboBox &object, Property<int> const &cb);
 
 void AddDialogData( struct _GtkToggleButton& object, bool& data );
 void AddDialogData( struct _GtkRadioButton& object, int& data );